diff options
author | Venkatesh Pallipadi <venkatesh.pallipadi@intel.com> | 2006-10-03 15:35:23 -0400 |
---|---|---|
committer | Dave Jones <davej@redhat.com> | 2006-10-15 19:57:10 -0400 |
commit | 64be7eedb2fd0d41614739b265b22708aa81734c (patch) | |
tree | 50df83e84eee613571f6869c51c62aab7b57cd1b /arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c | |
parent | 83d0515bbb10c7a3e52eee697d1032e447291eda (diff) |
[CPUFREQ][5/8] acpi-cpufreq: lindent acpi-cpufreq.c
Lindent acpi-cpufreq. Additional changes replacing "return (..)" by "return ..".
No functionality changes in this patch.
Signed-off-by: Denis Sadykov <denis.m.sadykov@intel.com>
Signed-off-by: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com>
Signed-off-by: Alexey Starikovskiy <alexey.y.starikovskiy@intel.com>
Signed-off-by: Dave Jones <davej@redhat.com>
Diffstat (limited to 'arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c')
-rw-r--r-- | arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c | 299 |
1 files changed, 139 insertions, 160 deletions
diff --git a/arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c b/arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c index 07fd97ba4c7a..385f17aca06b 100644 --- a/arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c +++ b/arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c | |||
@@ -51,7 +51,6 @@ MODULE_AUTHOR("Paul Diefenbaugh, Dominik Brodowski"); | |||
51 | MODULE_DESCRIPTION("ACPI Processor P-States Driver"); | 51 | MODULE_DESCRIPTION("ACPI Processor P-States Driver"); |
52 | MODULE_LICENSE("GPL"); | 52 | MODULE_LICENSE("GPL"); |
53 | 53 | ||
54 | |||
55 | enum { | 54 | enum { |
56 | UNDEFINED_CAPABLE = 0, | 55 | UNDEFINED_CAPABLE = 0, |
57 | SYSTEM_INTEL_MSR_CAPABLE, | 56 | SYSTEM_INTEL_MSR_CAPABLE, |
@@ -61,36 +60,34 @@ enum { | |||
61 | #define INTEL_MSR_RANGE (0xffff) | 60 | #define INTEL_MSR_RANGE (0xffff) |
62 | 61 | ||
63 | struct acpi_cpufreq_data { | 62 | struct acpi_cpufreq_data { |
64 | struct acpi_processor_performance *acpi_data; | 63 | struct acpi_processor_performance *acpi_data; |
65 | struct cpufreq_frequency_table *freq_table; | 64 | struct cpufreq_frequency_table *freq_table; |
66 | unsigned int resume; | 65 | unsigned int resume; |
67 | unsigned int cpu_feature; | 66 | unsigned int cpu_feature; |
68 | }; | 67 | }; |
69 | 68 | ||
70 | static struct acpi_cpufreq_data *drv_data[NR_CPUS]; | 69 | static struct acpi_cpufreq_data *drv_data[NR_CPUS]; |
71 | static struct acpi_processor_performance *acpi_perf_data[NR_CPUS]; | 70 | static struct acpi_processor_performance *acpi_perf_data[NR_CPUS]; |
72 | 71 | ||
73 | static struct cpufreq_driver acpi_cpufreq_driver; | 72 | static struct cpufreq_driver acpi_cpufreq_driver; |
74 | 73 | ||
75 | static unsigned int acpi_pstate_strict; | 74 | static unsigned int acpi_pstate_strict; |
76 | 75 | ||
77 | |||
78 | static int check_est_cpu(unsigned int cpuid) | 76 | static int check_est_cpu(unsigned int cpuid) |
79 | { | 77 | { |
80 | struct cpuinfo_x86 *cpu = &cpu_data[cpuid]; | 78 | struct cpuinfo_x86 *cpu = &cpu_data[cpuid]; |
81 | 79 | ||
82 | if (cpu->x86_vendor != X86_VENDOR_INTEL || | 80 | if (cpu->x86_vendor != X86_VENDOR_INTEL || |
83 | !cpu_has(cpu, X86_FEATURE_EST)) | 81 | !cpu_has(cpu, X86_FEATURE_EST)) |
84 | return 0; | 82 | return 0; |
85 | 83 | ||
86 | return 1; | 84 | return 1; |
87 | } | 85 | } |
88 | 86 | ||
89 | |||
90 | static unsigned extract_io(u32 value, struct acpi_cpufreq_data *data) | 87 | static unsigned extract_io(u32 value, struct acpi_cpufreq_data *data) |
91 | { | 88 | { |
92 | struct acpi_processor_performance *perf; | 89 | struct acpi_processor_performance *perf; |
93 | int i; | 90 | int i; |
94 | 91 | ||
95 | perf = data->acpi_data; | 92 | perf = data->acpi_data; |
96 | 93 | ||
@@ -101,7 +98,6 @@ static unsigned extract_io(u32 value, struct acpi_cpufreq_data *data) | |||
101 | return 0; | 98 | return 0; |
102 | } | 99 | } |
103 | 100 | ||
104 | |||
105 | static unsigned extract_msr(u32 msr, struct acpi_cpufreq_data *data) | 101 | static unsigned extract_msr(u32 msr, struct acpi_cpufreq_data *data) |
106 | { | 102 | { |
107 | int i; | 103 | int i; |
@@ -114,15 +110,14 @@ static unsigned extract_msr(u32 msr, struct acpi_cpufreq_data *data) | |||
114 | return data->freq_table[0].frequency; | 110 | return data->freq_table[0].frequency; |
115 | } | 111 | } |
116 | 112 | ||
117 | |||
118 | static unsigned extract_freq(u32 val, struct acpi_cpufreq_data *data) | 113 | static unsigned extract_freq(u32 val, struct acpi_cpufreq_data *data) |
119 | { | 114 | { |
120 | switch (data->cpu_feature) { | 115 | switch (data->cpu_feature) { |
121 | case SYSTEM_INTEL_MSR_CAPABLE: | 116 | case SYSTEM_INTEL_MSR_CAPABLE: |
122 | return extract_msr(val, data); | 117 | return extract_msr(val, data); |
123 | case SYSTEM_IO_CAPABLE: | 118 | case SYSTEM_IO_CAPABLE: |
124 | return extract_io(val, data); | 119 | return extract_io(val, data); |
125 | default: | 120 | default: |
126 | return 0; | 121 | return 0; |
127 | } | 122 | } |
128 | } | 123 | } |
@@ -138,7 +133,7 @@ static void wrport(u16 port, u8 bit_width, u32 value) | |||
138 | } | 133 | } |
139 | } | 134 | } |
140 | 135 | ||
141 | static void rdport(u16 port, u8 bit_width, u32 *ret) | 136 | static void rdport(u16 port, u8 bit_width, u32 * ret) |
142 | { | 137 | { |
143 | *ret = 0; | 138 | *ret = 0; |
144 | if (bit_width <= 8) { | 139 | if (bit_width <= 8) { |
@@ -176,13 +171,13 @@ static void do_drv_read(struct drv_cmd *cmd) | |||
176 | u32 h; | 171 | u32 h; |
177 | 172 | ||
178 | switch (cmd->type) { | 173 | switch (cmd->type) { |
179 | case SYSTEM_INTEL_MSR_CAPABLE: | 174 | case SYSTEM_INTEL_MSR_CAPABLE: |
180 | rdmsr(cmd->addr.msr.reg, cmd->val, h); | 175 | rdmsr(cmd->addr.msr.reg, cmd->val, h); |
181 | break; | 176 | break; |
182 | case SYSTEM_IO_CAPABLE: | 177 | case SYSTEM_IO_CAPABLE: |
183 | rdport(cmd->addr.io.port, cmd->addr.io.bit_width, &cmd->val); | 178 | rdport(cmd->addr.io.port, cmd->addr.io.bit_width, &cmd->val); |
184 | break; | 179 | break; |
185 | default: | 180 | default: |
186 | break; | 181 | break; |
187 | } | 182 | } |
188 | } | 183 | } |
@@ -192,20 +187,20 @@ static void do_drv_write(struct drv_cmd *cmd) | |||
192 | u32 h = 0; | 187 | u32 h = 0; |
193 | 188 | ||
194 | switch (cmd->type) { | 189 | switch (cmd->type) { |
195 | case SYSTEM_INTEL_MSR_CAPABLE: | 190 | case SYSTEM_INTEL_MSR_CAPABLE: |
196 | wrmsr(cmd->addr.msr.reg, cmd->val, h); | 191 | wrmsr(cmd->addr.msr.reg, cmd->val, h); |
197 | break; | 192 | break; |
198 | case SYSTEM_IO_CAPABLE: | 193 | case SYSTEM_IO_CAPABLE: |
199 | wrport(cmd->addr.io.port, cmd->addr.io.bit_width, cmd->val); | 194 | wrport(cmd->addr.io.port, cmd->addr.io.bit_width, cmd->val); |
200 | break; | 195 | break; |
201 | default: | 196 | default: |
202 | break; | 197 | break; |
203 | } | 198 | } |
204 | } | 199 | } |
205 | 200 | ||
206 | static inline void drv_read(struct drv_cmd *cmd) | 201 | static inline void drv_read(struct drv_cmd *cmd) |
207 | { | 202 | { |
208 | cpumask_t saved_mask = current->cpus_allowed; | 203 | cpumask_t saved_mask = current->cpus_allowed; |
209 | cmd->val = 0; | 204 | cmd->val = 0; |
210 | 205 | ||
211 | set_cpus_allowed(current, cmd->mask); | 206 | set_cpus_allowed(current, cmd->mask); |
@@ -216,8 +211,8 @@ static inline void drv_read(struct drv_cmd *cmd) | |||
216 | 211 | ||
217 | static void drv_write(struct drv_cmd *cmd) | 212 | static void drv_write(struct drv_cmd *cmd) |
218 | { | 213 | { |
219 | cpumask_t saved_mask = current->cpus_allowed; | 214 | cpumask_t saved_mask = current->cpus_allowed; |
220 | unsigned int i; | 215 | unsigned int i; |
221 | 216 | ||
222 | for_each_cpu_mask(i, cmd->mask) { | 217 | for_each_cpu_mask(i, cmd->mask) { |
223 | set_cpus_allowed(current, cpumask_of_cpu(i)); | 218 | set_cpus_allowed(current, cpumask_of_cpu(i)); |
@@ -230,8 +225,8 @@ static void drv_write(struct drv_cmd *cmd) | |||
230 | 225 | ||
231 | static u32 get_cur_val(cpumask_t mask) | 226 | static u32 get_cur_val(cpumask_t mask) |
232 | { | 227 | { |
233 | struct acpi_processor_performance *perf; | 228 | struct acpi_processor_performance *perf; |
234 | struct drv_cmd cmd; | 229 | struct drv_cmd cmd; |
235 | 230 | ||
236 | if (unlikely(cpus_empty(mask))) | 231 | if (unlikely(cpus_empty(mask))) |
237 | return 0; | 232 | return 0; |
@@ -262,14 +257,13 @@ static u32 get_cur_val(cpumask_t mask) | |||
262 | 257 | ||
263 | static unsigned int get_cur_freq_on_cpu(unsigned int cpu) | 258 | static unsigned int get_cur_freq_on_cpu(unsigned int cpu) |
264 | { | 259 | { |
265 | struct acpi_cpufreq_data *data = drv_data[cpu]; | 260 | struct acpi_cpufreq_data *data = drv_data[cpu]; |
266 | unsigned int freq; | 261 | unsigned int freq; |
267 | 262 | ||
268 | dprintk("get_cur_freq_on_cpu (%d)\n", cpu); | 263 | dprintk("get_cur_freq_on_cpu (%d)\n", cpu); |
269 | 264 | ||
270 | if (unlikely(data == NULL || | 265 | if (unlikely(data == NULL || |
271 | data->acpi_data == NULL || | 266 | data->acpi_data == NULL || data->freq_table == NULL)) { |
272 | data->freq_table == NULL)) { | ||
273 | return 0; | 267 | return 0; |
274 | } | 268 | } |
275 | 269 | ||
@@ -280,10 +274,10 @@ static unsigned int get_cur_freq_on_cpu(unsigned int cpu) | |||
280 | } | 274 | } |
281 | 275 | ||
282 | static unsigned int check_freqs(cpumask_t mask, unsigned int freq, | 276 | static unsigned int check_freqs(cpumask_t mask, unsigned int freq, |
283 | struct acpi_cpufreq_data *data) | 277 | struct acpi_cpufreq_data *data) |
284 | { | 278 | { |
285 | unsigned int cur_freq; | 279 | unsigned int cur_freq; |
286 | unsigned int i; | 280 | unsigned int i; |
287 | 281 | ||
288 | for (i = 0; i < 100; i++) { | 282 | for (i = 0; i < 100; i++) { |
289 | cur_freq = extract_freq(get_cur_val(mask), data); | 283 | cur_freq = extract_freq(get_cur_val(mask), data); |
@@ -295,34 +289,31 @@ static unsigned int check_freqs(cpumask_t mask, unsigned int freq, | |||
295 | } | 289 | } |
296 | 290 | ||
297 | static int acpi_cpufreq_target(struct cpufreq_policy *policy, | 291 | static int acpi_cpufreq_target(struct cpufreq_policy *policy, |
298 | unsigned int target_freq, | 292 | unsigned int target_freq, unsigned int relation) |
299 | unsigned int relation) | ||
300 | { | 293 | { |
301 | struct acpi_cpufreq_data *data = drv_data[policy->cpu]; | 294 | struct acpi_cpufreq_data *data = drv_data[policy->cpu]; |
302 | struct acpi_processor_performance *perf; | 295 | struct acpi_processor_performance *perf; |
303 | struct cpufreq_freqs freqs; | 296 | struct cpufreq_freqs freqs; |
304 | cpumask_t online_policy_cpus; | 297 | cpumask_t online_policy_cpus; |
305 | struct drv_cmd cmd; | 298 | struct drv_cmd cmd; |
306 | unsigned int msr; | 299 | unsigned int msr; |
307 | unsigned int next_state = 0; | 300 | unsigned int next_state = 0; |
308 | unsigned int next_perf_state = 0; | 301 | unsigned int next_perf_state = 0; |
309 | unsigned int i; | 302 | unsigned int i; |
310 | int result = 0; | 303 | int result = 0; |
311 | 304 | ||
312 | dprintk("acpi_cpufreq_target %d (%d)\n", target_freq, policy->cpu); | 305 | dprintk("acpi_cpufreq_target %d (%d)\n", target_freq, policy->cpu); |
313 | 306 | ||
314 | if (unlikely(data == NULL || | 307 | if (unlikely(data == NULL || |
315 | data->acpi_data == NULL || | 308 | data->acpi_data == NULL || data->freq_table == NULL)) { |
316 | data->freq_table == NULL)) { | ||
317 | return -ENODEV; | 309 | return -ENODEV; |
318 | } | 310 | } |
319 | 311 | ||
320 | perf = data->acpi_data; | 312 | perf = data->acpi_data; |
321 | result = cpufreq_frequency_table_target(policy, | 313 | result = cpufreq_frequency_table_target(policy, |
322 | data->freq_table, | 314 | data->freq_table, |
323 | target_freq, | 315 | target_freq, |
324 | relation, | 316 | relation, &next_state); |
325 | &next_state); | ||
326 | if (unlikely(result)) | 317 | if (unlikely(result)) |
327 | return -ENODEV; | 318 | return -ENODEV; |
328 | 319 | ||
@@ -339,30 +330,34 @@ static int acpi_cpufreq_target(struct cpufreq_policy *policy, | |||
339 | next_perf_state = data->freq_table[next_state].index; | 330 | next_perf_state = data->freq_table[next_state].index; |
340 | if (freqs.new == freqs.old) { | 331 | if (freqs.new == freqs.old) { |
341 | if (unlikely(data->resume)) { | 332 | if (unlikely(data->resume)) { |
342 | dprintk("Called after resume, resetting to P%d\n", next_perf_state); | 333 | dprintk("Called after resume, resetting to P%d\n", |
334 | next_perf_state); | ||
343 | data->resume = 0; | 335 | data->resume = 0; |
344 | } else { | 336 | } else { |
345 | dprintk("Already at target state (P%d)\n", next_perf_state); | 337 | dprintk("Already at target state (P%d)\n", |
338 | next_perf_state); | ||
346 | return 0; | 339 | return 0; |
347 | } | 340 | } |
348 | } | 341 | } |
349 | 342 | ||
350 | switch (data->cpu_feature) { | 343 | switch (data->cpu_feature) { |
351 | case SYSTEM_INTEL_MSR_CAPABLE: | 344 | case SYSTEM_INTEL_MSR_CAPABLE: |
352 | cmd.type = SYSTEM_INTEL_MSR_CAPABLE; | 345 | cmd.type = SYSTEM_INTEL_MSR_CAPABLE; |
353 | cmd.addr.msr.reg = MSR_IA32_PERF_CTL; | 346 | cmd.addr.msr.reg = MSR_IA32_PERF_CTL; |
354 | msr = (u32) perf->states[next_perf_state].control & INTEL_MSR_RANGE; | 347 | msr = |
355 | cmd.val = (cmd.val & ~INTEL_MSR_RANGE) | msr; | 348 | (u32) perf->states[next_perf_state]. |
356 | break; | 349 | control & INTEL_MSR_RANGE; |
357 | case SYSTEM_IO_CAPABLE: | 350 | cmd.val = (cmd.val & ~INTEL_MSR_RANGE) | msr; |
358 | cmd.type = SYSTEM_IO_CAPABLE; | 351 | break; |
359 | cmd.addr.io.port = perf->control_register.address; | 352 | case SYSTEM_IO_CAPABLE: |
360 | cmd.addr.io.bit_width = perf->control_register.bit_width; | 353 | cmd.type = SYSTEM_IO_CAPABLE; |
361 | cmd.val = (u32) perf->states[next_perf_state].control; | 354 | cmd.addr.io.port = perf->control_register.address; |
362 | break; | 355 | cmd.addr.io.bit_width = perf->control_register.bit_width; |
363 | default: | 356 | cmd.val = (u32) perf->states[next_perf_state].control; |
364 | return -ENODEV; | 357 | break; |
365 | } | 358 | default: |
359 | return -ENODEV; | ||
360 | } | ||
366 | 361 | ||
367 | cpus_clear(cmd.mask); | 362 | cpus_clear(cmd.mask); |
368 | 363 | ||
@@ -381,7 +376,7 @@ static int acpi_cpufreq_target(struct cpufreq_policy *policy, | |||
381 | if (acpi_pstate_strict) { | 376 | if (acpi_pstate_strict) { |
382 | if (!check_freqs(cmd.mask, freqs.new, data)) { | 377 | if (!check_freqs(cmd.mask, freqs.new, data)) { |
383 | dprintk("acpi_cpufreq_target failed (%d)\n", | 378 | dprintk("acpi_cpufreq_target failed (%d)\n", |
384 | policy->cpu); | 379 | policy->cpu); |
385 | return -EAGAIN; | 380 | return -EAGAIN; |
386 | } | 381 | } |
387 | } | 382 | } |
@@ -395,10 +390,7 @@ static int acpi_cpufreq_target(struct cpufreq_policy *policy, | |||
395 | return result; | 390 | return result; |
396 | } | 391 | } |
397 | 392 | ||
398 | 393 | static int acpi_cpufreq_verify(struct cpufreq_policy *policy) | |
399 | static int | ||
400 | acpi_cpufreq_verify ( | ||
401 | struct cpufreq_policy *policy) | ||
402 | { | 394 | { |
403 | struct acpi_cpufreq_data *data = drv_data[policy->cpu]; | 395 | struct acpi_cpufreq_data *data = drv_data[policy->cpu]; |
404 | 396 | ||
@@ -407,13 +399,10 @@ acpi_cpufreq_verify ( | |||
407 | return cpufreq_frequency_table_verify(policy, data->freq_table); | 399 | return cpufreq_frequency_table_verify(policy, data->freq_table); |
408 | } | 400 | } |
409 | 401 | ||
410 | |||
411 | static unsigned long | 402 | static unsigned long |
412 | acpi_cpufreq_guess_freq ( | 403 | acpi_cpufreq_guess_freq(struct acpi_cpufreq_data *data, unsigned int cpu) |
413 | struct acpi_cpufreq_data *data, | ||
414 | unsigned int cpu) | ||
415 | { | 404 | { |
416 | struct acpi_processor_performance *perf = data->acpi_data; | 405 | struct acpi_processor_performance *perf = data->acpi_data; |
417 | 406 | ||
418 | if (cpu_khz) { | 407 | if (cpu_khz) { |
419 | /* search the closest match to cpu_khz */ | 408 | /* search the closest match to cpu_khz */ |
@@ -423,14 +412,14 @@ acpi_cpufreq_guess_freq ( | |||
423 | 412 | ||
424 | for (i = 0; i < (perf->state_count - 1); i++) { | 413 | for (i = 0; i < (perf->state_count - 1); i++) { |
425 | freq = freqn; | 414 | freq = freqn; |
426 | freqn = perf->states[i+1].core_frequency * 1000; | 415 | freqn = perf->states[i + 1].core_frequency * 1000; |
427 | if ((2 * cpu_khz) > (freqn + freq)) { | 416 | if ((2 * cpu_khz) > (freqn + freq)) { |
428 | perf->state = i; | 417 | perf->state = i; |
429 | return (freq); | 418 | return freq; |
430 | } | 419 | } |
431 | } | 420 | } |
432 | perf->state = perf->state_count - 1; | 421 | perf->state = perf->state_count - 1; |
433 | return (freqn); | 422 | return freqn; |
434 | } else { | 423 | } else { |
435 | /* assume CPU is at P0... */ | 424 | /* assume CPU is at P0... */ |
436 | perf->state = 0; | 425 | perf->state = 0; |
@@ -438,7 +427,6 @@ acpi_cpufreq_guess_freq ( | |||
438 | } | 427 | } |
439 | } | 428 | } |
440 | 429 | ||
441 | |||
442 | /* | 430 | /* |
443 | * acpi_cpufreq_early_init - initialize ACPI P-States library | 431 | * acpi_cpufreq_early_init - initialize ACPI P-States library |
444 | * | 432 | * |
@@ -449,21 +437,21 @@ acpi_cpufreq_guess_freq ( | |||
449 | */ | 437 | */ |
450 | static int acpi_cpufreq_early_init(void) | 438 | static int acpi_cpufreq_early_init(void) |
451 | { | 439 | { |
452 | struct acpi_processor_performance *data; | 440 | struct acpi_processor_performance *data; |
453 | cpumask_t covered; | 441 | cpumask_t covered; |
454 | unsigned int i, j; | 442 | unsigned int i, j; |
455 | 443 | ||
456 | dprintk("acpi_cpufreq_early_init\n"); | 444 | dprintk("acpi_cpufreq_early_init\n"); |
457 | 445 | ||
458 | for_each_possible_cpu(i) { | 446 | for_each_possible_cpu(i) { |
459 | data = kzalloc(sizeof(struct acpi_processor_performance), | 447 | data = kzalloc(sizeof(struct acpi_processor_performance), |
460 | GFP_KERNEL); | 448 | GFP_KERNEL); |
461 | if (!data) { | 449 | if (!data) { |
462 | for_each_cpu_mask(j, covered) { | 450 | for_each_cpu_mask(j, covered) { |
463 | kfree(acpi_perf_data[j]); | 451 | kfree(acpi_perf_data[j]); |
464 | acpi_perf_data[j] = NULL; | 452 | acpi_perf_data[j] = NULL; |
465 | } | 453 | } |
466 | return (-ENOMEM); | 454 | return -ENOMEM; |
467 | } | 455 | } |
468 | acpi_perf_data[i] = data; | 456 | acpi_perf_data[i] = data; |
469 | cpu_set(i, covered); | 457 | cpu_set(i, covered); |
@@ -501,27 +489,25 @@ static struct dmi_system_id sw_any_bug_dmi_table[] = { | |||
501 | { } | 489 | { } |
502 | }; | 490 | }; |
503 | 491 | ||
504 | static int | 492 | static int acpi_cpufreq_cpu_init(struct cpufreq_policy *policy) |
505 | acpi_cpufreq_cpu_init ( | ||
506 | struct cpufreq_policy *policy) | ||
507 | { | 493 | { |
508 | unsigned int i; | 494 | unsigned int i; |
509 | unsigned int valid_states = 0; | 495 | unsigned int valid_states = 0; |
510 | unsigned int cpu = policy->cpu; | 496 | unsigned int cpu = policy->cpu; |
511 | struct acpi_cpufreq_data *data; | 497 | struct acpi_cpufreq_data *data; |
512 | unsigned int l, h; | 498 | unsigned int l, h; |
513 | unsigned int result = 0; | 499 | unsigned int result = 0; |
514 | struct cpuinfo_x86 *c = &cpu_data[policy->cpu]; | 500 | struct cpuinfo_x86 *c = &cpu_data[policy->cpu]; |
515 | struct acpi_processor_performance *perf; | 501 | struct acpi_processor_performance *perf; |
516 | 502 | ||
517 | dprintk("acpi_cpufreq_cpu_init\n"); | 503 | dprintk("acpi_cpufreq_cpu_init\n"); |
518 | 504 | ||
519 | if (!acpi_perf_data[cpu]) | 505 | if (!acpi_perf_data[cpu]) |
520 | return (-ENODEV); | 506 | return -ENODEV; |
521 | 507 | ||
522 | data = kzalloc(sizeof(struct acpi_cpufreq_data), GFP_KERNEL); | 508 | data = kzalloc(sizeof(struct acpi_cpufreq_data), GFP_KERNEL); |
523 | if (!data) | 509 | if (!data) |
524 | return (-ENOMEM); | 510 | return -ENOMEM; |
525 | 511 | ||
526 | data->acpi_data = acpi_perf_data[cpu]; | 512 | data->acpi_data = acpi_perf_data[cpu]; |
527 | drv_data[cpu] = data; | 513 | drv_data[cpu] = data; |
@@ -566,11 +552,11 @@ acpi_cpufreq_cpu_init ( | |||
566 | } | 552 | } |
567 | 553 | ||
568 | switch (perf->control_register.space_id) { | 554 | switch (perf->control_register.space_id) { |
569 | case ACPI_ADR_SPACE_SYSTEM_IO: | 555 | case ACPI_ADR_SPACE_SYSTEM_IO: |
570 | dprintk("SYSTEM IO addr space\n"); | 556 | dprintk("SYSTEM IO addr space\n"); |
571 | data->cpu_feature = SYSTEM_IO_CAPABLE; | 557 | data->cpu_feature = SYSTEM_IO_CAPABLE; |
572 | break; | 558 | break; |
573 | case ACPI_ADR_SPACE_FIXED_HARDWARE: | 559 | case ACPI_ADR_SPACE_FIXED_HARDWARE: |
574 | dprintk("HARDWARE addr space\n"); | 560 | dprintk("HARDWARE addr space\n"); |
575 | if (!check_est_cpu(cpu)) { | 561 | if (!check_est_cpu(cpu)) { |
576 | result = -ENODEV; | 562 | result = -ENODEV; |
@@ -578,14 +564,16 @@ acpi_cpufreq_cpu_init ( | |||
578 | } | 564 | } |
579 | data->cpu_feature = SYSTEM_INTEL_MSR_CAPABLE; | 565 | data->cpu_feature = SYSTEM_INTEL_MSR_CAPABLE; |
580 | break; | 566 | break; |
581 | default: | 567 | default: |
582 | dprintk("Unknown addr space %d\n", | 568 | dprintk("Unknown addr space %d\n", |
583 | (u32) (perf->control_register.space_id)); | 569 | (u32) (perf->control_register.space_id)); |
584 | result = -ENODEV; | 570 | result = -ENODEV; |
585 | goto err_unreg; | 571 | goto err_unreg; |
586 | } | 572 | } |
587 | 573 | ||
588 | data->freq_table = kmalloc(sizeof(struct cpufreq_frequency_table) * (perf->state_count + 1), GFP_KERNEL); | 574 | data->freq_table = |
575 | kmalloc(sizeof(struct cpufreq_frequency_table) * | ||
576 | (perf->state_count + 1), GFP_KERNEL); | ||
589 | if (!data->freq_table) { | 577 | if (!data->freq_table) { |
590 | result = -ENOMEM; | 578 | result = -ENOMEM; |
591 | goto err_unreg; | 579 | goto err_unreg; |
@@ -593,22 +581,23 @@ acpi_cpufreq_cpu_init ( | |||
593 | 581 | ||
594 | /* detect transition latency */ | 582 | /* detect transition latency */ |
595 | policy->cpuinfo.transition_latency = 0; | 583 | policy->cpuinfo.transition_latency = 0; |
596 | for (i=0; i<perf->state_count; i++) { | 584 | for (i = 0; i < perf->state_count; i++) { |
597 | if ((perf->states[i].transition_latency * 1000) > policy->cpuinfo.transition_latency) | 585 | if ((perf->states[i].transition_latency * 1000) > |
598 | policy->cpuinfo.transition_latency = perf->states[i].transition_latency * 1000; | 586 | policy->cpuinfo.transition_latency) |
587 | policy->cpuinfo.transition_latency = | ||
588 | perf->states[i].transition_latency * 1000; | ||
599 | } | 589 | } |
600 | policy->governor = CPUFREQ_DEFAULT_GOVERNOR; | 590 | policy->governor = CPUFREQ_DEFAULT_GOVERNOR; |
601 | 591 | ||
602 | /* table init */ | 592 | /* table init */ |
603 | for (i=0; i<perf->state_count; i++) | 593 | for (i = 0; i < perf->state_count; i++) { |
604 | { | 594 | if (i > 0 && perf->states[i].core_frequency == |
605 | if ( i > 0 && perf->states[i].core_frequency == | 595 | perf->states[i - 1].core_frequency) |
606 | perf->states[i - 1].core_frequency) | ||
607 | continue; | 596 | continue; |
608 | 597 | ||
609 | data->freq_table[valid_states].index = i; | 598 | data->freq_table[valid_states].index = i; |
610 | data->freq_table[valid_states].frequency = | 599 | data->freq_table[valid_states].frequency = |
611 | perf->states[i].core_frequency * 1000; | 600 | perf->states[i].core_frequency * 1000; |
612 | valid_states++; | 601 | valid_states++; |
613 | } | 602 | } |
614 | data->freq_table[perf->state_count].frequency = CPUFREQ_TABLE_END; | 603 | data->freq_table[perf->state_count].frequency = CPUFREQ_TABLE_END; |
@@ -619,14 +608,14 @@ acpi_cpufreq_cpu_init ( | |||
619 | } | 608 | } |
620 | 609 | ||
621 | switch (data->cpu_feature) { | 610 | switch (data->cpu_feature) { |
622 | case ACPI_ADR_SPACE_SYSTEM_IO: | 611 | case ACPI_ADR_SPACE_SYSTEM_IO: |
623 | /* Current speed is unknown and not detectable by IO port */ | 612 | /* Current speed is unknown and not detectable by IO port */ |
624 | policy->cur = acpi_cpufreq_guess_freq(data, policy->cpu); | 613 | policy->cur = acpi_cpufreq_guess_freq(data, policy->cpu); |
625 | break; | 614 | break; |
626 | case ACPI_ADR_SPACE_FIXED_HARDWARE: | 615 | case ACPI_ADR_SPACE_FIXED_HARDWARE: |
627 | get_cur_freq_on_cpu(cpu); | 616 | get_cur_freq_on_cpu(cpu); |
628 | break; | 617 | break; |
629 | default: | 618 | default: |
630 | break; | 619 | break; |
631 | } | 620 | } |
632 | 621 | ||
@@ -636,100 +625,89 @@ acpi_cpufreq_cpu_init ( | |||
636 | dprintk("CPU%u - ACPI performance management activated.\n", cpu); | 625 | dprintk("CPU%u - ACPI performance management activated.\n", cpu); |
637 | for (i = 0; i < perf->state_count; i++) | 626 | for (i = 0; i < perf->state_count; i++) |
638 | dprintk(" %cP%d: %d MHz, %d mW, %d uS\n", | 627 | dprintk(" %cP%d: %d MHz, %d mW, %d uS\n", |
639 | (i == perf->state?'*':' '), i, | 628 | (i == perf->state ? '*' : ' '), i, |
640 | (u32) perf->states[i].core_frequency, | 629 | (u32) perf->states[i].core_frequency, |
641 | (u32) perf->states[i].power, | 630 | (u32) perf->states[i].power, |
642 | (u32) perf->states[i].transition_latency); | 631 | (u32) perf->states[i].transition_latency); |
643 | 632 | ||
644 | cpufreq_frequency_table_get_attr(data->freq_table, policy->cpu); | 633 | cpufreq_frequency_table_get_attr(data->freq_table, policy->cpu); |
645 | 634 | ||
646 | /* | 635 | /* |
647 | * the first call to ->target() should result in us actually | 636 | * the first call to ->target() should result in us actually |
648 | * writing something to the appropriate registers. | 637 | * writing something to the appropriate registers. |
649 | */ | 638 | */ |
650 | data->resume = 1; | 639 | data->resume = 1; |
651 | 640 | ||
652 | return result; | 641 | return result; |
653 | 642 | ||
654 | err_freqfree: | 643 | err_freqfree: |
655 | kfree(data->freq_table); | 644 | kfree(data->freq_table); |
656 | err_unreg: | 645 | err_unreg: |
657 | acpi_processor_unregister_performance(perf, cpu); | 646 | acpi_processor_unregister_performance(perf, cpu); |
658 | err_free: | 647 | err_free: |
659 | kfree(data); | 648 | kfree(data); |
660 | drv_data[cpu] = NULL; | 649 | drv_data[cpu] = NULL; |
661 | 650 | ||
662 | return (result); | 651 | return result; |
663 | } | 652 | } |
664 | 653 | ||
665 | 654 | static int acpi_cpufreq_cpu_exit(struct cpufreq_policy *policy) | |
666 | static int | ||
667 | acpi_cpufreq_cpu_exit ( | ||
668 | struct cpufreq_policy *policy) | ||
669 | { | 655 | { |
670 | struct acpi_cpufreq_data *data = drv_data[policy->cpu]; | 656 | struct acpi_cpufreq_data *data = drv_data[policy->cpu]; |
671 | 657 | ||
672 | |||
673 | dprintk("acpi_cpufreq_cpu_exit\n"); | 658 | dprintk("acpi_cpufreq_cpu_exit\n"); |
674 | 659 | ||
675 | if (data) { | 660 | if (data) { |
676 | cpufreq_frequency_table_put_attr(policy->cpu); | 661 | cpufreq_frequency_table_put_attr(policy->cpu); |
677 | drv_data[policy->cpu] = NULL; | 662 | drv_data[policy->cpu] = NULL; |
678 | acpi_processor_unregister_performance(data->acpi_data, policy->cpu); | 663 | acpi_processor_unregister_performance(data->acpi_data, |
664 | policy->cpu); | ||
679 | kfree(data); | 665 | kfree(data); |
680 | } | 666 | } |
681 | 667 | ||
682 | return (0); | 668 | return 0; |
683 | } | 669 | } |
684 | 670 | ||
685 | static int | 671 | static int acpi_cpufreq_resume(struct cpufreq_policy *policy) |
686 | acpi_cpufreq_resume ( | ||
687 | struct cpufreq_policy *policy) | ||
688 | { | 672 | { |
689 | struct acpi_cpufreq_data *data = drv_data[policy->cpu]; | 673 | struct acpi_cpufreq_data *data = drv_data[policy->cpu]; |
690 | 674 | ||
691 | |||
692 | dprintk("acpi_cpufreq_resume\n"); | 675 | dprintk("acpi_cpufreq_resume\n"); |
693 | 676 | ||
694 | data->resume = 1; | 677 | data->resume = 1; |
695 | 678 | ||
696 | return (0); | 679 | return 0; |
697 | } | 680 | } |
698 | 681 | ||
699 | 682 | static struct freq_attr *acpi_cpufreq_attr[] = { | |
700 | static struct freq_attr* acpi_cpufreq_attr[] = { | ||
701 | &cpufreq_freq_attr_scaling_available_freqs, | 683 | &cpufreq_freq_attr_scaling_available_freqs, |
702 | NULL, | 684 | NULL, |
703 | }; | 685 | }; |
704 | 686 | ||
705 | static struct cpufreq_driver acpi_cpufreq_driver = { | 687 | static struct cpufreq_driver acpi_cpufreq_driver = { |
706 | .verify = acpi_cpufreq_verify, | 688 | .verify = acpi_cpufreq_verify, |
707 | .target = acpi_cpufreq_target, | 689 | .target = acpi_cpufreq_target, |
708 | .get = get_cur_freq_on_cpu, | 690 | .get = get_cur_freq_on_cpu, |
709 | .init = acpi_cpufreq_cpu_init, | 691 | .init = acpi_cpufreq_cpu_init, |
710 | .exit = acpi_cpufreq_cpu_exit, | 692 | .exit = acpi_cpufreq_cpu_exit, |
711 | .resume = acpi_cpufreq_resume, | 693 | .resume = acpi_cpufreq_resume, |
712 | .name = "acpi-cpufreq", | 694 | .name = "acpi-cpufreq", |
713 | .owner = THIS_MODULE, | 695 | .owner = THIS_MODULE, |
714 | .attr = acpi_cpufreq_attr, | 696 | .attr = acpi_cpufreq_attr, |
715 | }; | 697 | }; |
716 | 698 | ||
717 | 699 | static int __init acpi_cpufreq_init(void) | |
718 | static int __init | ||
719 | acpi_cpufreq_init (void) | ||
720 | { | 700 | { |
721 | dprintk("acpi_cpufreq_init\n"); | 701 | dprintk("acpi_cpufreq_init\n"); |
722 | 702 | ||
723 | acpi_cpufreq_early_init(); | 703 | acpi_cpufreq_early_init(); |
724 | 704 | ||
725 | return cpufreq_register_driver(&acpi_cpufreq_driver); | 705 | return cpufreq_register_driver(&acpi_cpufreq_driver); |
726 | } | 706 | } |
727 | 707 | ||
728 | 708 | static void __exit acpi_cpufreq_exit(void) | |
729 | static void __exit | ||
730 | acpi_cpufreq_exit (void) | ||
731 | { | 709 | { |
732 | unsigned int i; | 710 | unsigned int i; |
733 | dprintk("acpi_cpufreq_exit\n"); | 711 | dprintk("acpi_cpufreq_exit\n"); |
734 | 712 | ||
735 | cpufreq_unregister_driver(&acpi_cpufreq_driver); | 713 | cpufreq_unregister_driver(&acpi_cpufreq_driver); |
@@ -742,7 +720,8 @@ acpi_cpufreq_exit (void) | |||
742 | } | 720 | } |
743 | 721 | ||
744 | module_param(acpi_pstate_strict, uint, 0644); | 722 | module_param(acpi_pstate_strict, uint, 0644); |
745 | MODULE_PARM_DESC(acpi_pstate_strict, "value 0 or non-zero. non-zero -> strict ACPI checks are performed during frequency changes."); | 723 | MODULE_PARM_DESC(acpi_pstate_strict, |
724 | "value 0 or non-zero. non-zero -> strict ACPI checks are performed during frequency changes."); | ||
746 | 725 | ||
747 | late_initcall(acpi_cpufreq_init); | 726 | late_initcall(acpi_cpufreq_init); |
748 | module_exit(acpi_cpufreq_exit); | 727 | module_exit(acpi_cpufreq_exit); |