|
@@ -555,7 +555,7 @@ static int get_dimm_config(struct mem_ctl_info *mci)
|
|
|
pvt->is_close_pg = false;
|
|
|
}
|
|
|
|
|
|
- pci_read_config_dword(pvt->pci_ta, RANK_CFG_A, ®);
|
|
|
+ pci_read_config_dword(pvt->pci_ddrio, RANK_CFG_A, ®);
|
|
|
if (IS_RDIMM_ENABLED(reg)) {
|
|
|
/* FIXME: Can also be LRDIMM */
|
|
|
debugf0("Memory is registered\n");
|
|
@@ -1604,8 +1604,6 @@ static void sbridge_unregister_mci(struct sbridge_dev *sbridge_dev)
|
|
|
debugf0("MC: " __FILE__ ": %s(): mci = %p, dev = %p\n",
|
|
|
__func__, mci, &sbridge_dev->pdev[0]->dev);
|
|
|
|
|
|
- mce_unregister_decode_chain(&sbridge_mce_dec);
|
|
|
-
|
|
|
/* Remove MC sysfs nodes */
|
|
|
edac_mc_del_mc(mci->dev);
|
|
|
|
|
@@ -1682,7 +1680,6 @@ static int sbridge_register_mci(struct sbridge_dev *sbridge_dev)
|
|
|
goto fail0;
|
|
|
}
|
|
|
|
|
|
- mce_register_decode_chain(&sbridge_mce_dec);
|
|
|
return 0;
|
|
|
|
|
|
fail0:
|
|
@@ -1811,8 +1808,10 @@ static int __init sbridge_init(void)
|
|
|
|
|
|
pci_rc = pci_register_driver(&sbridge_driver);
|
|
|
|
|
|
- if (pci_rc >= 0)
|
|
|
+ if (pci_rc >= 0) {
|
|
|
+ mce_register_decode_chain(&sbridge_mce_dec);
|
|
|
return 0;
|
|
|
+ }
|
|
|
|
|
|
sbridge_printk(KERN_ERR, "Failed to register device with error %d.\n",
|
|
|
pci_rc);
|
|
@@ -1828,6 +1827,7 @@ static void __exit sbridge_exit(void)
|
|
|
{
|
|
|
debugf2("MC: " __FILE__ ": %s()\n", __func__);
|
|
|
pci_unregister_driver(&sbridge_driver);
|
|
|
+ mce_unregister_decode_chain(&sbridge_mce_dec);
|
|
|
}
|
|
|
|
|
|
module_init(sbridge_init);
|