nb/intel/sandybridge: Introduce find_predefined_pattern
function
Also fuse two per-channel loops together. Tested on Asus P8H61-M PRO, still boots. Change-Id: Iacc66f4364290a66d60d483055abef6e98223d16 Signed-off-by: Angel Pons <th3fanbus@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/47607 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Arthur Heymans <arthur@aheymans.xyz>
This commit is contained in:
parent
f305339d67
commit
60971dcd01
1 changed files with 59 additions and 52 deletions
|
@ -2350,6 +2350,63 @@ static int discover_edges_real(ramctr_timing *ctrl, int channel, int slotrank, i
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void find_predefined_pattern(ramctr_timing *ctrl, const int channel)
|
||||||
|
{
|
||||||
|
int slotrank, lane;
|
||||||
|
|
||||||
|
fill_pattern0(ctrl, channel, 0, 0);
|
||||||
|
FOR_ALL_LANES {
|
||||||
|
MCHBAR32(IOSAV_By_BW_SERROR_C_ch(channel, lane));
|
||||||
|
}
|
||||||
|
|
||||||
|
FOR_ALL_POPULATED_RANKS FOR_ALL_LANES {
|
||||||
|
ctrl->timings[channel][slotrank].lanes[lane].falling = 16;
|
||||||
|
ctrl->timings[channel][slotrank].lanes[lane].rising = 16;
|
||||||
|
}
|
||||||
|
|
||||||
|
program_timings(ctrl, channel);
|
||||||
|
|
||||||
|
FOR_ALL_POPULATED_RANKS {
|
||||||
|
wait_for_iosav(channel);
|
||||||
|
|
||||||
|
iosav_write_read_mpr_sequence(
|
||||||
|
channel, slotrank, ctrl->tMOD, 3, 4, 1, ctrl->CAS + 8);
|
||||||
|
|
||||||
|
/* Execute command queue */
|
||||||
|
iosav_run_once(channel);
|
||||||
|
|
||||||
|
wait_for_iosav(channel);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* XXX: check any measured value ? */
|
||||||
|
|
||||||
|
FOR_ALL_POPULATED_RANKS FOR_ALL_LANES {
|
||||||
|
ctrl->timings[channel][slotrank].lanes[lane].falling = 48;
|
||||||
|
ctrl->timings[channel][slotrank].lanes[lane].rising = 48;
|
||||||
|
}
|
||||||
|
|
||||||
|
program_timings(ctrl, channel);
|
||||||
|
|
||||||
|
FOR_ALL_POPULATED_RANKS {
|
||||||
|
wait_for_iosav(channel);
|
||||||
|
|
||||||
|
iosav_write_read_mpr_sequence(
|
||||||
|
channel, slotrank, ctrl->tMOD, 3, 4, 1, ctrl->CAS + 8);
|
||||||
|
|
||||||
|
/* Execute command queue */
|
||||||
|
iosav_run_once(channel);
|
||||||
|
|
||||||
|
wait_for_iosav(channel);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* XXX: check any measured value ? */
|
||||||
|
|
||||||
|
FOR_ALL_LANES {
|
||||||
|
MCHBAR32(IOSAV_By_BW_MASK_ch(channel, lane)) =
|
||||||
|
~MCHBAR32(IOSAV_By_BW_SERROR_ch(channel, lane)) & 0xff;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int discover_edges(ramctr_timing *ctrl)
|
int discover_edges(ramctr_timing *ctrl)
|
||||||
{
|
{
|
||||||
int falling_edges[NUM_CHANNELS][NUM_SLOTRANKS][NUM_LANES];
|
int falling_edges[NUM_CHANNELS][NUM_SLOTRANKS][NUM_LANES];
|
||||||
|
@ -2361,62 +2418,12 @@ int discover_edges(ramctr_timing *ctrl)
|
||||||
|
|
||||||
toggle_io_reset();
|
toggle_io_reset();
|
||||||
|
|
||||||
FOR_ALL_POPULATED_CHANNELS FOR_ALL_LANES {
|
|
||||||
MCHBAR32(IOSAV_By_BW_MASK_ch(channel, lane)) = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
FOR_ALL_POPULATED_CHANNELS {
|
FOR_ALL_POPULATED_CHANNELS {
|
||||||
fill_pattern0(ctrl, channel, 0, 0);
|
|
||||||
FOR_ALL_LANES {
|
FOR_ALL_LANES {
|
||||||
MCHBAR32(IOSAV_By_BW_SERROR_C_ch(channel, lane));
|
MCHBAR32(IOSAV_By_BW_MASK_ch(channel, lane)) = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
FOR_ALL_POPULATED_RANKS FOR_ALL_LANES {
|
find_predefined_pattern(ctrl, channel);
|
||||||
ctrl->timings[channel][slotrank].lanes[lane].falling = 16;
|
|
||||||
ctrl->timings[channel][slotrank].lanes[lane].rising = 16;
|
|
||||||
}
|
|
||||||
|
|
||||||
program_timings(ctrl, channel);
|
|
||||||
|
|
||||||
FOR_ALL_POPULATED_RANKS {
|
|
||||||
wait_for_iosav(channel);
|
|
||||||
|
|
||||||
iosav_write_read_mpr_sequence(
|
|
||||||
channel, slotrank, ctrl->tMOD, 3, 4, 1, ctrl->CAS + 8);
|
|
||||||
|
|
||||||
/* Execute command queue */
|
|
||||||
iosav_run_once(channel);
|
|
||||||
|
|
||||||
wait_for_iosav(channel);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* XXX: check any measured value ? */
|
|
||||||
|
|
||||||
FOR_ALL_POPULATED_RANKS FOR_ALL_LANES {
|
|
||||||
ctrl->timings[channel][slotrank].lanes[lane].falling = 48;
|
|
||||||
ctrl->timings[channel][slotrank].lanes[lane].rising = 48;
|
|
||||||
}
|
|
||||||
|
|
||||||
program_timings(ctrl, channel);
|
|
||||||
|
|
||||||
FOR_ALL_POPULATED_RANKS {
|
|
||||||
wait_for_iosav(channel);
|
|
||||||
|
|
||||||
iosav_write_read_mpr_sequence(
|
|
||||||
channel, slotrank, ctrl->tMOD, 3, 4, 1, ctrl->CAS + 8);
|
|
||||||
|
|
||||||
/* Execute command queue */
|
|
||||||
iosav_run_once(channel);
|
|
||||||
|
|
||||||
wait_for_iosav(channel);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* XXX: check any measured value ? */
|
|
||||||
|
|
||||||
FOR_ALL_LANES {
|
|
||||||
MCHBAR32(IOSAV_By_BW_MASK_ch(channel, lane)) =
|
|
||||||
~MCHBAR32(IOSAV_By_BW_SERROR_ch(channel, lane)) & 0xff;
|
|
||||||
}
|
|
||||||
|
|
||||||
fill_pattern0(ctrl, channel, 0, 0xffffffff);
|
fill_pattern0(ctrl, channel, 0, 0xffffffff);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue