mirror of
https://kernel.googlesource.com/pub/scm/linux/kernel/git/stable/linux-stable.git
synced 2025-11-05 08:07:50 +10:00
Merge branch 'pm-cpufreq'
Merge additional cpufreq updates for 6.6-rc1: - Add support for per-policy performance boost (Jie Zhan). - Fix assorted issues in the cpufreq core, common governor code and in the pcc cpufreq driver (Liao Chang). * pm-cpufreq: cpufreq: Support per-policy performance boost cpufreq: pcc: Fix the potentinal scheduling delays in target_index() cpufreq: governor: Free dbs_data directly when gov->init() fails cpufreq: Fix the race condition while updating the transition_task of policy cpufreq: Avoid printing kernel addresses in cpufreq_resume()
This commit is contained in:
commit
19a56a6b74
@ -86,6 +86,7 @@ static void cpufreq_governor_limits(struct cpufreq_policy *policy);
|
|||||||
static int cpufreq_set_policy(struct cpufreq_policy *policy,
|
static int cpufreq_set_policy(struct cpufreq_policy *policy,
|
||||||
struct cpufreq_governor *new_gov,
|
struct cpufreq_governor *new_gov,
|
||||||
unsigned int new_pol);
|
unsigned int new_pol);
|
||||||
|
static bool cpufreq_boost_supported(void);
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Two notifier lists: the "policy" list is involved in the
|
* Two notifier lists: the "policy" list is involved in the
|
||||||
@ -455,8 +456,10 @@ void cpufreq_freq_transition_end(struct cpufreq_policy *policy,
|
|||||||
policy->cur,
|
policy->cur,
|
||||||
policy->cpuinfo.max_freq);
|
policy->cpuinfo.max_freq);
|
||||||
|
|
||||||
|
spin_lock(&policy->transition_lock);
|
||||||
policy->transition_ongoing = false;
|
policy->transition_ongoing = false;
|
||||||
policy->transition_task = NULL;
|
policy->transition_task = NULL;
|
||||||
|
spin_unlock(&policy->transition_lock);
|
||||||
|
|
||||||
wake_up(&policy->transition_wait);
|
wake_up(&policy->transition_wait);
|
||||||
}
|
}
|
||||||
@ -621,6 +624,40 @@ static ssize_t store_boost(struct kobject *kobj, struct kobj_attribute *attr,
|
|||||||
}
|
}
|
||||||
define_one_global_rw(boost);
|
define_one_global_rw(boost);
|
||||||
|
|
||||||
|
static ssize_t show_local_boost(struct cpufreq_policy *policy, char *buf)
|
||||||
|
{
|
||||||
|
return sysfs_emit(buf, "%d\n", policy->boost_enabled);
|
||||||
|
}
|
||||||
|
|
||||||
|
static ssize_t store_local_boost(struct cpufreq_policy *policy,
|
||||||
|
const char *buf, size_t count)
|
||||||
|
{
|
||||||
|
int ret, enable;
|
||||||
|
|
||||||
|
ret = kstrtoint(buf, 10, &enable);
|
||||||
|
if (ret || enable < 0 || enable > 1)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
if (!cpufreq_driver->boost_enabled)
|
||||||
|
return -EINVAL;
|
||||||
|
|
||||||
|
if (policy->boost_enabled == enable)
|
||||||
|
return count;
|
||||||
|
|
||||||
|
cpus_read_lock();
|
||||||
|
ret = cpufreq_driver->set_boost(policy, enable);
|
||||||
|
cpus_read_unlock();
|
||||||
|
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
|
||||||
|
policy->boost_enabled = enable;
|
||||||
|
|
||||||
|
return count;
|
||||||
|
}
|
||||||
|
|
||||||
|
static struct freq_attr local_boost = __ATTR(boost, 0644, show_local_boost, store_local_boost);
|
||||||
|
|
||||||
static struct cpufreq_governor *find_governor(const char *str_governor)
|
static struct cpufreq_governor *find_governor(const char *str_governor)
|
||||||
{
|
{
|
||||||
struct cpufreq_governor *t;
|
struct cpufreq_governor *t;
|
||||||
@ -1055,6 +1092,12 @@ static int cpufreq_add_dev_interface(struct cpufreq_policy *policy)
|
|||||||
return ret;
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (cpufreq_boost_supported()) {
|
||||||
|
ret = sysfs_create_file(&policy->kobj, &local_boost.attr);
|
||||||
|
if (ret)
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1943,16 +1986,16 @@ void cpufreq_resume(void)
|
|||||||
|
|
||||||
for_each_active_policy(policy) {
|
for_each_active_policy(policy) {
|
||||||
if (cpufreq_driver->resume && cpufreq_driver->resume(policy)) {
|
if (cpufreq_driver->resume && cpufreq_driver->resume(policy)) {
|
||||||
pr_err("%s: Failed to resume driver: %p\n", __func__,
|
pr_err("%s: Failed to resume driver: %s\n", __func__,
|
||||||
policy);
|
cpufreq_driver->name);
|
||||||
} else if (has_target()) {
|
} else if (has_target()) {
|
||||||
down_write(&policy->rwsem);
|
down_write(&policy->rwsem);
|
||||||
ret = cpufreq_start_governor(policy);
|
ret = cpufreq_start_governor(policy);
|
||||||
up_write(&policy->rwsem);
|
up_write(&policy->rwsem);
|
||||||
|
|
||||||
if (ret)
|
if (ret)
|
||||||
pr_err("%s: Failed to start governor for policy: %p\n",
|
pr_err("%s: Failed to start governor for CPU%u's policy\n",
|
||||||
__func__, policy);
|
__func__, policy->cpu);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -2716,6 +2759,8 @@ int cpufreq_boost_trigger_state(int state)
|
|||||||
ret = cpufreq_driver->set_boost(policy, state);
|
ret = cpufreq_driver->set_boost(policy, state);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto err_reset_state;
|
goto err_reset_state;
|
||||||
|
|
||||||
|
policy->boost_enabled = state;
|
||||||
}
|
}
|
||||||
cpus_read_unlock();
|
cpus_read_unlock();
|
||||||
|
|
||||||
|
|||||||
@ -439,7 +439,7 @@ int cpufreq_dbs_governor_init(struct cpufreq_policy *policy)
|
|||||||
|
|
||||||
ret = gov->init(dbs_data);
|
ret = gov->init(dbs_data);
|
||||||
if (ret)
|
if (ret)
|
||||||
goto free_policy_dbs_info;
|
goto free_dbs_data;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* The sampling interval should not be less than the transition latency
|
* The sampling interval should not be less than the transition latency
|
||||||
@ -474,6 +474,8 @@ int cpufreq_dbs_governor_init(struct cpufreq_policy *policy)
|
|||||||
if (!have_governor_per_policy())
|
if (!have_governor_per_policy())
|
||||||
gov->gdbs_data = NULL;
|
gov->gdbs_data = NULL;
|
||||||
gov->exit(dbs_data);
|
gov->exit(dbs_data);
|
||||||
|
|
||||||
|
free_dbs_data:
|
||||||
kfree(dbs_data);
|
kfree(dbs_data);
|
||||||
|
|
||||||
free_policy_dbs_info:
|
free_policy_dbs_info:
|
||||||
|
|||||||
@ -232,8 +232,8 @@ static int pcc_cpufreq_target(struct cpufreq_policy *policy,
|
|||||||
status = ioread16(&pcch_hdr->status);
|
status = ioread16(&pcch_hdr->status);
|
||||||
iowrite16(0, &pcch_hdr->status);
|
iowrite16(0, &pcch_hdr->status);
|
||||||
|
|
||||||
cpufreq_freq_transition_end(policy, &freqs, status != CMD_COMPLETE);
|
|
||||||
spin_unlock(&pcc_lock);
|
spin_unlock(&pcc_lock);
|
||||||
|
cpufreq_freq_transition_end(policy, &freqs, status != CMD_COMPLETE);
|
||||||
|
|
||||||
if (status != CMD_COMPLETE) {
|
if (status != CMD_COMPLETE) {
|
||||||
pr_debug("target: FAILED for cpu %d, with status: 0x%x\n",
|
pr_debug("target: FAILED for cpu %d, with status: 0x%x\n",
|
||||||
|
|||||||
@ -141,6 +141,9 @@ struct cpufreq_policy {
|
|||||||
*/
|
*/
|
||||||
bool dvfs_possible_from_any_cpu;
|
bool dvfs_possible_from_any_cpu;
|
||||||
|
|
||||||
|
/* Per policy boost enabled flag. */
|
||||||
|
bool boost_enabled;
|
||||||
|
|
||||||
/* Cached frequency lookup from cpufreq_driver_resolve_freq. */
|
/* Cached frequency lookup from cpufreq_driver_resolve_freq. */
|
||||||
unsigned int cached_target_freq;
|
unsigned int cached_target_freq;
|
||||||
unsigned int cached_resolved_idx;
|
unsigned int cached_resolved_idx;
|
||||||
|
|||||||
Loading…
Reference in New Issue
Block a user