aboutsummaryrefslogtreecommitdiffstats
path: root/arch/arm64/kernel/smp.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm64/kernel/smp.c')
-rw-r--r--arch/arm64/kernel/smp.c5
1 files changed, 4 insertions, 1 deletions
diff --git a/arch/arm64/kernel/smp.c b/arch/arm64/kernel/smp.c
index d4dcc6515253..a886194e58fd 100644
--- a/arch/arm64/kernel/smp.c
+++ b/arch/arm64/kernel/smp.c
@@ -270,6 +270,7 @@ void __init smp_init_cpus(void)
270 bool bootcpu_valid = false; 270 bool bootcpu_valid = false;
271 271
272 while ((dn = of_find_node_by_type(dn, "cpu"))) { 272 while ((dn = of_find_node_by_type(dn, "cpu"))) {
273 const u32 *cell;
273 u64 hwid; 274 u64 hwid;
274 275
275 /* 276 /*
@@ -277,10 +278,12 @@ void __init smp_init_cpus(void)
277 * considered invalid to build a cpu_logical_map 278 * considered invalid to build a cpu_logical_map
278 * entry. 279 * entry.
279 */ 280 */
280 if (of_property_read_u64(dn, "reg", &hwid)) { 281 cell = of_get_property(dn, "reg", NULL);
282 if (!cell) {
281 pr_err("%s: missing reg property\n", dn->full_name); 283 pr_err("%s: missing reg property\n", dn->full_name);
282 goto next; 284 goto next;
283 } 285 }
286 hwid = of_read_number(cell, of_n_addr_cells(dn));
284 287
285 /* 288 /*
286 * Non affinity bits must be set to 0 in the DT 289 * Non affinity bits must be set to 0 in the DT