Commit ce53ad81 authored by Qiuxu Zhuo's avatar Qiuxu Zhuo Committed by Tony Luck

EDAC/igen6: Fix the issue of no error events

Current igen6_edac checks for pending errors before the registration
of the error handler. However, there is a possibility that the error
occurs during the registration process, leading to unhandled pending
errors and no future error events. This issue can be reproduced by
repeatedly injecting errors during the loading of the igen6_edac.

Fix this issue by moving the pending error handler after the registration
of the error handler, ensuring that no pending errors are left unhandled.

Fixes: 10590a9d ("EDAC/igen6: Add EDAC driver for Intel client SoCs using IBECC")
Reported-by: default avatarEe Wey Lim <ee.wey.lim@intel.com>
Tested-by: default avatarEe Wey Lim <ee.wey.lim@intel.com>
Signed-off-by: default avatarQiuxu Zhuo <qiuxu.zhuo@intel.com>
Signed-off-by: default avatarTony Luck <tony.luck@intel.com>
Link: https://lore.kernel.org/r/20230725080427.23883-1-qiuxu.zhuo@intel.com
parent c545f5e4
...@@ -27,7 +27,7 @@ ...@@ -27,7 +27,7 @@
#include "edac_mc.h" #include "edac_mc.h"
#include "edac_module.h" #include "edac_module.h"
#define IGEN6_REVISION "v2.5" #define IGEN6_REVISION "v2.5.1"
#define EDAC_MOD_STR "igen6_edac" #define EDAC_MOD_STR "igen6_edac"
#define IGEN6_NMI_NAME "igen6_ibecc" #define IGEN6_NMI_NAME "igen6_ibecc"
...@@ -1216,9 +1216,6 @@ static int igen6_probe(struct pci_dev *pdev, const struct pci_device_id *ent) ...@@ -1216,9 +1216,6 @@ static int igen6_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
INIT_WORK(&ecclog_work, ecclog_work_cb); INIT_WORK(&ecclog_work, ecclog_work_cb);
init_irq_work(&ecclog_irq_work, ecclog_irq_work_cb); init_irq_work(&ecclog_irq_work, ecclog_irq_work_cb);
/* Check if any pending errors before registering the NMI handler */
ecclog_handler();
rc = register_err_handler(); rc = register_err_handler();
if (rc) if (rc)
goto fail3; goto fail3;
...@@ -1230,6 +1227,9 @@ static int igen6_probe(struct pci_dev *pdev, const struct pci_device_id *ent) ...@@ -1230,6 +1227,9 @@ static int igen6_probe(struct pci_dev *pdev, const struct pci_device_id *ent)
goto fail4; goto fail4;
} }
/* Check if any pending errors before/during the registration of the error handler */
ecclog_handler();
igen6_debug_setup(); igen6_debug_setup();
return 0; return 0;
fail4: fail4:
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment