On Tue, Dec 20, 2011 at 7:44 AM, Vinh Nguyen Huu Tuong <vhtngu...@apm.com> wrote: > This patch extends PCI-E driver to support PCI-E for APM821xx SoC on > Bluestone board. > > Signed-off-by: Vinh Nguyen Huu Tuong <vhtngu...@apm.com>
> +static int apm821xx_pciex_init_port_hw(struct ppc4xx_pciex_port *port) > +{ > + u32 val; > + u32 utlset1; > + u32 timeout; > + > + /* > + * Do a software reset on PCIe ports. > + * This code is to fix the issue that pci drivers doesn't re-assign > + * bus number for PCIE devices after Uboot > + * scanned and configured all the buses (eg. PCIE NIC IntelPro/1000 > + * PT quad port, SAS LSI 1064E) > + */ > + > + mtdcri(SDR0, PESDR0_460EX_PHY_CTL_RST + (port->index * 0x55), 0x0); > + mdelay(10); > + > + if (port->endpoint) > + val = PTYPE_LEGACY_ENDPOINT << 20; > + else > + val = PTYPE_ROOT_PORT << 20; > + > + if (port->index == 0) { > + val |= LNKW_X1 << 12; > + utlset1 = 0x00000000; > + } else { > + val |= LNKW_X4 << 12; > + utlset1 = 0x20101101; > + } > + > + mtdcri(SDR0, port->sdr_base + PESDRn_DLPSET, val); > + mtdcri(SDR0, port->sdr_base + PESDRn_UTLSET1, utlset1); > + mtdcri(SDR0, port->sdr_base + PESDRn_UTLSET2, 0x01010000); > + > + switch (port->index) { > + case 0: > + mtdcri(SDR0, PESDR0_460EX_L0CDRCTL, 0x00003230); > + mtdcri(SDR0, PESDR0_460EX_L0DRV, 0x00000130); > + mtdcri(SDR0, PESDR0_460EX_L0CLK, 0x00000006); > + > + mtdcri(SDR0, PESDR0_460EX_PHY_CTL_RST, 0x10000000); > + mdelay(50); > + mtdcri(SDR0, PESDR0_460EX_PHY_CTL_RST, 0x30000000); > + break; > + > + case 1: > + mtdcri(SDR0, PESDR1_460EX_L0CDRCTL, 0x00003230); > + mtdcri(SDR0, PESDR1_460EX_L1CDRCTL, 0x00003230); > + mtdcri(SDR0, PESDR1_460EX_L2CDRCTL, 0x00003230); > + mtdcri(SDR0, PESDR1_460EX_L3CDRCTL, 0x00003230); > + mtdcri(SDR0, PESDR1_460EX_L0DRV, 0x00000130); > + mtdcri(SDR0, PESDR1_460EX_L1DRV, 0x00000130); > + mtdcri(SDR0, PESDR1_460EX_L2DRV, 0x00000130); > + mtdcri(SDR0, PESDR1_460EX_L3DRV, 0x00000130); > + mtdcri(SDR0, PESDR1_460EX_L0CLK, 0x00000006); > + mtdcri(SDR0, PESDR1_460EX_L1CLK, 0x00000006); > + mtdcri(SDR0, PESDR1_460EX_L2CLK, 0x00000006); > + mtdcri(SDR0, PESDR1_460EX_L3CLK, 0x00000006); > + > + mtdcri(SDR0, PESDR1_460EX_PHY_CTL_RST, 0x10000000); > + break; > + } Do we need a default case here to catch oddness and exit the function? > + > + mtdcri(SDR0, port->sdr_base + PESDRn_RCSSET, > + mfdcri(SDR0, port->sdr_base + PESDRn_RCSSET) | > + (PESDRx_RCSSET_RSTGU | PESDRx_RCSSET_RSTPYN)); > + > + /* Poll for PHY reset */ > + timeout = 0; > + while ((!(mfdcri(SDR0, PESDR0_460EX_RSTSTA + > + (port->index * 0x55)) & 0x1)) && > + (timeout < PCIE_PHY_RESET_TIMEOUT)) { > + udelay(10); > + timeout++; > + } > + > + if (timeout < PCIE_PHY_RESET_TIMEOUT) { > + mtdcri(SDR0, port->sdr_base + PESDRn_RCSSET, > + (mfdcri(SDR0, port->sdr_base + PESDRn_RCSSET) & > + ~(PESDRx_RCSSET_RSTGU | PESDRx_RCSSET_RSTDL)) | > + PESDRx_RCSSET_RSTPYN); > + > + port->has_ibpre = 1; > + > + return 0; > + } else { > + printk(KERN_INFO "PCIE: Can't reset PHY\n"); > + return -1; > + } If we can't reset the PHY, does this whole function essentially fail? Do the devices not get renumbered, etc? If so, you probably want to make that KERN_ERR. > @@ -1751,9 +1856,9 @@ static void __init ppc4xx_configure_pciex_PIMs(struct > ppc4xx_pciex_port *port, > * if it works > */ > out_le32(mbase + PECFG_PIM0LAL, 0x00000000); > - out_le32(mbase + PECFG_PIM0LAH, 0x00000000); > + out_le32(mbase + PECFG_PIM0LAH, 0x00000008); /* Moving on HB > */ > out_le32(mbase + PECFG_PIM1LAL, 0x00000000); > - out_le32(mbase + PECFG_PIM1LAH, 0x00000000); > + out_le32(mbase + PECFG_PIM1LAH, 0x0000000c); /* Moving on HB > */ > out_le32(mbase + PECFG_PIM01SAH, 0xffff0000); > out_le32(mbase + PECFG_PIM01SAL, 0x00000000); Why are these values changed, and are those changes only needed on APM821xx? > diff --git a/arch/powerpc/sysdev/ppc4xx_pci.h > b/arch/powerpc/sysdev/ppc4xx_pci.h > index 32ce763..faf3017 100644 > --- a/arch/powerpc/sysdev/ppc4xx_pci.h > +++ b/arch/powerpc/sysdev/ppc4xx_pci.h > @@ -441,6 +441,7 @@ > /* > * Config space register offsets > */ > +#define PECFG_ECDEVCTL 0x060 > #define PECFG_ECRTCTL 0x074 > > #define PECFG_BAR0LMPA 0x210 > @@ -448,6 +449,7 @@ > #define PECFG_BAR1MPA 0x218 > #define PECFG_BAR2LMPA 0x220 > #define PECFG_BAR2HMPA 0x224 > +#define PECFG_ECDEVCAPPA 0x25c > > #define PECFG_PIMEN 0x33c > #define PECFG_PIM0LAL 0x340 > @@ -494,5 +496,7 @@ enum > LNKW_X8 = 0x8 > }; > > +/* Timout for reset phy */ > +#define PCIE_PHY_RESET_TIMEOUT 10 Is this value applicable to all the 44x devices with PCI-e? josh _______________________________________________ Linuxppc-dev mailing list Linuxppc-dev@lists.ozlabs.org https://lists.ozlabs.org/listinfo/linuxppc-dev