nb/intel/sandybridge: Rewrite table accessors
There is no need to call get_FRQ a dozen times with the same parameters. As SNB will eventually use the same code, only IVB is being refactored. Tested on Asus P8Z77-V LX2, still boots with i7-2600 and i5-3330. Change-Id: Idd7c119b2aa291e6396e12fb29effaf3ec73108a Signed-off-by: Angel Pons <th3fanbus@gmail.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/39723 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Patrick Georgi <pgeorgi@google.com>
This commit is contained in:
parent
5271776689
commit
df09bdb726
|
@ -29,94 +29,94 @@ static u32 get_FRQ(u32 tCK, u8 base_freq)
|
||||||
return FRQ;
|
return FRQ;
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get REFI based on MC frequency, tREFI = 7.8usec */
|
/* Get REFI based on frequency index, tREFI = 7.8usec */
|
||||||
static u32 get_REFI(u32 tCK, u8 base_freq)
|
static u32 get_REFI(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_refi_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_refi_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_refi_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_refi_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get XSOffset based on MC frequency, tXS-Offset: tXS = tRFC + 10ns */
|
/* Get XSOffset based on frequency index, tXS-Offset: tXS = tRFC + 10ns */
|
||||||
static u8 get_XSOffset(u32 tCK, u8 base_freq)
|
static u8 get_XSOffset(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_xs_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_xs_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_xs_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_xs_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get MOD based on MC frequency */
|
/* Get MOD based on frequency index */
|
||||||
static u8 get_MOD(u32 tCK, u8 base_freq)
|
static u8 get_MOD(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_mod_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_mod_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_mod_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_mod_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get Write Leveling Output delay based on MC frequency */
|
/* Get Write Leveling Output delay based on frequency index */
|
||||||
static u8 get_WLO(u32 tCK, u8 base_freq)
|
static u8 get_WLO(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_wlo_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_wlo_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_wlo_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_wlo_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get CKE based on MC frequency */
|
/* Get CKE based on frequency index */
|
||||||
static u8 get_CKE(u32 tCK, u8 base_freq)
|
static u8 get_CKE(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_cke_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_cke_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_cke_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_cke_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get XPDLL based on MC frequency */
|
/* Get XPDLL based on frequency index */
|
||||||
static u8 get_XPDLL(u32 tCK, u8 base_freq)
|
static u8 get_XPDLL(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_xpdll_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_xpdll_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_xpdll_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_xpdll_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get XP based on MC frequency */
|
/* Get XP based on frequency index */
|
||||||
static u8 get_XP(u32 tCK, u8 base_freq)
|
static u8 get_XP(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_xp_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_xp_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_xp_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_xp_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get AONPD based on MC frequency */
|
/* Get AONPD based on frequency index */
|
||||||
static u8 get_AONPD(u32 tCK, u8 base_freq)
|
static u8 get_AONPD(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_aonpd_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_aonpd_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_aonpd_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_aonpd_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Get COMP2 based on MC frequency */
|
/* Get COMP2 based on frequency index */
|
||||||
static u32 get_COMP2(u32 tCK, u8 base_freq)
|
static u32 get_COMP2(u32 FRQ, u8 base_freq)
|
||||||
{
|
{
|
||||||
if (base_freq == 100)
|
if (base_freq == 100)
|
||||||
return frq_comp2_map[1][get_FRQ(tCK, 100) - 7];
|
return frq_comp2_map[1][FRQ - 7];
|
||||||
|
|
||||||
else
|
else
|
||||||
return frq_comp2_map[0][get_FRQ(tCK, 133) - 3];
|
return frq_comp2_map[0][FRQ - 3];
|
||||||
}
|
}
|
||||||
|
|
||||||
static void ivb_normalize_tclk(ramctr_timing *ctrl, bool ref_100mhz_support)
|
static void ivb_normalize_tclk(ramctr_timing *ctrl, bool ref_100mhz_support)
|
||||||
|
@ -363,14 +363,16 @@ static void dram_timing(ramctr_timing *ctrl)
|
||||||
ctrl->tRFC = DIV_ROUND_UP(ctrl->tRFC, ctrl->tCK);
|
ctrl->tRFC = DIV_ROUND_UP(ctrl->tRFC, ctrl->tCK);
|
||||||
printk(BIOS_DEBUG, "Selected tRFC : %uT\n", ctrl->tRFC);
|
printk(BIOS_DEBUG, "Selected tRFC : %uT\n", ctrl->tRFC);
|
||||||
|
|
||||||
ctrl->tREFI = get_REFI(ctrl->tCK, ctrl->base_freq);
|
const u32 FRQ = get_FRQ(ctrl->tCK, ctrl->base_freq);
|
||||||
ctrl->tMOD = get_MOD(ctrl->tCK, ctrl->base_freq);
|
|
||||||
ctrl->tXSOffset = get_XSOffset(ctrl->tCK, ctrl->base_freq);
|
ctrl->tREFI = get_REFI(FRQ, ctrl->base_freq);
|
||||||
ctrl->tWLO = get_WLO(ctrl->tCK, ctrl->base_freq);
|
ctrl->tMOD = get_MOD(FRQ, ctrl->base_freq);
|
||||||
ctrl->tCKE = get_CKE(ctrl->tCK, ctrl->base_freq);
|
ctrl->tXSOffset = get_XSOffset(FRQ, ctrl->base_freq);
|
||||||
ctrl->tXPDLL = get_XPDLL(ctrl->tCK, ctrl->base_freq);
|
ctrl->tWLO = get_WLO(FRQ, ctrl->base_freq);
|
||||||
ctrl->tXP = get_XP(ctrl->tCK, ctrl->base_freq);
|
ctrl->tCKE = get_CKE(FRQ, ctrl->base_freq);
|
||||||
ctrl->tAONPD = get_AONPD(ctrl->tCK, ctrl->base_freq);
|
ctrl->tXPDLL = get_XPDLL(FRQ, ctrl->base_freq);
|
||||||
|
ctrl->tXP = get_XP(FRQ, ctrl->base_freq);
|
||||||
|
ctrl->tAONPD = get_AONPD(FRQ, ctrl->base_freq);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void dram_freq(ramctr_timing *ctrl)
|
static void dram_freq(ramctr_timing *ctrl)
|
||||||
|
@ -432,6 +434,7 @@ static void dram_freq(ramctr_timing *ctrl)
|
||||||
|
|
||||||
static void dram_ioregs(ramctr_timing *ctrl)
|
static void dram_ioregs(ramctr_timing *ctrl)
|
||||||
{
|
{
|
||||||
|
const u32 FRQ = get_FRQ(ctrl->tCK, ctrl->base_freq);
|
||||||
u32 reg;
|
u32 reg;
|
||||||
|
|
||||||
int channel;
|
int channel;
|
||||||
|
@ -459,7 +462,7 @@ static void dram_ioregs(ramctr_timing *ctrl)
|
||||||
printram("done\n");
|
printram("done\n");
|
||||||
|
|
||||||
/* Set COMP2 */
|
/* Set COMP2 */
|
||||||
MCHBAR32(CRCOMPOFST2) = get_COMP2(ctrl->tCK, ctrl->base_freq);
|
MCHBAR32(CRCOMPOFST2) = get_COMP2(FRQ, ctrl->base_freq);
|
||||||
printram("COMP2 done\n");
|
printram("COMP2 done\n");
|
||||||
|
|
||||||
/* Set COMP1 */
|
/* Set COMP1 */
|
||||||
|
|
Loading…
Reference in New Issue