Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/sys/arch/arm/fdt Inspect #address-cells to determine if the ...



details:   https://anonhg.NetBSD.org/src/rev/49396cf1ca32
branches:  trunk
changeset: 985593:49396cf1ca32
user:      jmcneill <jmcneill%NetBSD.org@localhost>
date:      Mon Aug 30 23:16:17 2021 +0000

description:
Inspect #address-cells to determine if the cpu-release-addr requires
a 32- or 64-bit write.

diffstat:

 sys/arch/arm/fdt/cpu_fdt.c |  22 ++++++++++++++++------
 1 files changed, 16 insertions(+), 6 deletions(-)

diffs (59 lines):

diff -r d3ae514e7941 -r 49396cf1ca32 sys/arch/arm/fdt/cpu_fdt.c
--- a/sys/arch/arm/fdt/cpu_fdt.c        Mon Aug 30 23:14:14 2021 +0000
+++ b/sys/arch/arm/fdt/cpu_fdt.c        Mon Aug 30 23:16:17 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpu_fdt.c,v 1.40 2021/08/07 16:18:43 thorpej Exp $ */
+/* $NetBSD: cpu_fdt.c,v 1.41 2021/08/30 23:16:17 jmcneill Exp $ */
 
 /*-
  * Copyright (c) 2017 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -30,7 +30,7 @@
 #include "psci_fdt.h"
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cpu_fdt.c,v 1.40 2021/08/07 16:18:43 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpu_fdt.c,v 1.41 2021/08/30 23:16:17 jmcneill Exp $");
 
 #include <sys/param.h>
 #include <sys/atomic.h>
@@ -332,7 +332,8 @@
 
 #if defined(MULTIPROCESSOR) && defined(__aarch64__)
 static int
-spintable_cpu_on(u_int cpuindex, paddr_t entry_point_address, paddr_t cpu_release_addr)
+spintable_cpu_on(const int phandle, u_int cpuindex,
+    paddr_t entry_point_address, paddr_t cpu_release_addr)
 {
        /*
         * we need devmap for cpu-release-addr in advance.
@@ -346,10 +347,18 @@
                extern struct bus_space arm_generic_bs_tag;
                bus_space_handle_t ioh;
 
+               const int parent = OF_parent(phandle);
+               const int addr_cells = fdtbus_get_addr_cells(parent);
+
                bus_space_map(&arm_generic_bs_tag, cpu_release_addr,
                    sizeof(paddr_t), 0, &ioh);
-               bus_space_write_4(&arm_generic_bs_tag, ioh, 0,
-                   entry_point_address);
+               if (addr_cells == 1) {
+                       bus_space_write_4(&arm_generic_bs_tag, ioh, 0,
+                           entry_point_address);
+               } else {
+                       bus_space_write_8(&arm_generic_bs_tag, ioh, 0,
+                           entry_point_address);
+               }
                bus_space_unmap(&arm_generic_bs_tag, ioh, sizeof(paddr_t));
        }
 
@@ -367,7 +376,8 @@
        if (of_getprop_uint64(phandle, "cpu-release-addr", &addr) != 0)
                return ENXIO;
 
-       ret = spintable_cpu_on(mpidr, cpu_fdt_mpstart_pa(), (paddr_t)addr);
+       ret = spintable_cpu_on(phandle, mpidr, cpu_fdt_mpstart_pa(),
+           (paddr_t)addr);
        if (ret != 0)
                return EIO;
 



Home | Main Index | Thread Index | Old Index