Commit 6050cb1c authored by Rob Herring's avatar Rob Herring Committed by Geert Uytterhoeven

ARM: sh-mobile: Use of_cpu_node_to_id() to read CPU node 'reg'

Replace open coded CPU nodes reading of "reg" and translation to logical
ID with of_cpu_node_to_id().

The original code called of_parse_phandle() CONFIG_NR_CPUS times
regardless of the length of 'cpus'. Optimize the loop to bail out once
of_parse_phandle() fails as the end of 'cpus' property has been reached.
Signed-off-by: default avatarRob Herring <robh@kernel.org>
Reviewed-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Tested-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
Link: https://lore.kernel.org/r/20230327205228.573456-1-robh@kernel.orgSigned-off-by: default avatarGeert Uytterhoeven <geert+renesas@glider.be>
parent fe15c26e
...@@ -10,6 +10,7 @@ ...@@ -10,6 +10,7 @@
#include <linux/init.h> #include <linux/init.h>
#include <linux/io.h> #include <linux/io.h>
#include <linux/ioport.h> #include <linux/ioport.h>
#include <linux/of.h>
#include <linux/of_address.h> #include <linux/of_address.h>
#include <linux/smp.h> #include <linux/smp.h>
#include <linux/suspend.h> #include <linux/suspend.h>
...@@ -210,7 +211,6 @@ static void apmu_parse_dt(void (*fn)(struct resource *res, int cpu, int bit)) ...@@ -210,7 +211,6 @@ static void apmu_parse_dt(void (*fn)(struct resource *res, int cpu, int bit))
struct device_node *np_apmu, *np_cpu; struct device_node *np_apmu, *np_cpu;
struct resource res; struct resource res;
int bit, index; int bit, index;
u32 id;
for_each_matching_node(np_apmu, apmu_ids) { for_each_matching_node(np_apmu, apmu_ids) {
/* only enable the cluster that includes the boot CPU */ /* only enable the cluster that includes the boot CPU */
...@@ -218,35 +218,31 @@ static void apmu_parse_dt(void (*fn)(struct resource *res, int cpu, int bit)) ...@@ -218,35 +218,31 @@ static void apmu_parse_dt(void (*fn)(struct resource *res, int cpu, int bit))
for (bit = 0; bit < CONFIG_NR_CPUS; bit++) { for (bit = 0; bit < CONFIG_NR_CPUS; bit++) {
np_cpu = of_parse_phandle(np_apmu, "cpus", bit); np_cpu = of_parse_phandle(np_apmu, "cpus", bit);
if (np_cpu) { if (!np_cpu)
if (!of_property_read_u32(np_cpu, "reg", &id)) { break;
if (id == cpu_logical_map(0)) { if (of_cpu_node_to_id(np_cpu) == 0) {
is_allowed = true; is_allowed = true;
of_node_put(np_cpu); of_node_put(np_cpu);
break; break;
} }
}
of_node_put(np_cpu); of_node_put(np_cpu);
} }
}
if (!is_allowed) if (!is_allowed)
continue; continue;
for (bit = 0; bit < CONFIG_NR_CPUS; bit++) { for (bit = 0; bit < CONFIG_NR_CPUS; bit++) {
np_cpu = of_parse_phandle(np_apmu, "cpus", bit); np_cpu = of_parse_phandle(np_apmu, "cpus", bit);
if (np_cpu) { if (!np_cpu)
if (!of_property_read_u32(np_cpu, "reg", &id)) { break;
index = get_logical_index(id);
index = of_cpu_node_to_id(np_cpu);
if ((index >= 0) && if ((index >= 0) &&
!of_address_to_resource(np_apmu, !of_address_to_resource(np_apmu, 0, &res))
0, &res))
fn(&res, index, bit); fn(&res, index, bit);
}
of_node_put(np_cpu); of_node_put(np_cpu);
} }
} }
}
} }
static void __init shmobile_smp_apmu_setup_boot(void) static void __init shmobile_smp_apmu_setup_boot(void)
......
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