Commit 2f48802e authored by Linus Torvalds's avatar Linus Torvalds

Merge branch 'fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/davej/cpufreq

* 'fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/davej/cpufreq:
  [CPUFREQ] powernow-k8: Don't try to transition if the pstate is incorrect
  [CPUFREQ] powernow-k8: Don't notify of successful transition if we failed (vid case).
  [CPUFREQ] Don't set stat->last_index to -1 if the pol->cur has incorrect value.
parents 95559f2c fbb5b89e
...@@ -298,11 +298,13 @@ static int cpufreq_stat_notifier_trans(struct notifier_block *nb, ...@@ -298,11 +298,13 @@ static int cpufreq_stat_notifier_trans(struct notifier_block *nb,
old_index = stat->last_index; old_index = stat->last_index;
new_index = freq_table_get_index(stat, freq->new); new_index = freq_table_get_index(stat, freq->new);
cpufreq_stats_update(freq->cpu); /* We can't do stat->time_in_state[-1]= .. */
if (old_index == new_index) if (old_index == -1 || new_index == -1)
return 0; return 0;
if (old_index == -1 || new_index == -1) cpufreq_stats_update(freq->cpu);
if (old_index == new_index)
return 0; return 0;
spin_lock(&cpufreq_stats_lock); spin_lock(&cpufreq_stats_lock);
......
...@@ -1079,6 +1079,9 @@ static int transition_frequency_fidvid(struct powernow_k8_data *data, ...@@ -1079,6 +1079,9 @@ static int transition_frequency_fidvid(struct powernow_k8_data *data,
} }
res = transition_fid_vid(data, fid, vid); res = transition_fid_vid(data, fid, vid);
if (res)
return res;
freqs.new = find_khz_freq_from_fid(data->currfid); freqs.new = find_khz_freq_from_fid(data->currfid);
for_each_cpu(i, data->available_cores) { for_each_cpu(i, data->available_cores) {
...@@ -1101,7 +1104,8 @@ static int transition_frequency_pstate(struct powernow_k8_data *data, ...@@ -1101,7 +1104,8 @@ static int transition_frequency_pstate(struct powernow_k8_data *data,
/* get MSR index for hardware pstate transition */ /* get MSR index for hardware pstate transition */
pstate = index & HW_PSTATE_MASK; pstate = index & HW_PSTATE_MASK;
if (pstate > data->max_hw_pstate) if (pstate > data->max_hw_pstate)
return 0; return -EINVAL;
freqs.old = find_khz_freq_from_pstate(data->powernow_table, freqs.old = find_khz_freq_from_pstate(data->powernow_table,
data->currpstate); data->currpstate);
freqs.new = find_khz_freq_from_pstate(data->powernow_table, pstate); freqs.new = find_khz_freq_from_pstate(data->powernow_table, pstate);
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment