aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDave Jones <davej@redhat.com>2007-02-05 19:12:43 -0500
committerDave Jones <davej@redhat.com>2007-02-10 20:01:47 -0500
commitc120069779e3e35917c15393cf2847fa79811eb6 (patch)
tree9e1e5529b43c151ecc9d3743e5b51ff88eb52312
parent86acd49aa128bd7a1d4362c256c21fbdc2d5b1a0 (diff)
[CPUFREQ] Remove hotplug cpu crap
The hotplug CPU locking in cpufreq is horrendous. No-one seems to care enough to fix it, so just remove it so that the 99.9% of the real world users of this code can use cpufreq without being bothered by warnings. Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Dave Jones <davej@redhat.com>
-rw-r--r--drivers/cpufreq/cpufreq.c16
-rw-r--r--drivers/cpufreq/cpufreq_conservative.c2
-rw-r--r--drivers/cpufreq/cpufreq_ondemand.c2
-rw-r--r--drivers/cpufreq/cpufreq_stats.c2
-rw-r--r--drivers/cpufreq/cpufreq_userspace.c2
5 files changed, 0 insertions, 24 deletions
diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c
index a45cc89e387a..9bdcdbdcc0ad 100644
--- a/drivers/cpufreq/cpufreq.c
+++ b/drivers/cpufreq/cpufreq.c
@@ -415,12 +415,10 @@ static ssize_t store_##file_name \
415 if (ret != 1) \ 415 if (ret != 1) \
416 return -EINVAL; \ 416 return -EINVAL; \
417 \ 417 \
418 lock_cpu_hotplug(); \
419 mutex_lock(&policy->lock); \ 418 mutex_lock(&policy->lock); \
420 ret = __cpufreq_set_policy(policy, &new_policy); \ 419 ret = __cpufreq_set_policy(policy, &new_policy); \
421 policy->user_policy.object = policy->object; \ 420 policy->user_policy.object = policy->object; \
422 mutex_unlock(&policy->lock); \ 421 mutex_unlock(&policy->lock); \
423 unlock_cpu_hotplug(); \
424 \ 422 \
425 return ret ? ret : count; \ 423 return ret ? ret : count; \
426} 424}
@@ -479,8 +477,6 @@ static ssize_t store_scaling_governor (struct cpufreq_policy * policy,
479 &new_policy.governor)) 477 &new_policy.governor))
480 return -EINVAL; 478 return -EINVAL;
481 479
482 lock_cpu_hotplug();
483
484 /* Do not use cpufreq_set_policy here or the user_policy.max 480 /* Do not use cpufreq_set_policy here or the user_policy.max
485 will be wrongly overridden */ 481 will be wrongly overridden */
486 mutex_lock(&policy->lock); 482 mutex_lock(&policy->lock);
@@ -490,8 +486,6 @@ static ssize_t store_scaling_governor (struct cpufreq_policy * policy,
490 policy->user_policy.governor = policy->governor; 486 policy->user_policy.governor = policy->governor;
491 mutex_unlock(&policy->lock); 487 mutex_unlock(&policy->lock);
492 488
493 unlock_cpu_hotplug();
494
495 if (ret) 489 if (ret)
496 return ret; 490 return ret;
497 else 491 else
@@ -1278,7 +1272,6 @@ EXPORT_SYMBOL(cpufreq_unregister_notifier);
1278 *********************************************************************/ 1272 *********************************************************************/
1279 1273
1280 1274
1281/* Must be called with lock_cpu_hotplug held */
1282int __cpufreq_driver_target(struct cpufreq_policy *policy, 1275int __cpufreq_driver_target(struct cpufreq_policy *policy,
1283 unsigned int target_freq, 1276 unsigned int target_freq,
1284 unsigned int relation) 1277 unsigned int relation)
@@ -1304,13 +1297,11 @@ int cpufreq_driver_target(struct cpufreq_policy *policy,
1304 if (!policy) 1297 if (!policy)
1305 return -EINVAL; 1298 return -EINVAL;
1306 1299
1307 lock_cpu_hotplug();
1308 mutex_lock(&policy->lock); 1300 mutex_lock(&policy->lock);
1309 1301
1310 ret = __cpufreq_driver_target(policy, target_freq, relation); 1302 ret = __cpufreq_driver_target(policy, target_freq, relation);
1311 1303
1312 mutex_unlock(&policy->lock); 1304 mutex_unlock(&policy->lock);
1313 unlock_cpu_hotplug();
1314 1305
1315 cpufreq_cpu_put(policy); 1306 cpufreq_cpu_put(policy);
1316 return ret; 1307 return ret;
@@ -1338,7 +1329,6 @@ int cpufreq_driver_getavg(struct cpufreq_policy *policy)
1338EXPORT_SYMBOL_GPL(cpufreq_driver_getavg); 1329EXPORT_SYMBOL_GPL(cpufreq_driver_getavg);
1339 1330
1340/* 1331/*
1341 * Locking: Must be called with the lock_cpu_hotplug() lock held
1342 * when "event" is CPUFREQ_GOV_LIMITS 1332 * when "event" is CPUFREQ_GOV_LIMITS
1343 */ 1333 */
1344 1334
@@ -1433,7 +1423,6 @@ EXPORT_SYMBOL(cpufreq_get_policy);
1433/* 1423/*
1434 * data : current policy. 1424 * data : current policy.
1435 * policy : policy to be set. 1425 * policy : policy to be set.
1436 * Locking: Must be called with the lock_cpu_hotplug() lock held
1437 */ 1426 */
1438static int __cpufreq_set_policy(struct cpufreq_policy *data, 1427static int __cpufreq_set_policy(struct cpufreq_policy *data,
1439 struct cpufreq_policy *policy) 1428 struct cpufreq_policy *policy)
@@ -1539,8 +1528,6 @@ int cpufreq_set_policy(struct cpufreq_policy *policy)
1539 if (!data) 1528 if (!data)
1540 return -EINVAL; 1529 return -EINVAL;
1541 1530
1542 lock_cpu_hotplug();
1543
1544 /* lock this CPU */ 1531 /* lock this CPU */
1545 mutex_lock(&data->lock); 1532 mutex_lock(&data->lock);
1546 1533
@@ -1552,7 +1539,6 @@ int cpufreq_set_policy(struct cpufreq_policy *policy)
1552 1539
1553 mutex_unlock(&data->lock); 1540 mutex_unlock(&data->lock);
1554 1541
1555 unlock_cpu_hotplug();
1556 cpufreq_cpu_put(data); 1542 cpufreq_cpu_put(data);
1557 1543
1558 return ret; 1544 return ret;
@@ -1576,7 +1562,6 @@ int cpufreq_update_policy(unsigned int cpu)
1576 if (!data) 1562 if (!data)
1577 return -ENODEV; 1563 return -ENODEV;
1578 1564
1579 lock_cpu_hotplug();
1580 mutex_lock(&data->lock); 1565 mutex_lock(&data->lock);
1581 1566
1582 dprintk("updating policy for CPU %u\n", cpu); 1567 dprintk("updating policy for CPU %u\n", cpu);
@@ -1603,7 +1588,6 @@ int cpufreq_update_policy(unsigned int cpu)
1603 ret = __cpufreq_set_policy(data, &policy); 1588 ret = __cpufreq_set_policy(data, &policy);
1604 1589
1605 mutex_unlock(&data->lock); 1590 mutex_unlock(&data->lock);
1606 unlock_cpu_hotplug();
1607 cpufreq_cpu_put(data); 1591 cpufreq_cpu_put(data);
1608 return ret; 1592 return ret;
1609} 1593}
diff --git a/drivers/cpufreq/cpufreq_conservative.c b/drivers/cpufreq/cpufreq_conservative.c
index eef0270c6f3d..787e8417c106 100644
--- a/drivers/cpufreq/cpufreq_conservative.c
+++ b/drivers/cpufreq/cpufreq_conservative.c
@@ -430,14 +430,12 @@ static void dbs_check_cpu(int cpu)
430static void do_dbs_timer(struct work_struct *work) 430static void do_dbs_timer(struct work_struct *work)
431{ 431{
432 int i; 432 int i;
433 lock_cpu_hotplug();
434 mutex_lock(&dbs_mutex); 433 mutex_lock(&dbs_mutex);
435 for_each_online_cpu(i) 434 for_each_online_cpu(i)
436 dbs_check_cpu(i); 435 dbs_check_cpu(i);
437 schedule_delayed_work(&dbs_work, 436 schedule_delayed_work(&dbs_work,
438 usecs_to_jiffies(dbs_tuners_ins.sampling_rate)); 437 usecs_to_jiffies(dbs_tuners_ins.sampling_rate));
439 mutex_unlock(&dbs_mutex); 438 mutex_unlock(&dbs_mutex);
440 unlock_cpu_hotplug();
441} 439}
442 440
443static inline void dbs_timer_init(void) 441static inline void dbs_timer_init(void)
diff --git a/drivers/cpufreq/cpufreq_ondemand.c b/drivers/cpufreq/cpufreq_ondemand.c
index f697449327c6..d52f9b426521 100644
--- a/drivers/cpufreq/cpufreq_ondemand.c
+++ b/drivers/cpufreq/cpufreq_ondemand.c
@@ -440,9 +440,7 @@ static void do_dbs_timer(struct work_struct *work)
440 dbs_info->sample_type = DBS_NORMAL_SAMPLE; 440 dbs_info->sample_type = DBS_NORMAL_SAMPLE;
441 if (!dbs_tuners_ins.powersave_bias || 441 if (!dbs_tuners_ins.powersave_bias ||
442 sample_type == DBS_NORMAL_SAMPLE) { 442 sample_type == DBS_NORMAL_SAMPLE) {
443 lock_cpu_hotplug();
444 dbs_check_cpu(dbs_info); 443 dbs_check_cpu(dbs_info);
445 unlock_cpu_hotplug();
446 if (dbs_info->freq_lo) { 444 if (dbs_info->freq_lo) {
447 /* Setup timer for SUB_SAMPLE */ 445 /* Setup timer for SUB_SAMPLE */
448 dbs_info->sample_type = DBS_SUB_SAMPLE; 446 dbs_info->sample_type = DBS_SUB_SAMPLE;
diff --git a/drivers/cpufreq/cpufreq_stats.c b/drivers/cpufreq/cpufreq_stats.c
index 91ad342a6051..d1c7cac9316c 100644
--- a/drivers/cpufreq/cpufreq_stats.c
+++ b/drivers/cpufreq/cpufreq_stats.c
@@ -370,12 +370,10 @@ __exit cpufreq_stats_exit(void)
370 cpufreq_unregister_notifier(&notifier_trans_block, 370 cpufreq_unregister_notifier(&notifier_trans_block,
371 CPUFREQ_TRANSITION_NOTIFIER); 371 CPUFREQ_TRANSITION_NOTIFIER);
372 unregister_hotcpu_notifier(&cpufreq_stat_cpu_notifier); 372 unregister_hotcpu_notifier(&cpufreq_stat_cpu_notifier);
373 lock_cpu_hotplug();
374 for_each_online_cpu(cpu) { 373 for_each_online_cpu(cpu) {
375 cpufreq_stat_cpu_callback(&cpufreq_stat_cpu_notifier, 374 cpufreq_stat_cpu_callback(&cpufreq_stat_cpu_notifier,
376 CPU_DEAD, (void *)(long)cpu); 375 CPU_DEAD, (void *)(long)cpu);
377 } 376 }
378 unlock_cpu_hotplug();
379} 377}
380 378
381MODULE_AUTHOR ("Zou Nan hai <nanhai.zou@intel.com>"); 379MODULE_AUTHOR ("Zou Nan hai <nanhai.zou@intel.com>");
diff --git a/drivers/cpufreq/cpufreq_userspace.c b/drivers/cpufreq/cpufreq_userspace.c
index 2a4eb0bfaf30..860345c7799a 100644
--- a/drivers/cpufreq/cpufreq_userspace.c
+++ b/drivers/cpufreq/cpufreq_userspace.c
@@ -71,7 +71,6 @@ static int cpufreq_set(unsigned int freq, struct cpufreq_policy *policy)
71 71
72 dprintk("cpufreq_set for cpu %u, freq %u kHz\n", policy->cpu, freq); 72 dprintk("cpufreq_set for cpu %u, freq %u kHz\n", policy->cpu, freq);
73 73
74 lock_cpu_hotplug();
75 mutex_lock(&userspace_mutex); 74 mutex_lock(&userspace_mutex);
76 if (!cpu_is_managed[policy->cpu]) 75 if (!cpu_is_managed[policy->cpu])
77 goto err; 76 goto err;
@@ -94,7 +93,6 @@ static int cpufreq_set(unsigned int freq, struct cpufreq_policy *policy)
94 93
95 err: 94 err:
96 mutex_unlock(&userspace_mutex); 95 mutex_unlock(&userspace_mutex);
97 unlock_cpu_hotplug();
98 return ret; 96 return ret;
99} 97}
100 98