|
@@ -51,20 +51,22 @@ int is_serdes_configured(enum srds_prtcl device)
|
|
|
int serdes_get_first_lane(u32 sd, enum srds_prtcl device)
|
|
|
{
|
|
|
struct ccsr_gur __iomem *gur = (void *)(CONFIG_SYS_FSL_GUTS_ADDR);
|
|
|
- u32 cfg = gur_in32(&gur->rcwsr[28]);
|
|
|
+ u32 cfg = 0;
|
|
|
int i;
|
|
|
|
|
|
switch (sd) {
|
|
|
#ifdef CONFIG_SYS_FSL_SRDS_1
|
|
|
case FSL_SRDS_1:
|
|
|
- cfg &= FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_MASK;
|
|
|
- cfg >>= FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_SHIFT;
|
|
|
+ cfg = gur_in32(&gur->rcwsr[FSL_CHASSIS3_SRDS1_REGSR - 1]);
|
|
|
+ cfg &= FSL_CHASSIS3_SRDS1_PRTCL_MASK;
|
|
|
+ cfg >>= FSL_CHASSIS3_SRDS1_PRTCL_SHIFT;
|
|
|
break;
|
|
|
#endif
|
|
|
#ifdef CONFIG_SYS_FSL_SRDS_2
|
|
|
case FSL_SRDS_2:
|
|
|
- cfg &= FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_MASK;
|
|
|
- cfg >>= FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_SHIFT;
|
|
|
+ cfg = gur_in32(&gur->rcwsr[FSL_CHASSIS3_SRDS2_REGSR - 1]);
|
|
|
+ cfg &= FSL_CHASSIS3_SRDS2_PRTCL_MASK;
|
|
|
+ cfg >>= FSL_CHASSIS3_SRDS2_PRTCL_SHIFT;
|
|
|
break;
|
|
|
#endif
|
|
|
default:
|
|
@@ -83,8 +85,8 @@ int serdes_get_first_lane(u32 sd, enum srds_prtcl device)
|
|
|
return -ENODEV;
|
|
|
}
|
|
|
|
|
|
-void serdes_init(u32 sd, u32 sd_addr, u32 sd_prctl_mask, u32 sd_prctl_shift,
|
|
|
- u8 serdes_prtcl_map[SERDES_PRCTL_COUNT])
|
|
|
+void serdes_init(u32 sd, u32 sd_addr, u32 rcwsr, u32 sd_prctl_mask,
|
|
|
+ u32 sd_prctl_shift, u8 serdes_prtcl_map[SERDES_PRCTL_COUNT])
|
|
|
{
|
|
|
struct ccsr_gur __iomem *gur = (void *)(CONFIG_SYS_FSL_GUTS_ADDR);
|
|
|
u32 cfg;
|
|
@@ -95,7 +97,7 @@ void serdes_init(u32 sd, u32 sd_addr, u32 sd_prctl_mask, u32 sd_prctl_shift,
|
|
|
|
|
|
memset(serdes_prtcl_map, 0, sizeof(u8) * SERDES_PRCTL_COUNT);
|
|
|
|
|
|
- cfg = gur_in32(&gur->rcwsr[28]) & sd_prctl_mask;
|
|
|
+ cfg = gur_in32(&gur->rcwsr[rcwsr - 1]) & sd_prctl_mask;
|
|
|
cfg >>= sd_prctl_shift;
|
|
|
printf("Using SERDES%d Protocol: %d (0x%x)\n", sd + 1, cfg, cfg);
|
|
|
|
|
@@ -152,15 +154,17 @@ void fsl_serdes_init(void)
|
|
|
#ifdef CONFIG_SYS_FSL_SRDS_1
|
|
|
serdes_init(FSL_SRDS_1,
|
|
|
CONFIG_SYS_FSL_LSCH3_SERDES_ADDR,
|
|
|
- FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_MASK,
|
|
|
- FSL_CHASSIS3_RCWSR28_SRDS1_PRTCL_SHIFT,
|
|
|
+ FSL_CHASSIS3_SRDS1_REGSR,
|
|
|
+ FSL_CHASSIS3_SRDS1_PRTCL_MASK,
|
|
|
+ FSL_CHASSIS3_SRDS1_PRTCL_SHIFT,
|
|
|
serdes1_prtcl_map);
|
|
|
#endif
|
|
|
#ifdef CONFIG_SYS_FSL_SRDS_2
|
|
|
serdes_init(FSL_SRDS_2,
|
|
|
CONFIG_SYS_FSL_LSCH3_SERDES_ADDR + FSL_SRDS_2 * 0x10000,
|
|
|
- FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_MASK,
|
|
|
- FSL_CHASSIS3_RCWSR28_SRDS2_PRTCL_SHIFT,
|
|
|
+ FSL_CHASSIS3_SRDS2_REGSR,
|
|
|
+ FSL_CHASSIS3_SRDS2_PRTCL_MASK,
|
|
|
+ FSL_CHASSIS3_SRDS2_PRTCL_SHIFT,
|
|
|
serdes2_prtcl_map);
|
|
|
#endif
|
|
|
}
|