summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorLen Brown <len.brown@intel.com>2010-05-22 16:34:10 -0400
committerLen Brown <len.brown@intel.com>2010-05-27 13:04:04 -0400
commitc0d64cb031c21f163a0ec15cf10844bcf0ceedcf (patch)
treece65dc6b8cbda91e8c1f1c69753265618e8d9ae6
parent6b2c676bf32be91f43215d5874c07c1becaba013 (diff)
downloadop-kernel-dev-c0d64cb031c21f163a0ec15cf10844bcf0ceedcf.zip
op-kernel-dev-c0d64cb031c21f163a0ec15cf10844bcf0ceedcf.tar.gz
cpuidle: add cpuidle_unregister_driver() error check
Assure that cpuidle_unregister_driver() will not clobber the registered driver if unregistered by somebody else. Signed-off-by: Len Brown <len.brown@intel.com>
-rw-r--r--drivers/cpuidle/driver.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/drivers/cpuidle/driver.c b/drivers/cpuidle/driver.c
index 2257004..826b5c0 100644
--- a/drivers/cpuidle/driver.c
+++ b/drivers/cpuidle/driver.c
@@ -45,8 +45,11 @@ EXPORT_SYMBOL_GPL(cpuidle_register_driver);
*/
void cpuidle_unregister_driver(struct cpuidle_driver *drv)
{
- if (!drv)
+ if (drv != cpuidle_curr_driver) {
+ WARN(1, "invalid cpuidle_unregister_driver(%s)\n",
+ drv->name);
return;
+ }
spin_lock(&cpuidle_driver_lock);
cpuidle_curr_driver = NULL;
OpenPOWER on IntegriCloud