diff options
Diffstat (limited to 'arch/powerpc/cpu/mpc85xx/b4860_serdes.c')
| -rw-r--r-- | arch/powerpc/cpu/mpc85xx/b4860_serdes.c | 60 | 
1 files changed, 60 insertions, 0 deletions
| diff --git a/arch/powerpc/cpu/mpc85xx/b4860_serdes.c b/arch/powerpc/cpu/mpc85xx/b4860_serdes.c index 9990202f4..bd3234271 100644 --- a/arch/powerpc/cpu/mpc85xx/b4860_serdes.c +++ b/arch/powerpc/cpu/mpc85xx/b4860_serdes.c @@ -31,6 +31,7 @@ struct serdes_config {  	u8 lanes[SRDS_MAX_LANES];  }; +#ifdef CONFIG_PPC_B4860  static struct serdes_config serdes1_cfg_tbl[] = {  	/* SerDes 1 */  	{0x0D, {CPRI8, CPRI7, CPRI6, CPRI5, @@ -41,6 +42,12 @@ static struct serdes_config serdes1_cfg_tbl[] = {  		CPRI4, CPRI3, CPRI2, CPRI1}},  	{0x2a, {SGMII_FM1_DTSEC5, SGMII_FM1_DTSEC6,  		CPRI6, CPRI5, CPRI4, CPRI3, CPRI2, CPRI1}}, +	{0x2C, {SGMII_FM1_DTSEC5, SGMII_FM1_DTSEC6, +		CPRI6, CPRI5, CPRI4, CPRI3, CPRI2, CPRI1}}, +	{0x2D, {SGMII_FM1_DTSEC5, SGMII_FM1_DTSEC6, +		CPRI6, CPRI5, CPRI4, CPRI3, CPRI2, CPRI1}}, +	{0x2E, {SGMII_FM1_DTSEC5, SGMII_FM1_DTSEC6, +		CPRI6, CPRI5, CPRI4, CPRI3, CPRI2, CPRI1}},  	{0x30, {AURORA, AURORA,  		SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4,  		CPRI4, CPRI3, CPRI2, CPRI1}}, @@ -84,6 +91,8 @@ static struct serdes_config serdes2_cfg_tbl[] = {  	{0x4E, {SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2,  		SGMII_FM1_DTSEC3, AURORA,  		SRIO1, SRIO1, SRIO1, SRIO1}}, +	{0x7A, {SRIO2, SRIO2, SRIO2, SRIO2, +		SRIO1, SRIO1, SRIO1, SRIO1}},  	{0x84, {SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2,  		SRIO2, SRIO2, AURORA, AURORA,  		XFI_FM1_MAC9, XFI_FM1_MAC10}}, @@ -94,6 +103,9 @@ static struct serdes_config serdes2_cfg_tbl[] = {  		SRIO2, SRIO2,  		SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4,  		XFI_FM1_MAC9, XFI_FM1_MAC10}}, +	{0x8D, {SRIO2, SRIO2, SRIO2, SRIO2, +		SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, +		XFI_FM1_MAC9, XFI_FM1_MAC10}},  	{0x93, {SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2,  		SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4,  		XAUI_FM1_MAC10, XAUI_FM1_MAC10, @@ -111,8 +123,56 @@ static struct serdes_config serdes2_cfg_tbl[] = {  	{0xC3, {XAUI_FM1_MAC9, XAUI_FM1_MAC9,  		XAUI_FM1_MAC9, XAUI_FM1_MAC9,  		SRIO1, SRIO1, SRIO1, SRIO1}}, +	{0x98, {XAUI_FM1_MAC9, XAUI_FM1_MAC9, +		XAUI_FM1_MAC9, XAUI_FM1_MAC9, +		XAUI_FM1_MAC10, XAUI_FM1_MAC10, +		XAUI_FM1_MAC10, XAUI_FM1_MAC10}},  	{}  }; +#endif + +#ifdef CONFIG_PPC_B4420 +static struct serdes_config serdes1_cfg_tbl[] = { +	{0x0D, {NONE, NONE, CPRI6, CPRI5, +		CPRI4, CPRI3, NONE, NONE} }, +	{0x0E, {NONE, NONE, CPRI8, CPRI5, +		CPRI4, CPRI3, NONE, NONE} }, +	{0x0F, {NONE, NONE, CPRI6, CPRI5, +		CPRI4, CPRI3, NONE, NONE} }, +	{0x18, {NONE, NONE, +		SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, +		NONE, NONE, NONE, NONE} }, +	{0x1B, {NONE, NONE, +		SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, +		NONE, NONE, NONE, NONE} }, +	{0x1E, {NONE, NONE, AURORA, AURORA, +		NONE, NONE, NONE, NONE} }, +	{0x21, {NONE, NONE, AURORA, AURORA, +		NONE, NONE, NONE, NONE} }, +	{0x3E, {NONE, NONE, CPRI6, CPRI5, +		CPRI4, CPRI3, NONE, NONE} }, +	{} +}; +static struct serdes_config serdes2_cfg_tbl[] = { +	{0x49, {SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, +		SGMII_FM1_DTSEC3, AURORA, +		NONE, NONE, NONE, NONE} }, +	{0x4A, {SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, +		SGMII_FM1_DTSEC3, AURORA, +		NONE, NONE, NONE, NONE} }, +	{0x6F, {SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, +		AURORA, AURORA,	NONE, NONE, NONE, NONE} }, +	{0x70, {SGMII_FM1_DTSEC1, SGMII_FM1_DTSEC2, +		AURORA, AURORA,	NONE, NONE, NONE, NONE} }, +	{0x9A, {PCIE1, PCIE1, +		SGMII_FM1_DTSEC3, SGMII_FM1_DTSEC4, +		NONE, NONE, NONE, NONE} }, +	{0x9E, {PCIE1, PCIE1, PCIE1, PCIE1, +		NONE, NONE, NONE, NONE} }, +	{} +}; +#endif +  static struct serdes_config *serdes_cfg_tbl[] = {  	serdes1_cfg_tbl,  	serdes2_cfg_tbl, |