Skip to content

Commit

Permalink
Merge branch 'ucode' of git://git.kernel.org/pub/scm/linux/kernel/git…
Browse files Browse the repository at this point in the history
…/bp/bp into x86/urgent
  • Loading branch information
Ingo Molnar committed Dec 5, 2011
2 parents 1ef0389 + ce37def commit f1b2371
Show file tree
Hide file tree
Showing 2 changed files with 27 additions and 10 deletions.
9 changes: 8 additions & 1 deletion arch/x86/include/asm/msr.h
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,14 @@ static inline int wrmsr_safe(unsigned msr, unsigned low, unsigned high)
return native_write_msr_safe(msr, low, high);
}

/* rdmsr with exception handling */
/*
* rdmsr with exception handling.
*
* Please note that the exception handling works only after we've
* switched to the "smart" #GP handler in trap_init() which knows about
* exception tables - using this macro earlier than that causes machine
* hangs on boxes which do not implement the @msr in the first argument.
*/
#define rdmsr_safe(msr, p1, p2) \
({ \
int __err; \
Expand Down
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 f1b2371

Please sign in to comment.