diff options
Diffstat (limited to 'drivers')
| -rw-r--r-- | drivers/cpufreq/cpufreq.c | 57 |
1 files changed, 34 insertions, 23 deletions
diff --git a/drivers/cpufreq/cpufreq.c b/drivers/cpufreq/cpufreq.c index ad996c772c8b..9b416372a8e4 100644 --- a/drivers/cpufreq/cpufreq.c +++ b/drivers/cpufreq/cpufreq.c | |||
| @@ -284,39 +284,52 @@ EXPORT_SYMBOL_GPL(cpufreq_notify_transition); | |||
| 284 | * SYSFS INTERFACE * | 284 | * SYSFS INTERFACE * |
| 285 | *********************************************************************/ | 285 | *********************************************************************/ |
| 286 | 286 | ||
| 287 | static struct cpufreq_governor *__find_governor(const char *str_governor) | ||
| 288 | { | ||
| 289 | struct cpufreq_governor *t; | ||
| 290 | |||
| 291 | list_for_each_entry(t, &cpufreq_governor_list, governor_list) | ||
| 292 | if (!strnicmp(str_governor,t->name,CPUFREQ_NAME_LEN)) | ||
| 293 | return t; | ||
| 294 | |||
| 295 | return NULL; | ||
| 296 | } | ||
| 297 | |||
| 287 | /** | 298 | /** |
| 288 | * cpufreq_parse_governor - parse a governor string | 299 | * cpufreq_parse_governor - parse a governor string |
| 289 | */ | 300 | */ |
| 290 | static int cpufreq_parse_governor (char *str_governor, unsigned int *policy, | 301 | static int cpufreq_parse_governor (char *str_governor, unsigned int *policy, |
| 291 | struct cpufreq_governor **governor) | 302 | struct cpufreq_governor **governor) |
| 292 | { | 303 | { |
| 304 | int err = -EINVAL; | ||
| 305 | |||
| 293 | if (!cpufreq_driver) | 306 | if (!cpufreq_driver) |
| 294 | return -EINVAL; | 307 | goto out; |
| 308 | |||
| 295 | if (cpufreq_driver->setpolicy) { | 309 | if (cpufreq_driver->setpolicy) { |
| 296 | if (!strnicmp(str_governor, "performance", CPUFREQ_NAME_LEN)) { | 310 | if (!strnicmp(str_governor, "performance", CPUFREQ_NAME_LEN)) { |
| 297 | *policy = CPUFREQ_POLICY_PERFORMANCE; | 311 | *policy = CPUFREQ_POLICY_PERFORMANCE; |
| 298 | return 0; | 312 | err = 0; |
| 299 | } else if (!strnicmp(str_governor, "powersave", CPUFREQ_NAME_LEN)) { | 313 | } else if (!strnicmp(str_governor, "powersave", CPUFREQ_NAME_LEN)) { |
| 300 | *policy = CPUFREQ_POLICY_POWERSAVE; | 314 | *policy = CPUFREQ_POLICY_POWERSAVE; |
| 301 | return 0; | 315 | err = 0; |
| 302 | } | 316 | } |
| 303 | return -EINVAL; | 317 | } else if (cpufreq_driver->target) { |
| 304 | } else { | ||
| 305 | struct cpufreq_governor *t; | 318 | struct cpufreq_governor *t; |
| 319 | |||
| 306 | mutex_lock(&cpufreq_governor_mutex); | 320 | mutex_lock(&cpufreq_governor_mutex); |
| 307 | if (!cpufreq_driver || !cpufreq_driver->target) | 321 | |
| 308 | goto out; | 322 | t = __find_governor(str_governor); |
| 309 | list_for_each_entry(t, &cpufreq_governor_list, governor_list) { | 323 | |
| 310 | if (!strnicmp(str_governor,t->name,CPUFREQ_NAME_LEN)) { | 324 | if (t != NULL) { |
| 311 | *governor = t; | 325 | *governor = t; |
| 312 | mutex_unlock(&cpufreq_governor_mutex); | 326 | err = 0; |
| 313 | return 0; | ||
| 314 | } | ||
| 315 | } | 327 | } |
| 316 | out: | 328 | |
| 317 | mutex_unlock(&cpufreq_governor_mutex); | 329 | mutex_unlock(&cpufreq_governor_mutex); |
| 318 | } | 330 | } |
| 319 | return -EINVAL; | 331 | out: |
| 332 | return err; | ||
| 320 | } | 333 | } |
| 321 | 334 | ||
| 322 | 335 | ||
| @@ -1265,23 +1278,21 @@ static int __cpufreq_governor(struct cpufreq_policy *policy, unsigned int event) | |||
| 1265 | 1278 | ||
| 1266 | int cpufreq_register_governor(struct cpufreq_governor *governor) | 1279 | int cpufreq_register_governor(struct cpufreq_governor *governor) |
| 1267 | { | 1280 | { |
| 1268 | struct cpufreq_governor *t; | 1281 | int err; |
| 1269 | 1282 | ||
| 1270 | if (!governor) | 1283 | if (!governor) |
| 1271 | return -EINVAL; | 1284 | return -EINVAL; |
| 1272 | 1285 | ||
| 1273 | mutex_lock(&cpufreq_governor_mutex); | 1286 | mutex_lock(&cpufreq_governor_mutex); |
| 1274 | 1287 | ||
| 1275 | list_for_each_entry(t, &cpufreq_governor_list, governor_list) { | 1288 | err = -EBUSY; |
| 1276 | if (!strnicmp(governor->name,t->name,CPUFREQ_NAME_LEN)) { | 1289 | if (__find_governor(governor->name) == NULL) { |
| 1277 | mutex_unlock(&cpufreq_governor_mutex); | 1290 | err = 0; |
| 1278 | return -EBUSY; | 1291 | list_add(&governor->governor_list, &cpufreq_governor_list); |
| 1279 | } | ||
| 1280 | } | 1292 | } |
| 1281 | list_add(&governor->governor_list, &cpufreq_governor_list); | ||
| 1282 | 1293 | ||
| 1283 | mutex_unlock(&cpufreq_governor_mutex); | 1294 | mutex_unlock(&cpufreq_governor_mutex); |
| 1284 | return 0; | 1295 | return err; |
| 1285 | } | 1296 | } |
| 1286 | EXPORT_SYMBOL_GPL(cpufreq_register_governor); | 1297 | EXPORT_SYMBOL_GPL(cpufreq_register_governor); |
| 1287 | 1298 | ||
