|
@@ -1700,11 +1700,14 @@ static void f10_map_sysaddr_to_csrow(struct mem_ctl_info *mci,
|
|
|
*/
|
|
|
static void amd64_debug_display_dimm_sizes(int ctrl, struct amd64_pvt *pvt)
|
|
|
{
|
|
|
- int dimm, size0, size1;
|
|
|
+ int dimm, size0, size1, factor = 0;
|
|
|
u32 dbam;
|
|
|
u32 *dcsb;
|
|
|
|
|
|
if (boot_cpu_data.x86 == 0xf) {
|
|
|
+ if (pvt->dclr0 & F10_WIDTH_128)
|
|
|
+ factor = 1;
|
|
|
+
|
|
|
/* K8 families < revF not supported yet */
|
|
|
if (pvt->ext_model < K8_REV_F)
|
|
|
return;
|
|
@@ -1732,7 +1735,8 @@ static void amd64_debug_display_dimm_sizes(int ctrl, struct amd64_pvt *pvt)
|
|
|
size1 = pvt->ops->dbam_to_cs(pvt, DBAM_DIMM(dimm, dbam));
|
|
|
|
|
|
edac_printk(KERN_DEBUG, EDAC_MC, " %d: %5dMB %d: %5dMB\n",
|
|
|
- dimm * 2, size0, dimm * 2 + 1, size1);
|
|
|
+ dimm * 2, size0 << factor,
|
|
|
+ dimm * 2 + 1, size1 << factor);
|
|
|
}
|
|
|
}
|
|
|
|