On Apr 27, 2011, at 12:35 AM, Prabhakar Kushwaha wrote:

> FSL PCIe controller can act as agent(EP) or host(RC).
> Under Agent(EP) mode they are configured via Host. So it is not required to 
> add
> with the PCI(e) sub-system.
> 
> Add and configure PCIe controller only for RC mode.
> 
> Signed-off-by: Vivek Mahajan <vivek.maha...@freescale.com>
> Signed-off-by: Prabhakar Kushwaha <prabha...@freescale.com>
> ---
> Based upon 
> git://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux-2.6.git(branch 
> master)
> 
> arch/powerpc/sysdev/fsl_pci.c |   14 ++++++++++++++
> 1 files changed, 14 insertions(+), 0 deletions(-)
> 
> diff --git a/arch/powerpc/sysdev/fsl_pci.c b/arch/powerpc/sysdev/fsl_pci.c
> index 68ca929..87ac11b 100644
> --- a/arch/powerpc/sysdev/fsl_pci.c
> +++ b/arch/powerpc/sysdev/fsl_pci.c
> @@ -323,6 +323,7 @@ int __init fsl_add_bridge(struct device_node *dev, int 
> is_primary)
>       struct pci_controller *hose;
>       struct resource rsrc;
>       const int *bus_range;
> +     u8 is_agent;
> 
>       if (!of_device_is_available(dev)) {
>               pr_warning("%s: disabled\n", dev->full_name);
> @@ -353,6 +354,19 @@ int __init fsl_add_bridge(struct device_node *dev, int 
> is_primary)
> 
>       setup_indirect_pci(hose, rsrc.start, rsrc.start + 0x4,
>               PPC_INDIRECT_TYPE_BIG_ENDIAN);
> +
> +     early_read_config_byte(hose, 0, 0, PCI_HEADER_TYPE, &is_agent);

Why are we looking at PCI_HEADER_TYPE?  We should look at PCI_CLASS_PROG.

> +     if ((is_agent & 0x7f) == PCI_HEADER_TYPE_NORMAL) {
> +             u32 temp;
> +
> +             temp = (u32)hose->cfg_data & ~PAGE_MASK;
> +             if (((u32)hose->cfg_data & PAGE_MASK) != (u32)hose->cfg_addr)
> +                     iounmap(hose->cfg_data - temp);
> +             iounmap(hose->cfg_addr);
> +             pcibios_free_controller(hose);
> +             return 0;
> +     }
> +
>       setup_pci_cmd(hose);
> 
>       /* check PCI express link status */
> -- 
> 1.7.3
> 
> 
> _______________________________________________
> Linuxppc-dev mailing list
> Linuxppc-dev@lists.ozlabs.org
> https://lists.ozlabs.org/listinfo/linuxppc-dev

_______________________________________________
Linuxppc-dev mailing list
Linuxppc-dev@lists.ozlabs.org
https://lists.ozlabs.org/listinfo/linuxppc-dev

Reply via email to