[U-Boot] [PATCH] pci/fsl_pci_init: Enable inbound PCI config cycles
Peter Tyser
ptyser at xes-inc.com
Wed Oct 29 00:37:23 CET 2008
Set CFG_READY bit in Configuration Ready Register for PCIe
devices and clear ACL bit in PBFR to allow Freescale devices
to respond to incoming PCI configuration cycles.
Signed-off-by: Peter Tyser <ptyser at xes-inc.com>
---
drivers/pci/fsl_pci_init.c | 17 +++++++++++++++++
1 files changed, 17 insertions(+), 0 deletions(-)
diff --git a/drivers/pci/fsl_pci_init.c b/drivers/pci/fsl_pci_init.c
index 7625ccc..6da9c22 100644
--- a/drivers/pci/fsl_pci_init.c
+++ b/drivers/pci/fsl_pci_init.c
@@ -37,6 +37,11 @@ DECLARE_GLOBAL_DATA_PTR;
#include <pci.h>
#include <asm/immap_fsl_pci.h>
+/* Freescale-specific PCI config registers */
+#define FSL_PCI_PBFR 0x44
+#define FSL_PCIE_CAP_ID 0x4c
+#define FSL_PCIE_CFG_RDY 0x4b0
+
void pciauto_prescan_setup_bridge(struct pci_controller *hose,
pci_dev_t dev, int sub_bus);
void pciauto_postscan_setup_bridge(struct pci_controller *hose,
@@ -302,6 +307,18 @@ void fsl_pci_init(struct pci_controller *hose)
if (temp16) {
pci_hose_write_config_word(hose, dev, PCI_SEC_STATUS, 0xffff);
}
+
+ /* Enable inbound PCI config cycles */
+ pci_hose_read_config_byte(hose, dev, FSL_PCIE_CAP_ID, &temp8);
+ if (temp8 != 0x0) {
+ /* PCIe - set CFG_READY bit of Configuration Ready Register */
+ pci_hose_write_config_byte(hose, dev, FSL_PCIE_CFG_RDY, 0x1);
+ } else {
+ /* PCI - clear ACL bit of PBFR */
+ pci_hose_read_config_word(hose, dev, FSL_PCI_PBFR, &temp16);
+ temp16 &= ~0x20;
+ pci_hose_write_config_byte(hose, dev, FSL_PCI_PBFR, temp16);
+ }
}
#ifdef CONFIG_OF_BOARD_SETUP
--
1.6.0.2.GIT
More information about the U-Boot
mailing list