aboutsummaryrefslogtreecommitdiffstats
path: root/arch/i386/kernel/cpu/cpufreq
diff options
context:
space:
mode:
authorVenkatesh Pallipadi <venkatesh.pallipadi@intel.com>2006-10-03 15:27:10 -0400
committerDave Jones <davej@redhat.com>2006-10-15 19:57:10 -0400
commit519ce3ec76bf5c068e575800a9977659f7cccec4 (patch)
treee724263d3c23d7ce81fb22b04427e567806442f7 /arch/i386/kernel/cpu/cpufreq
parenteff0df65da81c75084d936e86854a3418347c27f (diff)
[CPUFREQ][1/8] acpi-cpufreq: software coordination and handle all CPUs in the group
This patchset has refresh/rebase of a bunch of patches/bugfixes related to acpi-cpufreq that were sent earlier on this list. patch 1/8 Patch that fixes a bug in swcoordination code in acpi-cpufreq patch 2/8 through patch 7/8 Grand unification of ACPI based speedstep-centrino and acpi-cpufreq drivers. ACPI allows P-state transitions in multiple ways. Like using IO ports or using processor native method (MSR). Without this patch, IO port based P-state transitions are handled in acpi-cpufreq driver and MSR based transitions on Intel CPUs are handled in speedstep-centrino driver. Even though most of the code in these two drivers should be similar, except for final changing/checking of frequency (one driver does it using IO port and other does it through MSR), we have duplicated code in these two drivers. There are also issues around BIOSes supporting both MSR and IO port and which driver should be loaded first in standard installations. The patchset combines functionality of these two driver into acpi-cpufreq driver. ACPI based functionality in speedstep-centrino is marked deprecated and will be removed in future. speedstep-centrino will continue to work on systems that depend on older non-ACPI table based P-state chanes. * 2/8 - Patch that reorganizes the code in acpi-cpufreq, cleaning it up a little and making it easier to add MSR support later. * 3/8 - Pull in the MSR based transition support into acpi-cpufreq. * 4/8 - Mark speedstep-centrino deprecated. Change the order in Makefile to load acpi-cpufreq first and speedstep-centrino later, in cases where both are configured in. * 5/8 - lindent acpi-cpufreq.c * 6/8 - Minor change to eliminate the check of current frequency on notifications. We can use last set frequency instead. * 7/8 - Make cpufreq->get of acpi_cpufreq work correctly again. There will be a patch in future that removes ACPI based support in speedstep-centrino in coming months. patch 8/8 Add support for IA32_APERF and IA32_MPERF MSR and get the actual frequency from these MSRs and use it to determine the next frequency target in ondemand governor This patch: There is a bug in software coordination patch in acpi-cpufreq, due to which frequency will only be set on first CPU of any coordinated group. Bug identified by Denis, was not recognised earlier as there are no platforms yet that use software coordination with acpi-cpufreq driver. Signed-off-by: Denis Sadykov <denis.m.sadykov@intel.com> Signed-off-by: Venkatesh Pallipadi <venkatesh.pallipadi@intel.com> Signed-off-by: Dave Jones <davej@redhat.com>
Diffstat (limited to 'arch/i386/kernel/cpu/cpufreq')
-rw-r--r--arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c11
1 files changed, 8 insertions, 3 deletions
diff --git a/arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c b/arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c
index 57c880bf0bd6..e902d970226f 100644
--- a/arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c
+++ b/arch/i386/kernel/cpu/cpufreq/acpi-cpufreq.c
@@ -197,6 +197,7 @@ acpi_cpufreq_target (
197 unsigned int relation) 197 unsigned int relation)
198{ 198{
199 struct cpufreq_acpi_io *data = acpi_io_data[policy->cpu]; 199 struct cpufreq_acpi_io *data = acpi_io_data[policy->cpu];
200 struct cpufreq_acpi_io *cpudata;
200 struct acpi_processor_performance *perf; 201 struct acpi_processor_performance *perf;
201 struct cpufreq_freqs freqs; 202 struct cpufreq_freqs freqs;
202 cpumask_t online_policy_cpus; 203 cpumask_t online_policy_cpus;
@@ -260,7 +261,8 @@ acpi_cpufreq_target (
260 break; 261 break;
261 } 262 }
262 263
263 result = acpi_processor_set_performance (data, j, next_state); 264 cpudata = acpi_io_data[j];
265 result = acpi_processor_set_performance(cpudata, j, next_state);
264 if (result) { 266 if (result) {
265 result = -EAGAIN; 267 result = -EAGAIN;
266 break; 268 break;
@@ -287,8 +289,11 @@ acpi_cpufreq_target (
287 289
288 if (!cpus_empty(covered_cpus)) { 290 if (!cpus_empty(covered_cpus)) {
289 for_each_cpu_mask(j, covered_cpus) { 291 for_each_cpu_mask(j, covered_cpus) {
290 policy->cpu = j; 292 cpus_clear(set_mask);
291 acpi_processor_set_performance (data, 293 cpu_set(j, set_mask);
294 set_cpus_allowed(current, set_mask);
295 cpudata = acpi_io_data[j];
296 acpi_processor_set_performance(cpudata,
292 j, 297 j,
293 cur_state); 298 cur_state);
294 } 299 }