diff options
| author | Dietmar Eggemann <dietmar.eggemann@arm.com> | 2017-09-26 12:41:11 -0400 |
|---|---|---|
| committer | Rafael J. Wysocki <rafael.j.wysocki@intel.com> | 2017-10-02 20:37:54 -0400 |
| commit | 8216f588b52b61ce36fc0080218e4730435e58b7 (patch) | |
| tree | a65d5176435ac175bcf4c6fb29995e5fe3b8cb24 | |
| parent | 0e27c567d1673137b06aa96bb7aef635fb657dee (diff) | |
drivers base/arch_topology: allow inlining cpu-invariant accounting support
Allow inlining of topology_get_cpu_scale() into the task
scheduler fast path (e.g. __update_load_avg_se()) by coding it as a
static inline function in the arch topology header file.
Signed-off-by: Dietmar Eggemann <dietmar.eggemann@arm.com>
Acked-by: Viresh Kumar <viresh.kumar@linaro.org>
Signed-off-by: Rafael J. Wysocki <rafael.j.wysocki@intel.com>
| -rw-r--r-- | drivers/base/arch_topology.c | 7 | ||||
| -rw-r--r-- | include/linux/arch_topology.h | 8 |
2 files changed, 8 insertions, 7 deletions
diff --git a/drivers/base/arch_topology.c b/drivers/base/arch_topology.c index 416ec2f5211d..aea0b9d521f6 100644 --- a/drivers/base/arch_topology.c +++ b/drivers/base/arch_topology.c | |||
| @@ -37,12 +37,7 @@ void arch_set_freq_scale(struct cpumask *cpus, unsigned long cur_freq, | |||
| 37 | } | 37 | } |
| 38 | 38 | ||
| 39 | static DEFINE_MUTEX(cpu_scale_mutex); | 39 | static DEFINE_MUTEX(cpu_scale_mutex); |
| 40 | static DEFINE_PER_CPU(unsigned long, cpu_scale) = SCHED_CAPACITY_SCALE; | 40 | DEFINE_PER_CPU(unsigned long, cpu_scale) = SCHED_CAPACITY_SCALE; |
| 41 | |||
| 42 | unsigned long topology_get_cpu_scale(struct sched_domain *sd, int cpu) | ||
| 43 | { | ||
| 44 | return per_cpu(cpu_scale, cpu); | ||
| 45 | } | ||
| 46 | 41 | ||
| 47 | void topology_set_cpu_scale(unsigned int cpu, unsigned long capacity) | 42 | void topology_set_cpu_scale(unsigned int cpu, unsigned long capacity) |
| 48 | { | 43 | { |
diff --git a/include/linux/arch_topology.h b/include/linux/arch_topology.h index f6e490312e4d..c189de3ef5df 100644 --- a/include/linux/arch_topology.h +++ b/include/linux/arch_topology.h | |||
| @@ -12,8 +12,14 @@ void topology_normalize_cpu_scale(void); | |||
| 12 | struct device_node; | 12 | struct device_node; |
| 13 | bool topology_parse_cpu_capacity(struct device_node *cpu_node, int cpu); | 13 | bool topology_parse_cpu_capacity(struct device_node *cpu_node, int cpu); |
| 14 | 14 | ||
| 15 | DECLARE_PER_CPU(unsigned long, cpu_scale); | ||
| 16 | |||
| 15 | struct sched_domain; | 17 | struct sched_domain; |
| 16 | unsigned long topology_get_cpu_scale(struct sched_domain *sd, int cpu); | 18 | static inline |
| 19 | unsigned long topology_get_cpu_scale(struct sched_domain *sd, int cpu) | ||
| 20 | { | ||
| 21 | return per_cpu(cpu_scale, cpu); | ||
| 22 | } | ||
| 17 | 23 | ||
| 18 | void topology_set_cpu_scale(unsigned int cpu, unsigned long capacity); | 24 | void topology_set_cpu_scale(unsigned int cpu, unsigned long capacity); |
| 19 | 25 | ||
