diff options
Diffstat (limited to 'drivers/cpufreq')
| -rw-r--r-- | drivers/cpufreq/acpi-cpufreq.c | 2 | ||||
| -rw-r--r-- | drivers/cpufreq/cpufreq-cpu0.c | 10 | ||||
| -rw-r--r-- | drivers/cpufreq/cpufreq_governor.h | 6 | ||||
| -rw-r--r-- | drivers/cpufreq/cpufreq_stats.c | 12 | ||||
| -rw-r--r-- | drivers/cpufreq/intel_pstate.c | 35 |
5 files changed, 49 insertions, 16 deletions
diff --git a/drivers/cpufreq/acpi-cpufreq.c b/drivers/cpufreq/acpi-cpufreq.c index 937bc286591f..57a8774f0b4e 100644 --- a/drivers/cpufreq/acpi-cpufreq.c +++ b/drivers/cpufreq/acpi-cpufreq.c | |||
| @@ -730,7 +730,6 @@ static int acpi_cpufreq_cpu_init(struct cpufreq_policy *policy) | |||
| 730 | policy->shared_type == CPUFREQ_SHARED_TYPE_ANY) { | 730 | policy->shared_type == CPUFREQ_SHARED_TYPE_ANY) { |
| 731 | cpumask_copy(policy->cpus, perf->shared_cpu_map); | 731 | cpumask_copy(policy->cpus, perf->shared_cpu_map); |
| 732 | } | 732 | } |
| 733 | cpumask_copy(policy->related_cpus, perf->shared_cpu_map); | ||
| 734 | 733 | ||
| 735 | #ifdef CONFIG_SMP | 734 | #ifdef CONFIG_SMP |
| 736 | dmi_check_system(sw_any_bug_dmi_table); | 735 | dmi_check_system(sw_any_bug_dmi_table); |
| @@ -742,7 +741,6 @@ static int acpi_cpufreq_cpu_init(struct cpufreq_policy *policy) | |||
| 742 | if (check_amd_hwpstate_cpu(cpu) && !acpi_pstate_strict) { | 741 | if (check_amd_hwpstate_cpu(cpu) && !acpi_pstate_strict) { |
| 743 | cpumask_clear(policy->cpus); | 742 | cpumask_clear(policy->cpus); |
| 744 | cpumask_set_cpu(cpu, policy->cpus); | 743 | cpumask_set_cpu(cpu, policy->cpus); |
| 745 | cpumask_copy(policy->related_cpus, cpu_sibling_mask(cpu)); | ||
| 746 | policy->shared_type = CPUFREQ_SHARED_TYPE_HW; | 744 | policy->shared_type = CPUFREQ_SHARED_TYPE_HW; |
| 747 | pr_info_once(PFX "overriding BIOS provided _PSD data\n"); | 745 | pr_info_once(PFX "overriding BIOS provided _PSD data\n"); |
| 748 | } | 746 | } |
diff --git a/drivers/cpufreq/cpufreq-cpu0.c b/drivers/cpufreq/cpufreq-cpu0.c index 4e5b7fb8927c..37d23a0f8c56 100644 --- a/drivers/cpufreq/cpufreq-cpu0.c +++ b/drivers/cpufreq/cpufreq-cpu0.c | |||
| @@ -178,10 +178,16 @@ static struct cpufreq_driver cpu0_cpufreq_driver = { | |||
| 178 | 178 | ||
| 179 | static int cpu0_cpufreq_probe(struct platform_device *pdev) | 179 | static int cpu0_cpufreq_probe(struct platform_device *pdev) |
| 180 | { | 180 | { |
| 181 | struct device_node *np; | 181 | struct device_node *np, *parent; |
| 182 | int ret; | 182 | int ret; |
| 183 | 183 | ||
| 184 | for_each_child_of_node(of_find_node_by_path("/cpus"), np) { | 184 | parent = of_find_node_by_path("/cpus"); |
| 185 | if (!parent) { | ||
| 186 | pr_err("failed to find OF /cpus\n"); | ||
| 187 | return -ENOENT; | ||
| 188 | } | ||
| 189 | |||
| 190 | for_each_child_of_node(parent, np) { | ||
| 185 | if (of_get_property(np, "operating-points", NULL)) | 191 | if (of_get_property(np, "operating-points", NULL)) |
| 186 | break; | 192 | break; |
| 187 | } | 193 | } |
diff --git a/drivers/cpufreq/cpufreq_governor.h b/drivers/cpufreq/cpufreq_governor.h index 46bde01eee62..cc4bd2f6838a 100644 --- a/drivers/cpufreq/cpufreq_governor.h +++ b/drivers/cpufreq/cpufreq_governor.h | |||
| @@ -14,8 +14,8 @@ | |||
| 14 | * published by the Free Software Foundation. | 14 | * published by the Free Software Foundation. |
| 15 | */ | 15 | */ |
| 16 | 16 | ||
| 17 | #ifndef _CPUFREQ_GOVERNER_H | 17 | #ifndef _CPUFREQ_GOVERNOR_H |
| 18 | #define _CPUFREQ_GOVERNER_H | 18 | #define _CPUFREQ_GOVERNOR_H |
| 19 | 19 | ||
| 20 | #include <linux/cpufreq.h> | 20 | #include <linux/cpufreq.h> |
| 21 | #include <linux/kobject.h> | 21 | #include <linux/kobject.h> |
| @@ -175,4 +175,4 @@ bool need_load_eval(struct cpu_dbs_common_info *cdbs, | |||
| 175 | unsigned int sampling_rate); | 175 | unsigned int sampling_rate); |
| 176 | int cpufreq_governor_dbs(struct dbs_data *dbs_data, | 176 | int cpufreq_governor_dbs(struct dbs_data *dbs_data, |
| 177 | struct cpufreq_policy *policy, unsigned int event); | 177 | struct cpufreq_policy *policy, unsigned int event); |
| 178 | #endif /* _CPUFREQ_GOVERNER_H */ | 178 | #endif /* _CPUFREQ_GOVERNOR_H */ |
diff --git a/drivers/cpufreq/cpufreq_stats.c b/drivers/cpufreq/cpufreq_stats.c index 2fd779eb1ed1..bfd6273fd873 100644 --- a/drivers/cpufreq/cpufreq_stats.c +++ b/drivers/cpufreq/cpufreq_stats.c | |||
| @@ -180,15 +180,19 @@ static void cpufreq_stats_free_sysfs(unsigned int cpu) | |||
| 180 | { | 180 | { |
| 181 | struct cpufreq_policy *policy = cpufreq_cpu_get(cpu); | 181 | struct cpufreq_policy *policy = cpufreq_cpu_get(cpu); |
| 182 | 182 | ||
| 183 | if (!cpufreq_frequency_get_table(cpu)) | 183 | if (!policy) |
| 184 | return; | 184 | return; |
| 185 | 185 | ||
| 186 | if (policy && !policy_is_shared(policy)) { | 186 | if (!cpufreq_frequency_get_table(cpu)) |
| 187 | goto put_ref; | ||
| 188 | |||
| 189 | if (!policy_is_shared(policy)) { | ||
| 187 | pr_debug("%s: Free sysfs stat\n", __func__); | 190 | pr_debug("%s: Free sysfs stat\n", __func__); |
| 188 | sysfs_remove_group(&policy->kobj, &stats_attr_group); | 191 | sysfs_remove_group(&policy->kobj, &stats_attr_group); |
| 189 | } | 192 | } |
| 190 | if (policy) | 193 | |
| 191 | cpufreq_cpu_put(policy); | 194 | put_ref: |
| 195 | cpufreq_cpu_put(policy); | ||
| 192 | } | 196 | } |
| 193 | 197 | ||
| 194 | static int cpufreq_stats_create_table(struct cpufreq_policy *policy, | 198 | static int cpufreq_stats_create_table(struct cpufreq_policy *policy, |
diff --git a/drivers/cpufreq/intel_pstate.c b/drivers/cpufreq/intel_pstate.c index f6dd1e761129..6133ef5cf671 100644 --- a/drivers/cpufreq/intel_pstate.c +++ b/drivers/cpufreq/intel_pstate.c | |||
| @@ -358,14 +358,14 @@ static void intel_pstate_sysfs_expose_params(void) | |||
| 358 | static int intel_pstate_min_pstate(void) | 358 | static int intel_pstate_min_pstate(void) |
| 359 | { | 359 | { |
| 360 | u64 value; | 360 | u64 value; |
| 361 | rdmsrl(0xCE, value); | 361 | rdmsrl(MSR_PLATFORM_INFO, value); |
| 362 | return (value >> 40) & 0xFF; | 362 | return (value >> 40) & 0xFF; |
| 363 | } | 363 | } |
| 364 | 364 | ||
| 365 | static int intel_pstate_max_pstate(void) | 365 | static int intel_pstate_max_pstate(void) |
| 366 | { | 366 | { |
| 367 | u64 value; | 367 | u64 value; |
| 368 | rdmsrl(0xCE, value); | 368 | rdmsrl(MSR_PLATFORM_INFO, value); |
| 369 | return (value >> 8) & 0xFF; | 369 | return (value >> 8) & 0xFF; |
| 370 | } | 370 | } |
| 371 | 371 | ||
| @@ -373,7 +373,7 @@ static int intel_pstate_turbo_pstate(void) | |||
| 373 | { | 373 | { |
| 374 | u64 value; | 374 | u64 value; |
| 375 | int nont, ret; | 375 | int nont, ret; |
| 376 | rdmsrl(0x1AD, value); | 376 | rdmsrl(MSR_NHM_TURBO_RATIO_LIMIT, value); |
| 377 | nont = intel_pstate_max_pstate(); | 377 | nont = intel_pstate_max_pstate(); |
| 378 | ret = ((value) & 255); | 378 | ret = ((value) & 255); |
| 379 | if (ret <= nont) | 379 | if (ret <= nont) |
| @@ -454,7 +454,7 @@ static inline void intel_pstate_calc_busy(struct cpudata *cpu, | |||
| 454 | sample->idletime_us * 100, | 454 | sample->idletime_us * 100, |
| 455 | sample->duration_us); | 455 | sample->duration_us); |
| 456 | core_pct = div64_u64(sample->aperf * 100, sample->mperf); | 456 | core_pct = div64_u64(sample->aperf * 100, sample->mperf); |
| 457 | sample->freq = cpu->pstate.turbo_pstate * core_pct * 1000; | 457 | sample->freq = cpu->pstate.max_pstate * core_pct * 1000; |
| 458 | 458 | ||
| 459 | sample->core_pct_busy = div_s64((sample->pstate_pct_busy * core_pct), | 459 | sample->core_pct_busy = div_s64((sample->pstate_pct_busy * core_pct), |
| 460 | 100); | 460 | 100); |
| @@ -502,7 +502,6 @@ static inline void intel_pstate_set_sample_time(struct cpudata *cpu) | |||
| 502 | 502 | ||
| 503 | sample_time = cpu->pstate_policy->sample_rate_ms; | 503 | sample_time = cpu->pstate_policy->sample_rate_ms; |
| 504 | delay = msecs_to_jiffies(sample_time); | 504 | delay = msecs_to_jiffies(sample_time); |
| 505 | delay -= jiffies % delay; | ||
| 506 | mod_timer_pinned(&cpu->timer, jiffies + delay); | 505 | mod_timer_pinned(&cpu->timer, jiffies + delay); |
| 507 | } | 506 | } |
| 508 | 507 | ||
| @@ -752,6 +751,29 @@ static struct cpufreq_driver intel_pstate_driver = { | |||
| 752 | 751 | ||
| 753 | static int __initdata no_load; | 752 | static int __initdata no_load; |
| 754 | 753 | ||
| 754 | static int intel_pstate_msrs_not_valid(void) | ||
| 755 | { | ||
| 756 | /* Check that all the msr's we are using are valid. */ | ||
| 757 | u64 aperf, mperf, tmp; | ||
| 758 | |||
| 759 | rdmsrl(MSR_IA32_APERF, aperf); | ||
| 760 | rdmsrl(MSR_IA32_MPERF, mperf); | ||
| 761 | |||
| 762 | if (!intel_pstate_min_pstate() || | ||
| 763 | !intel_pstate_max_pstate() || | ||
| 764 | !intel_pstate_turbo_pstate()) | ||
| 765 | return -ENODEV; | ||
| 766 | |||
| 767 | rdmsrl(MSR_IA32_APERF, tmp); | ||
| 768 | if (!(tmp - aperf)) | ||
| 769 | return -ENODEV; | ||
| 770 | |||
| 771 | rdmsrl(MSR_IA32_MPERF, tmp); | ||
| 772 | if (!(tmp - mperf)) | ||
| 773 | return -ENODEV; | ||
| 774 | |||
| 775 | return 0; | ||
| 776 | } | ||
| 755 | static int __init intel_pstate_init(void) | 777 | static int __init intel_pstate_init(void) |
| 756 | { | 778 | { |
| 757 | int cpu, rc = 0; | 779 | int cpu, rc = 0; |
| @@ -764,6 +786,9 @@ static int __init intel_pstate_init(void) | |||
| 764 | if (!id) | 786 | if (!id) |
| 765 | return -ENODEV; | 787 | return -ENODEV; |
| 766 | 788 | ||
| 789 | if (intel_pstate_msrs_not_valid()) | ||
| 790 | return -ENODEV; | ||
| 791 | |||
| 767 | pr_info("Intel P-state driver initializing.\n"); | 792 | pr_info("Intel P-state driver initializing.\n"); |
| 768 | 793 | ||
| 769 | all_cpu_data = vmalloc(sizeof(void *) * num_possible_cpus()); | 794 | all_cpu_data = vmalloc(sizeof(void *) * num_possible_cpus()); |
