mirror of
https://github.com/enjoy-digital/litex.git
synced 2025-01-04 09:52:26 -05:00
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:
parent
33c7b2ce6b
commit
aaed4b9475
1 changed files with 12 additions and 9 deletions
|
@ -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;
|
||||||
|
|
Loading…
Reference in a new issue