On Mon, 2012-02-06 at 17:09 +0100, Stanislaw Gruszka wrote: > That will save us some CPU cycles at run time. > > Obviously I do not think port-based IO is possible, but I added > check for that during probe just in case. > > Signed-off-by: Stanislaw Gruszka <sgruszka@xxxxxxxxxx> > --- > drivers/net/wireless/iwlwifi/iwl-pci.c | 12 ++++++++---- > 1 files changed, 8 insertions(+), 4 deletions(-) > > diff --git a/drivers/net/wireless/iwlwifi/iwl-pci.c b/drivers/net/wireless/iwlwifi/iwl-pci.c > index 03702a2..32b326d 100644 > --- a/drivers/net/wireless/iwlwifi/iwl-pci.c > +++ b/drivers/net/wireless/iwlwifi/iwl-pci.c > @@ -153,18 +153,17 @@ static u32 iwl_pci_get_hw_id(struct iwl_bus *bus) > > static void iwl_pci_write8(struct iwl_bus *bus, u32 ofs, u8 val) > { > - iowrite8(val, IWL_BUS_GET_PCI_BUS(bus)->hw_base + ofs); > + writeb(val, IWL_BUS_GET_PCI_BUS(bus)->hw_base + ofs); > } > > static void iwl_pci_write32(struct iwl_bus *bus, u32 ofs, u32 val) > { > - iowrite32(val, IWL_BUS_GET_PCI_BUS(bus)->hw_base + ofs); > + writel(val, IWL_BUS_GET_PCI_BUS(bus)->hw_base + ofs); > } > http://www.gossamer-threads.com/lists/linux/kernel/960145 > static u32 iwl_pci_read32(struct iwl_bus *bus, u32 ofs) > { > - u32 val = ioread32(IWL_BUS_GET_PCI_BUS(bus)->hw_base + ofs); > - return val; > + return readl(IWL_BUS_GET_PCI_BUS(bus)->hw_base + ofs); > } > > static const struct iwl_bus_ops bus_ops_pci = { > @@ -417,6 +416,11 @@ static int iwl_pci_probe(struct pci_dev *pdev, const struct pci_device_id *ent) > goto out_pci_disable_device; > } > > + if (pci_resource_flags(pdev, 0) & IORESOURCE_IO) { > + dev_printk(KERN_ERR, bus->dev, "not supported I/O method"); > + goto out_pci_disable_device; > + } > + > pci_bus->hw_base = pci_iomap(pdev, 0, 0); > if (!pci_bus->hw_base) { > dev_printk(KERN_ERR, bus->dev, "pci_iomap failed"); I believe iwl driver were use readl/writel before switch to ioread32/iowrite32 (long time ago) http://www.gossamer-threads.com/lists/linux/kernel/960145 also, AFAIK, the readl/writel IO functions still works but their use in new code is discouraged. Wey -- To unsubscribe from this list: send the line "unsubscribe linux-wireless" in the body of a message to majordomo@xxxxxxxxxxxxxxx More majordomo info at http://vger.kernel.org/majordomo-info.html