Skip to content

Commit

Permalink
x86, microcode: Fix the failure path of microcode update driver init …
Browse files Browse the repository at this point in the history
…code

The microcode update driver's initialization code does not handle
failures correctly. This patch fixes this issue.

Signed-off-by: Jan Beulich <[email protected]>
Signed-off-by: Srivatsa S. Bhat <[email protected]>
Link: http://lkml.kernel.org/r/[email protected]
Link: http://lkml.kernel.org/r/[email protected]
Signed-off-by: Borislav Petkov <[email protected]>
  • Loading branch information
Srivatsa S. Bhat authored and Borislav Petkov committed Dec 5, 2011
1 parent 8e8da02 commit bd39906
Showing 1 changed file with 19 additions and 9 deletions.
28 changes: 19 additions & 9 deletions arch/x86/kernel/microcode_core.c
Original file line number Diff line number Diff line change
Expand Up @@ -256,7 +256,7 @@ static int __init microcode_dev_init(void)
return 0;
}

static void microcode_dev_exit(void)
static void __exit microcode_dev_exit(void)
{
misc_deregister(&microcode_dev);
}
Expand Down Expand Up @@ -519,10 +519,8 @@ static int __init microcode_init(void)

microcode_pdev = platform_device_register_simple("microcode", -1,
NULL, 0);
if (IS_ERR(microcode_pdev)) {
microcode_dev_exit();
if (IS_ERR(microcode_pdev))
return PTR_ERR(microcode_pdev);
}

get_online_cpus();
mutex_lock(&microcode_mutex);
Expand All @@ -532,14 +530,12 @@ static int __init microcode_init(void)
mutex_unlock(&microcode_mutex);
put_online_cpus();

if (error) {
platform_device_unregister(microcode_pdev);
return error;
}
if (error)
goto out_pdev;

error = microcode_dev_init();
if (error)
return error;
goto out_sysdev_driver;

register_syscore_ops(&mc_syscore_ops);
register_hotcpu_notifier(&mc_cpu_notifier);
Expand All @@ -548,6 +544,20 @@ static int __init microcode_init(void)
" <[email protected]>, Peter Oruba\n");

return 0;

out_sysdev_driver:
get_online_cpus();
mutex_lock(&microcode_mutex);

sysdev_driver_unregister(&cpu_sysdev_class, &mc_sysdev_driver);

mutex_unlock(&microcode_mutex);
put_online_cpus();

out_pdev:
platform_device_unregister(microcode_pdev);
return error;

}
module_init(microcode_init);

Expand Down

0 comments on commit bd39906

Please sign in to comment.