bios/sdram: review/cleanup Command/Clock calibration, set window at the start instead of middle.

Working on KC705 that previously required manual adjustment.
This commit is contained in:
Florent Kermarrec 2020-04-25 11:00:21 +02:00
parent 33c7b2ce6b
commit aaed4b9475

View file

@ -441,21 +441,19 @@ static void write_level_cdly_range(unsigned int *best_error, int *best_cdly,
} }
delay_mean /= SDRAM_PHY_MODULES; delay_mean /= SDRAM_PHY_MODULES;
/* we want it to be in the middle */ /* we want it to be at the start */
int ideal_delay = (SDRAM_PHY_DELAYS - ddrphy_half_sys8x_taps_read()) / 2; int ideal_delay = 1;
int error = ideal_delay - delay_mean; int error = ideal_delay - delay_mean;
if (error < 0) if (error < 0)
error *= -1; error *= -1;
if (error < *best_error) { if (error < *best_error) {
printf("+");
*best_cdly = cdly; *best_cdly = cdly;
*best_error = error; *best_error = error;
} else {
printf("-");
} }
printf("1");
} else { } else {
printf("."); printf("0");
} }
} }
} }
@ -469,14 +467,17 @@ int write_level(void)
int cdly_range_end; int cdly_range_end;
int cdly_range_step; int cdly_range_step;
printf("cdly scan: "); printf("Command/Clk scan:\n");
/* Center write leveling by varying cdly. Searching through all possible /* Center write leveling by varying cdly. Searching through all possible
* values is slow, but we can use a simple optimization method of iterativly * values is slow, but we can use a simple optimization method of iterativly
* scanning smaller ranges with decreasing step */ * scanning smaller ranges with decreasing step */
cdly_range_start = 0; cdly_range_start = 0;
cdly_range_end = 512; cdly_range_end = SDRAM_PHY_DELAYS;
cdly_range_step = 64; if (SDRAM_PHY_DELAYS > 32)
cdly_range_step = SDRAM_PHY_DELAYS/8;
else
cdly_range_step = 1;
while (cdly_range_step > 0) { while (cdly_range_step > 0) {
printf("|"); printf("|");
write_level_cdly_range(&best_error, &best_cdly, write_level_cdly_range(&best_error, &best_cdly,
@ -507,6 +508,8 @@ int write_level(void)
} }
} }
printf("Data scan:\n");
/* re-run write leveling the final time */ /* re-run write leveling the final time */
if (!write_level_scan(delays, 1)) if (!write_level_scan(delays, 1))
return 0; return 0;