Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/dev/fdt Do not sort cpu nodes when enumerating so they a...
details: https://anonhg.NetBSD.org/src/rev/118329e8109e
branches: trunk
changeset: 995696:118329e8109e
user: jmcneill <jmcneill%NetBSD.org@localhost>
date: Wed Jan 02 14:54:54 2019 +0000
description:
Do not sort cpu nodes when enumerating so they attach in the order listed
in the devicetree.
diffstat:
sys/dev/fdt/cpus.c | 15 ++++++++++-----
sys/dev/fdt/fdtbus.c | 40 ++++++++++++++++++++++++----------------
sys/dev/fdt/fdtvar.h | 3 ++-
3 files changed, 36 insertions(+), 22 deletions(-)
diffs (135 lines):
diff -r 6e9644018ab7 -r 118329e8109e sys/dev/fdt/cpus.c
--- a/sys/dev/fdt/cpus.c Wed Jan 02 14:31:33 2019 +0000
+++ b/sys/dev/fdt/cpus.c Wed Jan 02 14:54:54 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: cpus.c,v 1.4 2018/09/09 21:15:21 jmcneill Exp $ */
+/* $NetBSD: cpus.c,v 1.5 2019/01/02 14:54:54 jmcneill Exp $ */
/*-
* Copyright (c) 2017 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cpus.c,v 1.4 2018/09/09 21:15:21 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cpus.c,v 1.5 2019/01/02 14:54:54 jmcneill Exp $");
#include <sys/param.h>
#include <sys/bus.h>
@@ -42,7 +42,7 @@
static int cpus_match(device_t, cfdata_t, void *);
static void cpus_attach(device_t, device_t, void *);
-static bool cpus_bus_match(void *, int);
+static bool cpus_cpu_enabled(int);
CFATTACH_DECL_NEW(cpus, 0, cpus_match, cpus_attach, NULL, NULL);
@@ -59,15 +59,20 @@
{
struct fdt_attach_args * const faa = aux;
const int phandle = faa->faa_phandle;
+ int child;
aprint_naive("\n");
aprint_normal("\n");
- fdt_add_bus_match(self, phandle, faa, cpus_bus_match, NULL);
+ for (child = OF_child(phandle); child; child = OF_peer(child)) {
+ if (!cpus_cpu_enabled(child))
+ continue;
+ fdt_add_child(self, child, faa, 0);
+ }
}
static bool
-cpus_bus_match(void *priv, int child)
+cpus_cpu_enabled(int child)
{
const char *s;
diff -r 6e9644018ab7 -r 118329e8109e sys/dev/fdt/fdtbus.c
--- a/sys/dev/fdt/fdtbus.c Wed Jan 02 14:31:33 2019 +0000
+++ b/sys/dev/fdt/fdtbus.c Wed Jan 02 14:54:54 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: fdtbus.c,v 1.24 2018/09/23 19:32:03 jmcneill Exp $ */
+/* $NetBSD: fdtbus.c,v 1.25 2019/01/02 14:54:54 jmcneill Exp $ */
/*-
* Copyright (c) 2015 Jared D. McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: fdtbus.c,v 1.24 2018/09/23 19:32:03 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: fdtbus.c,v 1.25 2019/01/02 14:54:54 jmcneill Exp $");
#include <sys/param.h>
#include <sys/systm.h>
@@ -198,27 +198,35 @@
fdt_add_bus_match(device_t bus, const int phandle, struct fdt_attach_args *faa,
bool (*fn)(void *, int), void *fnarg)
{
- struct fdt_node *node;
int child;
for (child = OF_child(phandle); child; child = OF_peer(child)) {
if (fn && !fn(fnarg, child))
continue;
- /* Add the node to our device list */
- node = kmem_alloc(sizeof(*node), KM_SLEEP);
- node->n_bus = bus;
- node->n_dev = NULL;
- node->n_phandle = child;
- node->n_name = fdtbus_get_string(child, "name");
- node->n_order = fdt_get_order(child);
- node->n_faa = *faa;
- node->n_faa.faa_phandle = child;
- node->n_faa.faa_name = node->n_name;
+ fdt_add_child(bus, child, faa, fdt_get_order(child));
+ }
+}
+
+void
+fdt_add_child(device_t bus, const int child, struct fdt_attach_args *faa,
+ u_int order)
+{
+ struct fdt_node *node;
- fdt_add_node(node);
- fdt_need_rescan = true;
- }
+ /* Add the node to our device list */
+ node = kmem_alloc(sizeof(*node), KM_SLEEP);
+ node->n_bus = bus;
+ node->n_dev = NULL;
+ node->n_phandle = child;
+ node->n_name = fdtbus_get_string(child, "name");
+ node->n_order = order;
+ node->n_faa = *faa;
+ node->n_faa.faa_phandle = child;
+ node->n_faa.faa_name = node->n_name;
+
+ fdt_add_node(node);
+ fdt_need_rescan = true;
}
static int
diff -r 6e9644018ab7 -r 118329e8109e sys/dev/fdt/fdtvar.h
--- a/sys/dev/fdt/fdtvar.h Wed Jan 02 14:31:33 2019 +0000
+++ b/sys/dev/fdt/fdtvar.h Wed Jan 02 14:54:54 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: fdtvar.h,v 1.42 2018/09/15 13:42:41 jakllsch Exp $ */
+/* $NetBSD: fdtvar.h,v 1.43 2019/01/02 14:54:54 jmcneill Exp $ */
/*-
* Copyright (c) 2015 Jared D. McNeill <jmcneill%invisible.ca@localhost>
@@ -362,6 +362,7 @@
void fdt_add_bus(device_t, int, struct fdt_attach_args *);
void fdt_add_bus_match(device_t, int, struct fdt_attach_args *,
bool (*)(void *, int), void *);
+void fdt_add_child(device_t, int, struct fdt_attach_args *, u_int);
void fdt_remove_byhandle(int);
void fdt_remove_bycompat(const char *[]);
Home |
Main Index |
Thread Index |
Old Index