diff options
author | Gabor Juhos <juhosg@openwrt.org> | 2009-10-01 19:41:00 +0000 |
---|---|---|
committer | Gabor Juhos <juhosg@openwrt.org> | 2009-10-01 19:41:00 +0000 |
commit | 5aae65b58c70460a589f251620834c2d792976ee (patch) | |
tree | d4e20d673cfee22b5ffe56da3672ab6f8768b9ed /target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c | |
parent | 0757fee42d9a0a5cc4f745c0c81a3c3af94d24c7 (diff) | |
download | mtk-20170518-5aae65b58c70460a589f251620834c2d792976ee.zip mtk-20170518-5aae65b58c70460a589f251620834c2d792976ee.tar.gz mtk-20170518-5aae65b58c70460a589f251620834c2d792976ee.tar.bz2 |
ar71xx: add PCI Host Controller fixup for ar724x
SVN-Revision: 17808
Diffstat (limited to 'target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c')
-rw-r--r-- | target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c | 23 |
1 files changed, 23 insertions, 0 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 02f3a8c..139af94 100644 --- a/target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c +++ b/target/linux/ar71xx/files/arch/mips/pci/pci-ar724x.c @@ -29,6 +29,7 @@ static void __iomem *ar724x_pci_localcfg_base; static void __iomem *ar724x_pci_devcfg_base; +static int ar724x_pci_fixup_enable; static DEFINE_SPINLOCK(ar724x_pci_lock); @@ -128,6 +129,27 @@ static int ar724x_pci_write_config(struct pci_bus *bus, unsigned int devfn, return PCIBIOS_SUCCESSFUL; } +static void ar724x_pci_fixup(struct pci_dev *dev) +{ + u32 t; + + if (!ar724x_pci_fixup_enable) + return; + + if (dev->bus->number != 0 || dev->devfn != 0) + return; + + DBG("PCI: fixup host controller %s (%04x:%04x)\n", pci_name(dev), + dev->vendor, dev->device); + + /* setup COMMAND register */ + t = PCI_COMMAND_MEMORY | PCI_COMMAND_MASTER | PCI_COMMAND_INVALIDATE + | PCI_COMMAND_PARITY | PCI_COMMAND_SERR | PCI_COMMAND_FAST_BACK; + + pci_write_config_word(dev, PCI_COMMAND, t); +} +DECLARE_PCI_FIXUP_EARLY(PCI_ANY_ID, PCI_ANY_ID, ar724x_pci_fixup); + int __init ar724x_pcibios_map_irq(const struct pci_dev *dev, uint8_t slot, uint8_t pin) { @@ -195,6 +217,7 @@ int __init ar724x_pcibios_init(void) ar724x_pci_write(ar724x_pci_localcfg_base, PCI_COMMAND, 4, t); + ar724x_pci_fixup_enable = 1; register_pci_controller(&ar724x_pci_controller); return 0; |