nb/intel/sandybridge: Introduce `disable_refresh_machine` function
The same IOSAV sequence is used in both loops, so there's no need to reprogram it again in the second loop. Tested on Asus P8H61-M PRO, still boots. Change-Id: If7ee7917b61e4b752b4fc4700715dc9506520c03 Signed-off-by: Angel Pons <th3fanbus@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/47612 Reviewed-by: Arthur Heymans <arthur@aheymans.xyz> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
This commit is contained in:
parent
8360946c8e
commit
7d11513ab3
|
@ -1933,21 +1933,33 @@ static void train_write_flyby(ramctr_timing *ctrl)
|
||||||
MCHBAR32(GDCRTRAININGMOD) = 0;
|
MCHBAR32(GDCRTRAININGMOD) = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void write_op(ramctr_timing *ctrl, int channel)
|
static void disable_refresh_machine(ramctr_timing *ctrl)
|
||||||
{
|
{
|
||||||
int slotrank;
|
int channel;
|
||||||
|
|
||||||
wait_for_iosav(channel);
|
FOR_ALL_POPULATED_CHANNELS {
|
||||||
|
/* choose an existing rank */
|
||||||
|
const int slotrank = !(ctrl->rankmap[channel] & 1) ? 2 : 0;
|
||||||
|
|
||||||
/* choose an existing rank. */
|
iosav_write_zqcs_sequence(channel, slotrank, 4, 4, 31);
|
||||||
slotrank = !(ctrl->rankmap[channel] & 1) ? 2 : 0;
|
|
||||||
|
|
||||||
iosav_write_zqcs_sequence(channel, slotrank, 4, 4, 31);
|
/* Execute command queue */
|
||||||
|
iosav_run_once(channel);
|
||||||
|
|
||||||
/* Execute command queue */
|
wait_for_iosav(channel);
|
||||||
iosav_run_once(channel);
|
|
||||||
|
|
||||||
wait_for_iosav(channel);
|
MCHBAR32_OR(SCHED_CBIT_ch(channel), 1 << 21);
|
||||||
|
}
|
||||||
|
|
||||||
|
/* Refresh disable */
|
||||||
|
MCHBAR32_AND(MC_INIT_STATE_G, ~(1 << 3));
|
||||||
|
|
||||||
|
FOR_ALL_POPULATED_CHANNELS {
|
||||||
|
/* Execute the same command queue */
|
||||||
|
iosav_run_once(channel);
|
||||||
|
|
||||||
|
wait_for_iosav(channel);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
@ -1970,16 +1982,7 @@ int write_training(ramctr_timing *ctrl)
|
||||||
FOR_ALL_POPULATED_CHANNELS
|
FOR_ALL_POPULATED_CHANNELS
|
||||||
MCHBAR32_OR(TC_RWP_ch(channel), 1 << 27);
|
MCHBAR32_OR(TC_RWP_ch(channel), 1 << 27);
|
||||||
|
|
||||||
FOR_ALL_POPULATED_CHANNELS {
|
disable_refresh_machine(ctrl);
|
||||||
write_op(ctrl, channel);
|
|
||||||
MCHBAR32_OR(SCHED_CBIT_ch(channel), 1 << 21);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Refresh disable */
|
|
||||||
MCHBAR32_AND(MC_INIT_STATE_G, ~(1 << 3));
|
|
||||||
FOR_ALL_POPULATED_CHANNELS {
|
|
||||||
write_op(ctrl, channel);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Enable write leveling on all ranks
|
/* Enable write leveling on all ranks
|
||||||
Disable all DQ outputs
|
Disable all DQ outputs
|
||||||
|
@ -2142,38 +2145,7 @@ static void fill_pattern5(ramctr_timing *ctrl, int channel, int patno)
|
||||||
|
|
||||||
static void reprogram_320c(ramctr_timing *ctrl)
|
static void reprogram_320c(ramctr_timing *ctrl)
|
||||||
{
|
{
|
||||||
int channel, slotrank;
|
disable_refresh_machine(ctrl);
|
||||||
|
|
||||||
FOR_ALL_POPULATED_CHANNELS {
|
|
||||||
wait_for_iosav(channel);
|
|
||||||
|
|
||||||
/* Choose an existing rank */
|
|
||||||
slotrank = !(ctrl->rankmap[channel] & 1) ? 2 : 0;
|
|
||||||
|
|
||||||
iosav_write_zqcs_sequence(channel, slotrank, 4, 4, 31);
|
|
||||||
|
|
||||||
/* Execute command queue */
|
|
||||||
iosav_run_once(channel);
|
|
||||||
|
|
||||||
wait_for_iosav(channel);
|
|
||||||
MCHBAR32_OR(SCHED_CBIT_ch(channel), 1 << 21);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* refresh disable */
|
|
||||||
MCHBAR32_AND(MC_INIT_STATE_G, ~(1 << 3));
|
|
||||||
FOR_ALL_POPULATED_CHANNELS {
|
|
||||||
wait_for_iosav(channel);
|
|
||||||
|
|
||||||
/* choose an existing rank. */
|
|
||||||
slotrank = !(ctrl->rankmap[channel] & 1) ? 2 : 0;
|
|
||||||
|
|
||||||
iosav_write_zqcs_sequence(channel, slotrank, 4, 4, 31);
|
|
||||||
|
|
||||||
/* Execute command queue */
|
|
||||||
iosav_run_once(channel);
|
|
||||||
|
|
||||||
wait_for_iosav(channel);
|
|
||||||
}
|
|
||||||
|
|
||||||
/* JEDEC reset */
|
/* JEDEC reset */
|
||||||
dram_jedecreset(ctrl);
|
dram_jedecreset(ctrl);
|
||||||
|
|
Loading…
Reference in New Issue