[PATCH 07/16] ARM: integrator: convert PCI to use generic config accesses
From: arnd@arndb.de (Arnd Bergmann)
Date: 2015-01-10 21:53:28
Also in:
linux-pci, lkml
From: arnd@arndb.de (Arnd Bergmann)
Date: 2015-01-10 21:53:28
Also in:
linux-pci, lkml
On Saturday 10 January 2015 22:40:22 Linus Walleij wrote:
quoted
static int v3_read_config(struct pci_bus *bus, unsigned int devfn, int where, int size, u32 *val) { - addr = v3_open_config_window(bus, devfn, where); + int ret = pci_generic_config_read(bus, devfn, where, size, val); v3_close_config_window(); + return ret; } static int v3_write_config(struct pci_bus *bus, unsigned int devfn, int where, int size, u32 val) { + int ret = pci_generic_config_write(bus, devfn, where, size, val); v3_close_config_window(); - raw_spin_unlock_irqrestore(&v3_lock, flags); + return ret; } static struct pci_ops pci_v3_ops = { + .map_bus = v3_open_config_window, .read = v3_read_config, .write = v3_write_config,So .map_bus is called before every .read/.write operation I take it. Wouldn't it be proper to call the v3_close_config_window() from a matching .unmap_bus() callback for symmetry?
It would be nicer for integrator but useless for anything else, so I'd vote for leaving it the way Rob posted. Arnd