Source-Changes-HG archive

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

[src/trunk]: src/sys/arch/arm/nvidia Use device_compatible_entry / of_search_...



details:   https://anonhg.NetBSD.org/src/rev/d584fa4297bd
branches:  trunk
changeset: 1018029:d584fa4297bd
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Tue Jan 19 00:36:09 2021 +0000

description:
Use device_compatible_entry / of_search_compatible() rather than
matching against multiple sets of compatinbility strings.

diffstat:

 sys/arch/arm/nvidia/tegra_pcie.c |  44 +++++++++++++++++++++++++--------------
 1 files changed, 28 insertions(+), 16 deletions(-)

diffs (105 lines):

diff -r 7b8b7c838ca6 -r d584fa4297bd sys/arch/arm/nvidia/tegra_pcie.c
--- a/sys/arch/arm/nvidia/tegra_pcie.c  Tue Jan 19 00:35:10 2021 +0000
+++ b/sys/arch/arm/nvidia/tegra_pcie.c  Tue Jan 19 00:36:09 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tegra_pcie.c,v 1.32 2021/01/15 23:11:59 jmcneill Exp $ */
+/* $NetBSD: tegra_pcie.c,v 1.33 2021/01/19 00:36:09 thorpej Exp $ */
 
 /*-
  * Copyright (c) 2015 Jared D. McNeill <jmcneill%invisible.ca@localhost>
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: tegra_pcie.c,v 1.32 2021/01/15 23:11:59 jmcneill Exp $");
+__KERNEL_RCSID(0, "$NetBSD: tegra_pcie.c,v 1.33 2021/01/19 00:36:09 thorpej Exp $");
 
 #include <sys/param.h>
 
@@ -65,6 +65,11 @@
 #define TEGRA_PCIE_NBUS 256
 #define TEGRA_PCIE_ECFB (1<<(12 - 8))  /* extended conf frags per bus */
 
+enum tegra_pcie_type {
+       TEGRA_PCIE_124          = 0,
+       TEGRA_PCIE_210          = 1,
+};
+
 struct tegra_pcie_ih {
        int                     (*ih_callback)(void *);
        void                    *ih_arg;
@@ -81,6 +86,7 @@
        bus_space_handle_t      sc_bsh_pads;
        bus_space_handle_t      sc_bsh_rpconf;
        int                     sc_phandle;
+       enum tegra_pcie_type    sc_type;
 
        struct arm32_pci_chipset sc_pc;
 
@@ -130,17 +136,18 @@
 CFATTACH_DECL_NEW(tegra_pcie, sizeof(struct tegra_pcie_softc),
        tegra_pcie_match, tegra_pcie_attach, NULL, NULL);
 
+static const struct device_compatible_entry compat_data[] = {
+       { .compat = "nvidia,tegra210-pcie",     .value = TEGRA_PCIE_210 },
+       { .compat = "nvidia,tegra124-pcie",     .value = TEGRA_PCIE_124 },
+       { 0 }
+};
+
 static int
 tegra_pcie_match(device_t parent, cfdata_t cf, void *aux)
 {
-       const char * const compatible[] = {
-               "nvidia,tegra210-pcie",
-               "nvidia,tegra124-pcie",
-               NULL
-       };
        struct fdt_attach_args * const faa = aux;
 
-       return of_match_compatible(faa->faa_phandle, compatible);
+       return of_match_compat_data(faa->faa_phandle, compat_data);
 }
 
 static void
@@ -148,6 +155,7 @@
 {
        struct tegra_pcie_softc * const sc = device_private(self);
        struct fdt_attach_args * const faa = aux;
+       const struct device_compatible_entry *dce;
        struct pciconf_resources *pcires;
        struct pcibus_attach_args pba;
        bus_addr_t afi_addr, cs_addr, pads_addr;
@@ -196,6 +204,10 @@
                return;
        }
 
+       dce = of_search_compatible(faa->faa_phandle, compat_data);
+       KASSERT(dce != NULL);
+       sc->sc_type = dce->value;
+
        tegra_pcie_conf_map_buses(sc);
 
        TAILQ_INIT(&sc->sc_intrs);
@@ -463,14 +475,14 @@
        bus_space_write_4(sc->sc_bst, sc->sc_bsh_afi, AFI_PCIE_CONFIG_REG, cfg);
 
        /* Configure refclk pad */
-       const char * const tegra124_compat[] = { "nvidia,tegra124-pcie", NULL };
-       if (of_match_compatible(sc->sc_phandle, tegra124_compat))
-               bus_space_write_4(sc->sc_bst, sc->sc_bsh_pads, PADS_REFCLK_CFG0_REG,
-                   0x44ac44ac);
-       const char * const tegra210_compat[] = { "nvidia,tegra210-pcie", NULL };
-       if (of_match_compatible(sc->sc_phandle, tegra210_compat))
-               bus_space_write_4(sc->sc_bst, sc->sc_bsh_pads, PADS_REFCLK_CFG0_REG,
-                   0x90b890b8);
+       if (sc->sc_type == TEGRA_PCIE_124) {
+               bus_space_write_4(sc->sc_bst, sc->sc_bsh_pads,
+                   PADS_REFCLK_CFG0_REG, 0x44ac44ac);
+       }
+       if (sc->sc_type == TEGRA_PCIE_210) {
+               bus_space_write_4(sc->sc_bst, sc->sc_bsh_pads,
+                   PADS_REFCLK_CFG0_REG, 0x90b890b8);
+       }
 
        /*
         * Map PCI address spaces into ARM address space via



Home | Main Index | Thread Index | Old Index