diff options
-rw-r--r-- | drivers/edac/i7300_edac.c | 18 |
1 files changed, 14 insertions, 4 deletions
diff --git a/drivers/edac/i7300_edac.c b/drivers/edac/i7300_edac.c index a88742abf1f4..b5152256967f 100644 --- a/drivers/edac/i7300_edac.c +++ b/drivers/edac/i7300_edac.c | |||
@@ -450,14 +450,24 @@ static int decode_mtr(struct i7300_pvt *pvt, | |||
450 | p_csrow->mtype = MEM_FB_DDR2; | 450 | p_csrow->mtype = MEM_FB_DDR2; |
451 | 451 | ||
452 | /* | 452 | /* |
453 | * FIXME: the type of error detection actually depends of the | 453 | * The type of error detection actually depends of the |
454 | * mode of operation. When it is just one single memory chip, at | 454 | * mode of operation. When it is just one single memory chip, at |
455 | * socket 0, channel 0, it uses 8-byte-over-32-byte SECDED+ code. | 455 | * socket 0, channel 0, it uses 8-byte-over-32-byte SECDED+ code. |
456 | * In normal or mirrored mode, it uses Single Device Data correction, | 456 | * In normal or mirrored mode, it uses Lockstep mode, |
457 | * with the possibility of using an extended algorithm for x8 memories | 457 | * with the possibility of using an extended algorithm for x8 memories |
458 | * See datasheet Sections 7.3.6 to 7.3.8 | 458 | * See datasheet Sections 7.3.6 to 7.3.8 |
459 | */ | 459 | */ |
460 | p_csrow->edac_mode = EDAC_S8ECD8ED; | 460 | |
461 | if (IS_SINGLE_MODE(pvt->mc_settings_a)) { | ||
462 | p_csrow->edac_mode = EDAC_SECDED; | ||
463 | debugf0("ECC code is 8-byte-over-32-byte SECDED+ code\n"); | ||
464 | } else { | ||
465 | debugf0("ECC code is on Lockstep mode\n"); | ||
466 | if (MTR_DRAM_WIDTH(mtr)) | ||
467 | p_csrow->edac_mode = EDAC_S8ECD8ED; | ||
468 | else | ||
469 | p_csrow->edac_mode = EDAC_S4ECD4ED; | ||
470 | } | ||
461 | 471 | ||
462 | /* ask what device type on this row */ | 472 | /* ask what device type on this row */ |
463 | if (MTR_DRAM_WIDTH(mtr)) { | 473 | if (MTR_DRAM_WIDTH(mtr)) { |