diff options
author | Vernon Mauery <vernux@us.ibm.com> | 2010-04-16 18:40:19 -0400 |
---|---|---|
committer | Mauro Carvalho Chehab <mchehab@redhat.com> | 2010-05-18 11:43:23 -0400 |
commit | 8a311e179e52d122ac203d8e88014284c18ca8ab (patch) | |
tree | 8320e9f28bdbe9abb02664e9df35c8714f9898ee /drivers | |
parent | 2a6fae326713ec84f307c045f6b497d4afaeb1d4 (diff) |
Always call i7core_[ur]dimm_check_mc_ecc_err
This fixes an error in function i7core_check_error
In commit ca9c90ba09ca3c9799319f46a56f397afbf617c2 which converts the
driver to use double buffering, there is a change in the logic. Before,
if mce_count was zero, it skipped over a couple of statements and
finished out with a call to the *check_mc_ecc_err function. The current
code checks to see if mce_count is 0 and then exits.
This change reverts the behavior back to the original where if there are
no errors to report, we skip to the end and call the *check_mc_ecc_err
function.
This fix allows the driver to work again on my Nehalem based blades
again.
Signed-off-by: Vernon Mauery <vernux@us.ibm.com>
Signed-off-by: Mauro Carvalho Chehab <mchehab@redhat.com>
Diffstat (limited to 'drivers')
-rw-r--r-- | drivers/edac/i7core_edac.c | 3 |
1 files changed, 2 insertions, 1 deletions
diff --git a/drivers/edac/i7core_edac.c b/drivers/edac/i7core_edac.c index 8e93df637bca..cd51709c4d89 100644 --- a/drivers/edac/i7core_edac.c +++ b/drivers/edac/i7core_edac.c | |||
@@ -1670,7 +1670,7 @@ static void i7core_check_error(struct mem_ctl_info *mci) | |||
1670 | count = (pvt->mce_out + MCE_LOG_LEN - pvt->mce_in) | 1670 | count = (pvt->mce_out + MCE_LOG_LEN - pvt->mce_in) |
1671 | % MCE_LOG_LEN; | 1671 | % MCE_LOG_LEN; |
1672 | if (!count) | 1672 | if (!count) |
1673 | return; | 1673 | goto check_ce_error; |
1674 | 1674 | ||
1675 | m = pvt->mce_outentry; | 1675 | m = pvt->mce_outentry; |
1676 | if (pvt->mce_in + count > MCE_LOG_LEN) { | 1676 | if (pvt->mce_in + count > MCE_LOG_LEN) { |
@@ -1703,6 +1703,7 @@ static void i7core_check_error(struct mem_ctl_info *mci) | |||
1703 | /* | 1703 | /* |
1704 | * Now, let's increment CE error counts | 1704 | * Now, let's increment CE error counts |
1705 | */ | 1705 | */ |
1706 | check_ce_error: | ||
1706 | if (!pvt->is_registered) | 1707 | if (!pvt->is_registered) |
1707 | i7core_udimm_check_mc_ecc_err(mci); | 1708 | i7core_udimm_check_mc_ecc_err(mci); |
1708 | else | 1709 | else |