--- linux-3.2-rc6/drivers/edac/sb_edac.c 2011-12-16 21:36:26.000000000 -0500 +++ linux-3.2-rc6-new/drivers/edac/sb_edac.c 2011-12-23 14:54:57.000000000 -0500 @@ -1661,9 +1661,6 @@ debugf0("MC: " __FILE__ ": %s(): mci = %p, dev = %p\n", __func__, mci, &sbridge_dev->pdev[0]->dev); - atomic_notifier_chain_unregister(&x86_mce_decoder_chain, - &sbridge_mce_dec); - /* Remove MC sysfs nodes */ edac_mc_del_mc(mci->dev); @@ -1731,8 +1728,6 @@ goto fail0; } - atomic_notifier_chain_register(&x86_mce_decoder_chain, - &sbridge_mce_dec); return 0; fail0: @@ -1861,8 +1856,11 @@ pci_rc = pci_register_driver(&sbridge_driver); - if (pci_rc >= 0) + if (pci_rc >= 0) { + atomic_notifier_chain_register(&x86_mce_decoder_chain, + &sbridge_mce_dec); return 0; + } sbridge_printk(KERN_ERR, "Failed to register device with error %d.\n", pci_rc); @@ -1877,6 +1875,9 @@ static void __exit sbridge_exit(void) { debugf2("MC: " __FILE__ ": %s()\n", __func__); + atomic_notifier_chain_unregister(&x86_mce_decoder_chain, + &sbridge_mce_dec); + pci_unregister_driver(&sbridge_driver); }