Commit 816a8de0 authored by Sudeep KarkadaNagesha's avatar Sudeep KarkadaNagesha

ARM: topology: remove hwid/MPIDR dependency from cpu_capacity

Currently the topology code computes cpu capacity and stores it in
the list along with hwid(which is MPIDR) as it parses the CPU nodes
in the device tree. This is required as it needs to be mapped to the
logical CPU later.

Since the CPU device nodes can be retrieved in the logical ordering
using DT/OF helpers, its possible to store cpu_capacity also in logical
ordering and avoid storing hwid for each entry.

This patch removes hwid by making use of of_get_cpu_node.

Cc: Russell King <linux@arm.linux.org.uk>
Cc: Lorenzo Pieralisi <lorenzo.pieralisi@arm.com>
Acked-by: default avatarRob Herring <rob.herring@calxeda.com>
Acked-by: default avatarNicolas Pitre <nico@linaro.org>
Signed-off-by: default avatarSudeep KarkadaNagesha <sudeep.karkadanagesha@arm.com>
parent bd00860e
...@@ -74,12 +74,8 @@ struct cpu_efficiency table_efficiency[] = { ...@@ -74,12 +74,8 @@ struct cpu_efficiency table_efficiency[] = {
{NULL, }, {NULL, },
}; };
struct cpu_capacity { unsigned long *__cpu_capacity;
unsigned long hwid; #define cpu_capacity(cpu) __cpu_capacity[cpu]
unsigned long capacity;
};
struct cpu_capacity *cpu_capacity;
unsigned long middle_capacity = 1; unsigned long middle_capacity = 1;
...@@ -100,15 +96,19 @@ static void __init parse_dt_topology(void) ...@@ -100,15 +96,19 @@ static void __init parse_dt_topology(void)
unsigned long capacity = 0; unsigned long capacity = 0;
int alloc_size, cpu = 0; int alloc_size, cpu = 0;
alloc_size = nr_cpu_ids * sizeof(struct cpu_capacity); alloc_size = nr_cpu_ids * sizeof(*__cpu_capacity);
cpu_capacity = kzalloc(alloc_size, GFP_NOWAIT); __cpu_capacity = kzalloc(alloc_size, GFP_NOWAIT);
while ((cn = of_find_node_by_type(cn, "cpu"))) { for_each_possible_cpu(cpu) {
const u32 *rate, *reg; const u32 *rate;
int len; int len;
if (cpu >= num_possible_cpus()) /* too early to use cpu->of_node */
break; cn = of_get_cpu_node(cpu, NULL);
if (!cn) {
pr_err("missing device node for CPU %d\n", cpu);
continue;
}
for (cpu_eff = table_efficiency; cpu_eff->compatible; cpu_eff++) for (cpu_eff = table_efficiency; cpu_eff->compatible; cpu_eff++)
if (of_device_is_compatible(cn, cpu_eff->compatible)) if (of_device_is_compatible(cn, cpu_eff->compatible))
...@@ -124,12 +124,6 @@ static void __init parse_dt_topology(void) ...@@ -124,12 +124,6 @@ static void __init parse_dt_topology(void)
continue; continue;
} }
reg = of_get_property(cn, "reg", &len);
if (!reg || len != 4) {
pr_err("%s missing reg property\n", cn->full_name);
continue;
}
capacity = ((be32_to_cpup(rate)) >> 20) * cpu_eff->efficiency; capacity = ((be32_to_cpup(rate)) >> 20) * cpu_eff->efficiency;
/* Save min capacity of the system */ /* Save min capacity of the system */
...@@ -140,13 +134,9 @@ static void __init parse_dt_topology(void) ...@@ -140,13 +134,9 @@ static void __init parse_dt_topology(void)
if (capacity > max_capacity) if (capacity > max_capacity)
max_capacity = capacity; max_capacity = capacity;
cpu_capacity[cpu].capacity = capacity; cpu_capacity(cpu) = capacity;
cpu_capacity[cpu++].hwid = be32_to_cpup(reg);
} }
if (cpu < num_possible_cpus())
cpu_capacity[cpu].hwid = (unsigned long)(-1);
/* If min and max capacities are equals, we bypass the update of the /* If min and max capacities are equals, we bypass the update of the
* cpu_scale because all CPUs have the same capacity. Otherwise, we * cpu_scale because all CPUs have the same capacity. Otherwise, we
* compute a middle_capacity factor that will ensure that the capacity * compute a middle_capacity factor that will ensure that the capacity
...@@ -154,9 +144,7 @@ static void __init parse_dt_topology(void) ...@@ -154,9 +144,7 @@ static void __init parse_dt_topology(void)
* SCHED_POWER_SCALE, which is the default value, but with the * SCHED_POWER_SCALE, which is the default value, but with the
* constraint explained near table_efficiency[]. * constraint explained near table_efficiency[].
*/ */
if (min_capacity == max_capacity) if (4*max_capacity < (3*(max_capacity + min_capacity)))
cpu_capacity[0].hwid = (unsigned long)(-1);
else if (4*max_capacity < (3*(max_capacity + min_capacity)))
middle_capacity = (min_capacity + max_capacity) middle_capacity = (min_capacity + max_capacity)
>> (SCHED_POWER_SHIFT+1); >> (SCHED_POWER_SHIFT+1);
else else
...@@ -170,23 +158,12 @@ static void __init parse_dt_topology(void) ...@@ -170,23 +158,12 @@ static void __init parse_dt_topology(void)
* boot. The update of all CPUs is in O(n^2) for heteregeneous system but the * boot. The update of all CPUs is in O(n^2) for heteregeneous system but the
* function returns directly for SMP system. * function returns directly for SMP system.
*/ */
void update_cpu_power(unsigned int cpu, unsigned long hwid) void update_cpu_power(unsigned int cpu)
{ {
unsigned int idx = 0; if (!cpu_capacity(cpu))
/* look for the cpu's hwid in the cpu capacity table */
for (idx = 0; idx < num_possible_cpus(); idx++) {
if (cpu_capacity[idx].hwid == hwid)
break;
if (cpu_capacity[idx].hwid == -1)
return;
}
if (idx == num_possible_cpus())
return; return;
set_power_scale(cpu, cpu_capacity[idx].capacity / middle_capacity); set_power_scale(cpu, cpu_capacity(cpu) / middle_capacity);
printk(KERN_INFO "CPU%u: update cpu_power %lu\n", printk(KERN_INFO "CPU%u: update cpu_power %lu\n",
cpu, arch_scale_freq_power(NULL, cpu)); cpu, arch_scale_freq_power(NULL, cpu));
...@@ -194,7 +171,7 @@ void update_cpu_power(unsigned int cpu, unsigned long hwid) ...@@ -194,7 +171,7 @@ void update_cpu_power(unsigned int cpu, unsigned long hwid)
#else #else
static inline void parse_dt_topology(void) {} static inline void parse_dt_topology(void) {}
static inline void update_cpu_power(unsigned int cpuid, unsigned int mpidr) {} static inline void update_cpu_power(unsigned int cpuid) {}
#endif #endif
/* /*
...@@ -281,7 +258,7 @@ void store_cpu_topology(unsigned int cpuid) ...@@ -281,7 +258,7 @@ void store_cpu_topology(unsigned int cpuid)
update_siblings_masks(cpuid); update_siblings_masks(cpuid);
update_cpu_power(cpuid, mpidr & MPIDR_HWID_BITMASK); update_cpu_power(cpuid);
printk(KERN_INFO "CPU%u: thread %d, cpu %d, socket %d, mpidr %x\n", printk(KERN_INFO "CPU%u: thread %d, cpu %d, socket %d, mpidr %x\n",
cpuid, cpu_topology[cpuid].thread_id, cpuid, cpu_topology[cpuid].thread_id,
......
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