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 Use device_compatible_entry / of_search_com...



details:   https://anonhg.NetBSD.org/src/rev/1dd256e1a358
branches:  trunk
changeset: 1018031:1dd256e1a358
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Tue Jan 19 00:40:17 2021 +0000

description:
Use device_compatible_entry / of_search_compatible() for the GICv3
quirk table.

diffstat:

 sys/arch/arm/fdt/gicv3_fdt.c |  47 ++++++++++++++++++++++---------------------
 1 files changed, 24 insertions(+), 23 deletions(-)

diffs (102 lines):

diff -r af3bf16ea560 -r 1dd256e1a358 sys/arch/arm/fdt/gicv3_fdt.c
--- a/sys/arch/arm/fdt/gicv3_fdt.c      Tue Jan 19 00:38:52 2021 +0000
+++ b/sys/arch/arm/fdt/gicv3_fdt.c      Tue Jan 19 00:40:17 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: gicv3_fdt.c,v 1.11 2021/01/15 00:38:22 jmcneill Exp $ */
+/* $NetBSD: gicv3_fdt.c,v 1.12 2021/01/19 00:40:17 thorpej Exp $ */
 
 /*-
  * Copyright (c) 2015-2018 Jared McNeill <jmcneill%invisible.ca@localhost>
@@ -31,7 +31,7 @@
 #define        _INTR_PRIVATE
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: gicv3_fdt.c,v 1.11 2021/01/15 00:38:22 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: gicv3_fdt.c,v 1.12 2021/01/19 00:40:17 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/bus.h>
@@ -107,29 +107,26 @@
        struct gicv3_fdt_irq    *sc_irq[GICV3_MAXIRQ];
 };
 
-struct gicv3_fdt_quirk {
-       const char              *compat;
-       u_int                   quirks;
-};
-
-static const struct gicv3_fdt_quirk gicv3_fdt_quirks[] = {
-       { "rockchip,rk3399",    GICV3_QUIRK_RK3399 },
+static const struct device_compatible_entry gicv3_fdt_quirks[] = {
+       { .compat = "rockchip,rk3399",          .value = GICV3_QUIRK_RK3399 },
+       { 0 }
 };
 
 CFATTACH_DECL_NEW(gicv3_fdt, sizeof(struct gicv3_fdt_softc),
        gicv3_fdt_match, gicv3_fdt_attach, NULL, NULL);
 
+static const struct device_compatible_entry compat_data[] = {
+       { .compat = "arm,gic-v3" },
+       { 0 }
+};
+
 static int
 gicv3_fdt_match(device_t parent, cfdata_t cf, void *aux)
 {
-       const char * const compatible[] = {
-               "arm,gic-v3",
-               NULL
-       };
        struct fdt_attach_args * const faa = aux;
        const int phandle = faa->faa_phandle;
 
-       return of_match_compatible(phandle, compatible);
+       return of_match_compat_data(phandle, compat_data);
 }
 
 static void
@@ -138,7 +135,7 @@
        struct gicv3_fdt_softc * const sc = device_private(self);
        struct fdt_attach_args * const faa = aux;
        const int phandle = faa->faa_phandle;
-       int error, n;
+       int error;
 
        error = fdtbus_register_interrupt_controller(self, phandle,
            &gicv3_fdt_funcs);
@@ -164,11 +161,10 @@
        aprint_debug_dev(self, "%d redistributors\n", sc->sc_gic.sc_bsh_r_count);
 
        /* Apply quirks */
-       for (n = 0; n < __arraycount(gicv3_fdt_quirks); n++) {
-               const char *compat[] = { gicv3_fdt_quirks[n].compat, NULL };
-               if (of_match_compatible(OF_finddevice("/"), compat)) {
-                       sc->sc_gic.sc_quirks |= gicv3_fdt_quirks[n].quirks;
-               }
+       const struct device_compatible_entry *dce =
+           of_search_compatible(OF_finddevice("/"), gicv3_fdt_quirks);
+       if (dce != NULL) {
+               sc->sc_gic.sc_quirks |= dce->value;
        }
 
        error = gicv3_init(&sc->sc_gic);
@@ -183,11 +179,16 @@
                gicv3_fdt_attach_mbi(sc);
        } else {
                /* Interrupt Translation Services */
-               for (int child = OF_child(phandle); child; child = OF_peer(child)) {
+               static const struct device_compatible_entry its_compat[] = {
+                       { .compat = "arm,gic-v3-its" },
+                       { 0 }
+               };
+
+               for (int child = OF_child(phandle); child;
+                    child = OF_peer(child)) {
                        if (!fdtbus_status_okay(child))
                                continue;
-                       const char * const its_compat[] = { "arm,gic-v3-its", NULL };
-                       if (of_match_compatible(child, its_compat))
+                       if (of_match_compat_data(child, its_compat))
                                gicv3_fdt_attach_its(sc, faa->faa_bst, child);
                }
        }



Home | Main Index | Thread Index | Old Index