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