northbridge/amd/amdfam10: Update DRAM speed limits for C32 sockets
The existing code applied G34-specific speed limits to all socket types. Update G34 and C32 specific speed limits to be in line with BKDG recommendations. Change-Id: I958ad333c47948ae741a56de5866af3e636fd24d Signed-off-by: Timothy Pearson <tpearson@raptorengineeringinc.com> Reviewed-on: https://review.coreboot.org/13140 Tested-by: build bot (Jenkins) Tested-by: Raptor Engineering Automated Test Stand <noreply@raptorengineeringinc.com> Reviewed-by: Patrick Georgi <pgeorgi@google.com>
This commit is contained in:
parent
a39e6d1cf9
commit
19ce16ae69
1 changed files with 265 additions and 93 deletions
|
@ -180,6 +180,8 @@ static uint16_t mct_MaxLoadFreq(uint8_t count, uint8_t highest_rank_count, uint8
|
||||||
}
|
}
|
||||||
|
|
||||||
if (is_fam15h()) {
|
if (is_fam15h()) {
|
||||||
|
if (CONFIG_CPU_SOCKET_TYPE == 0x15) {
|
||||||
|
/* Socket G34 */
|
||||||
if (IS_ENABLED(CONFIG_DIMM_REGISTERED) && registered) {
|
if (IS_ENABLED(CONFIG_DIMM_REGISTERED) && registered) {
|
||||||
/* Fam15h BKDG Rev. 3.14 Table 27 */
|
/* Fam15h BKDG Rev. 3.14 Table 27 */
|
||||||
if (voltage & 0x4) {
|
if (voltage & 0x4) {
|
||||||
|
@ -316,6 +318,176 @@ static uint16_t mct_MaxLoadFreq(uint8_t count, uint8_t highest_rank_count, uint8
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
} else if (CONFIG_CPU_SOCKET_TYPE == 0x14) {
|
||||||
|
/* Socket C32 */
|
||||||
|
if (IS_ENABLED(CONFIG_DIMM_REGISTERED) && registered) {
|
||||||
|
/* Fam15h BKDG Rev. 3.14 Table 30 */
|
||||||
|
if (voltage & 0x4) {
|
||||||
|
/* 1.25V */
|
||||||
|
if (count > 1) {
|
||||||
|
if (highest_rank_count > 2) {
|
||||||
|
/* Limit to DDR3-800 */
|
||||||
|
if (freq > 400) {
|
||||||
|
freq = 400;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-800\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: 1 registered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (voltage & 0x2) {
|
||||||
|
/* 1.35V */
|
||||||
|
if (count > 1) {
|
||||||
|
if (highest_rank_count > 2) {
|
||||||
|
/* Limit to DDR3-800 */
|
||||||
|
if (freq > 400) {
|
||||||
|
freq = 400;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-800\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else if (highest_rank_count > 1) {
|
||||||
|
/* Limit to DDR3-1066 */
|
||||||
|
if (freq > 533) {
|
||||||
|
freq = 533;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-1066\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1600 */
|
||||||
|
if (freq > 800) {
|
||||||
|
freq = 800;
|
||||||
|
printk(BIOS_DEBUG, "%s: 1 registered DIMM on %dmV channel; limiting to DDR3-1600\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (voltage & 0x1) {
|
||||||
|
/* 1.50V */
|
||||||
|
if (count > 1) {
|
||||||
|
if (highest_rank_count > 2) {
|
||||||
|
/* Limit to DDR3-800 */
|
||||||
|
if (freq > 400) {
|
||||||
|
freq = 400;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-800\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else if (highest_rank_count > 1) {
|
||||||
|
/* Limit to DDR3-1066 */
|
||||||
|
if (freq > 533) {
|
||||||
|
freq = 533;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-1066\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (highest_rank_count > 2) {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1600 */
|
||||||
|
if (freq > 800) {
|
||||||
|
freq = 800;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 registered DIMM on %dmV channel; limiting to DDR3-1600\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Fam15h BKDG Rev. 3.14 Table 29 */
|
||||||
|
if (voltage & 0x4) {
|
||||||
|
/* 1.25V */
|
||||||
|
if (count > 1) {
|
||||||
|
/* Limit to DDR3-1066 */
|
||||||
|
if (freq > 533) {
|
||||||
|
freq = 533;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1066\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (voltage & 0x2) {
|
||||||
|
if (count > 1) {
|
||||||
|
if (highest_rank_count > 1) {
|
||||||
|
/* Limit to DDR3-1066 */
|
||||||
|
if (freq > 533) {
|
||||||
|
freq = 533;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1066\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else if (voltage & 0x1) {
|
||||||
|
if (MaxDimmsInstallable == 1) {
|
||||||
|
/* Limit to DDR3-1600 */
|
||||||
|
if (freq > 800) {
|
||||||
|
freq = 800;
|
||||||
|
printk(BIOS_DEBUG, "%s: 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1600\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
if (count > 1) {
|
||||||
|
if (highest_rank_count > 1) {
|
||||||
|
/* Limit to DDR3-1066 */
|
||||||
|
if (freq > 533) {
|
||||||
|
freq = 533;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1066\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1333 */
|
||||||
|
if (freq > 666) {
|
||||||
|
freq = 666;
|
||||||
|
printk(BIOS_DEBUG, "%s: More than 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1333\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* Limit to DDR3-1600 */
|
||||||
|
if (freq > 800) {
|
||||||
|
freq = 800;
|
||||||
|
printk(BIOS_DEBUG, "%s: 1 unbuffered DIMM on %dmV channel; limiting to DDR3-1600\n", __func__, voltage_index_to_mv(voltage));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
/* TODO
|
||||||
|
* Other socket support unimplemented
|
||||||
|
*/
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (IS_ENABLED(CONFIG_DIMM_REGISTERED) && registered) {
|
if (IS_ENABLED(CONFIG_DIMM_REGISTERED) && registered) {
|
||||||
/* K10 BKDG Rev. 3.62 Table 34 */
|
/* K10 BKDG Rev. 3.62 Table 34 */
|
||||||
|
|
Loading…
Reference in a new issue