Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/sdmmc Follow the Linux driver an use the FDT "compat...



details:   https://anonhg.NetBSD.org/src/rev/78e7cd413a65
branches:  trunk
changeset: 1006013:78e7cd413a65
user:      mlelstv <mlelstv%NetBSD.org@localhost>
date:      Mon Dec 30 16:28:14 2019 +0000

description:
Follow the Linux driver an use the FDT "compatible" property to build a
filename for the nvram config file, fall back to the standard filename.

E.g.

# ofctl -p /
[Caching 123 nodes and 1093 properties]
#address-cells          00000001 ........ ........ ........     1
#size-cells             00000001 ........ ........ ........     1
compatible              73696e6f 766f6970 2c627069 2d6d322d   "sinovoip,bpi-m2-
            0010:       7a65726f 00...... ........ ........   zero"
            0015:       616c6c77 696e6e65 722c7375 6e38692d   "allwinner,sun8i-
            0025:       68322d70 6c757300 ........ ........   h2-plus"
interrupt-parent        00000001 ........ ........ ........   ....
model                   42616e61 6e612050 69204250 492d4d32   "Banana Pi BPI-M2
            0010:       2d5a6572 6f00.... ........ ........   -Zero"
name                    00...... ........ ........ ........   ""
serial-number           30326330 30303432 65636431 36376566   02c00042ecd167ef
            0010:       00...... ........ ........ ........   .


-rw-r--r--  1 root  wheel     875 Nov  2 12:06 brcmfmac43430-sdio.AP6212.txt
lrwxr-xr-x  1 root  wheel      29 Dec 30 16:19 brcmfmac43430-sdio.sinovoip,bpi-m2-zero.txt -> brcmfmac43430-sdio.AP6212.txt
-rw-r--r--  1 root  wheel     874 Jun 30  2019 brcmfmac43430-sdio.raspberrypi,3-model-b.txt
-rw-r--r--  1 root  wheel    1864 Jun 30  2019 brcmfmac43455-sdio.raspberrypi,3-model-b-plus.txt
lrwxr-xr-x  1 root  wheel      29 Dec 30 11:24 brcmfmac43455-sdio.raspberrypi,4-model-b-plus.txt -> brcmfmac43455-sdio.raspberrypi,3-model-b-plus.txt

diffstat:

 sys/dev/sdmmc/if_bwfm_sdio.c |  37 ++++++++++++++++++++++++++++++++++---
 1 files changed, 34 insertions(+), 3 deletions(-)

diffs (93 lines):

diff -r 784373328daf -r 78e7cd413a65 sys/dev/sdmmc/if_bwfm_sdio.c
--- a/sys/dev/sdmmc/if_bwfm_sdio.c      Mon Dec 30 16:19:27 2019 +0000
+++ b/sys/dev/sdmmc/if_bwfm_sdio.c      Mon Dec 30 16:28:14 2019 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_bwfm_sdio.c,v 1.9 2019/10/28 06:37:52 mlelstv Exp $ */
+/* $NetBSD: if_bwfm_sdio.c,v 1.10 2019/12/30 16:28:14 mlelstv Exp $ */
 /* $OpenBSD: if_bwfm_sdio.c,v 1.1 2017/10/11 17:19:50 patrick Exp $ */
 /*
  * Copyright (c) 2010-2016 Broadcom Corporation
@@ -116,6 +116,7 @@
 static int     bwfm_sdio_detach(device_t, int);
 static void    bwfm_sdio_attachhook(device_t);
 static int     bwfm_fdt_find_phandle(device_t, device_t);
+static const char *bwfm_fdt_get_model(void);
 
 static void    bwfm_sdio_backplane(struct bwfm_sdio_softc *, uint32_t);
 static uint8_t bwfm_sdio_read_1(struct bwfm_sdio_softc *, uint32_t);
@@ -377,7 +378,8 @@
        struct bwfm_sdio_softc *sc = device_private(self);
        struct bwfm_softc *bwfm = &sc->sc_sc;
        firmware_handle_t fwh;
-       const char *name, *nvname;
+       const char *name, *nvname, *model;
+       char *nvnamebuf;
        u_char *ucode, *nvram;
        size_t size, nvlen, nvsize;
        uint32_t reg, clk;
@@ -435,6 +437,21 @@
                goto err;
        }
 
+       /* compute a model specific filename for the NV config */
+       nvnamebuf = NULL;
+       model = bwfm_fdt_get_model();
+       if (model != NULL) {
+               /* assume nvname ends in ".txt" */
+               nvnamebuf = kmem_asprintf("%.*s.%s.txt",
+                   (int)(strlen(nvname) - 4),
+                   nvname, model);
+       }
+
+       aprint_verbose_dev(self, "Firmware       %s\n", name);
+       aprint_verbose_dev(self, "Default Config %s\n", nvname);
+       if (nvnamebuf != NULL)
+               aprint_verbose_dev(self, "Model Config   %s\n", nvnamebuf);
+
        if (firmware_open("if_bwfm", name, &fwh) != 0) {
                printf("%s: failed firmware_open of file %s\n",
                    DEVNAME(sc), name);
@@ -456,7 +473,8 @@
                goto err1;
        }
 
-       if (firmware_open("if_bwfm", nvname, &fwh) != 0) {
+       if ((nvnamebuf == NULL || firmware_open("if_bwfm", nvnamebuf, &fwh) != 0)
+           && firmware_open("if_bwfm", nvname, &fwh) != 0) {
                printf("%s: failed firmware_open of file %s\n",
                    DEVNAME(sc), nvname);
                goto err1;
@@ -492,6 +510,8 @@
 
        firmware_free(nvram, nvlen);
        firmware_free(ucode, size);
+       if (nvnamebuf != NULL)
+               kmem_free(nvnamebuf, strlen(nvnamebuf)+1);
 
        sdmmc_pause(hztoms(1)*1000, NULL);
 
@@ -565,6 +585,8 @@
        firmware_free(nvram, nvlen);
 err1:
        firmware_free(ucode, size);
+       if (nvnamebuf != NULL)
+               kmem_free(nvnamebuf, strlen(nvnamebuf)+1);
 err:
        return;
 }
@@ -603,6 +625,15 @@
        return phandle;
 }
 
+static const char *
+bwfm_fdt_get_model(void)
+{
+       int phandle;
+
+       phandle = OF_finddevice("/");
+       return fdtbus_get_string_index(phandle, "compatible", 0);
+}
+
 static int
 bwfm_sdio_detach(device_t self, int flags)
 {



Home | Main Index | Thread Index | Old Index