forked from glfernando/remoteproc
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
x86, microcode: Fix the failure path of microcode update driver init …
…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.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -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(µcode_dev); | ||
} | ||
|
@@ -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(µcode_mutex); | ||
|
@@ -532,14 +530,12 @@ static int __init microcode_init(void) | |
mutex_unlock(µcode_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); | ||
|
@@ -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(µcode_mutex); | ||
|
||
sysdev_driver_unregister(&cpu_sysdev_class, &mc_sysdev_driver); | ||
|
||
mutex_unlock(µcode_mutex); | ||
put_online_cpus(); | ||
|
||
out_pdev: | ||
platform_device_unregister(microcode_pdev); | ||
return error; | ||
|
||
} | ||
module_init(microcode_init); | ||
|
||
|