diff options
author | juhosg <juhosg@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2010-03-18 19:19:07 +0000 |
---|---|---|
committer | juhosg <juhosg@3c298f89-4303-0410-b956-a3cf2f4a3e73> | 2010-03-18 19:19:07 +0000 |
commit | a95e8602caad2e0fa7000656bcbf8204e558dd25 (patch) | |
tree | 00d0207fff56aea512ed57a560bfacf765811304 /target | |
parent | 3079a4d84dc08f172a79eb38cf29146c0c82ba46 (diff) |
ar71xx: introduce global ar724x_pci_ctrl_base variable
git-svn-id: svn://svn.openwrt.org/openwrt/trunk@20284 3c298f89-4303-0410-b956-a3cf2f4a3e73
Diffstat (limited to 'target')
-rw-r--r-- | target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c | 34 |
1 files changed, 14 insertions, 20 deletions
diff --git a/target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c b/target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c index 251bf6d39..30b34dc7e 100644 --- a/target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c +++ b/target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c @@ -30,38 +30,25 @@ static void __iomem *ar724x_pci_localcfg_base; static void __iomem *ar724x_pci_devcfg_base; +static void __iomem *ar724x_pci_ctrl_base; static int ar724x_pci_fixup_enable; static DEFINE_SPINLOCK(ar724x_pci_lock); static inline void ar724x_pci_wr(unsigned reg, u32 val) { - void __iomem *base; - - base = ioremap_nocache(AR724X_PCI_CTRL_BASE, AR724X_PCI_CTRL_SIZE); - __raw_writel(val, base + reg); - (void) __raw_readl(base + reg); - iounmap(base); + __raw_writel(val, ar724x_pci_ctrl_base + reg); + (void) __raw_readl(ar724x_pci_ctrl_base + reg); } static inline void ar724x_pci_wr_nf(unsigned reg, u32 val) { - void __iomem *base; - - base = ioremap_nocache(AR724X_PCI_CTRL_BASE, AR724X_PCI_CTRL_SIZE); - __raw_writel(val, base + reg); - iounmap(base); + __raw_writel(val, ar724x_pci_ctrl_base + reg); } static inline u32 ar724x_pci_rr(unsigned reg) { - void __iomem *base; - u32 ret; - - base = ioremap_nocache(AR724X_PCI_CTRL_BASE, AR724X_PCI_CTRL_SIZE); - ret = __raw_readl(base + reg); - iounmap(base); - return ret; + return __raw_readl(ar724x_pci_ctrl_base + reg); } static void ar724x_pci_read(void __iomem *base, int where, int size, u32 *value) @@ -368,10 +355,15 @@ int __init ar724x_pcibios_init(void) if (ar724x_pci_devcfg_base == NULL) goto err_unmap_localcfg; + ar724x_pci_ctrl_base = ioremap_nocache(AR724X_PCI_CTRL_BASE, + AR724X_PCI_CTRL_SIZE); + if (ar724x_pci_ctrl_base == NULL) + goto err_unmap_devcfg; + ar724x_pci_reset(); ret = ar724x_pci_setup(); if (ret) - goto err_unmap_devcfg; + goto err_unmap_ctrl; ar724x_pci_fixup_enable = 1; ar724x_pci_irq_init(); @@ -379,7 +371,9 @@ int __init ar724x_pcibios_init(void) return 0; - err_unmap_devcfg: + err_unmap_ctrl: + iounmap(ar724x_pci_ctrl_base); + err_unmap_devcfg: iounmap(ar724x_pci_devcfg_base); err_unmap_localcfg: iounmap(ar724x_pci_localcfg_base); |