提交 08871c09 编写于 作者: P Prabhakar Kushwaha 提交者: Kumar Gala

powerpc/85xx: Add host-pci(e) bridge only for RC

FSL PCIe controller can act as agent(EP) or host(RC).  Under Agent(EP) mode
the controller will be configured by the host system.  So its not required
to be registered with the PCI(e) sub-system. We only register the
controller if its configured in host(RC) mode.
Signed-off-by: NVivek Mahajan <vivek.mahajan@freescale.com>
Signed-off-by: NPrabhakar Kushwaha <prabhakar@freescale.com>
Signed-off-by: NKumar Gala <galak@kernel.crashing.org>
上级 3907ab26
...@@ -330,6 +330,7 @@ int __init fsl_add_bridge(struct device_node *dev, int is_primary) ...@@ -330,6 +330,7 @@ int __init fsl_add_bridge(struct device_node *dev, int is_primary)
struct pci_controller *hose; struct pci_controller *hose;
struct resource rsrc; struct resource rsrc;
const int *bus_range; const int *bus_range;
u8 progif;
if (!of_device_is_available(dev)) { if (!of_device_is_available(dev)) {
pr_warning("%s: disabled\n", dev->full_name); pr_warning("%s: disabled\n", dev->full_name);
...@@ -360,6 +361,18 @@ int __init fsl_add_bridge(struct device_node *dev, int is_primary) ...@@ -360,6 +361,18 @@ int __init fsl_add_bridge(struct device_node *dev, int is_primary)
setup_indirect_pci(hose, rsrc.start, rsrc.start + 0x4, setup_indirect_pci(hose, rsrc.start, rsrc.start + 0x4,
PPC_INDIRECT_TYPE_BIG_ENDIAN); PPC_INDIRECT_TYPE_BIG_ENDIAN);
early_read_config_byte(hose, 0, 0, PCI_CLASS_PROG, &progif);
if ((progif & 1) == 1) {
/* unmap cfg_data & cfg_addr separately if not on same page */
if (((unsigned long)hose->cfg_data & PAGE_MASK) !=
((unsigned long)hose->cfg_addr & PAGE_MASK))
iounmap(hose->cfg_data);
iounmap(hose->cfg_addr);
pcibios_free_controller(hose);
return 0;
}
setup_pci_cmd(hose); setup_pci_cmd(hose);
/* check PCI express link status */ /* check PCI express link status */
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册