Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/eisa Use eisa_compatible_{match,lookup}().



details:   https://anonhg.NetBSD.org/src/rev/4a595bd5c059
branches:  trunk
changeset: 980207:4a595bd5c059
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Wed Jan 27 04:35:15 2021 +0000

description:
Use eisa_compatible_{match,lookup}().

diffstat:

 sys/dev/eisa/ahb.c         |   36 ++++-----
 sys/dev/eisa/ahc_eisa.c    |   27 ++++---
 sys/dev/eisa/bha_eisa.c    |   28 ++++---
 sys/dev/eisa/cac_eisa.c    |   77 ++++++++++++++--------
 sys/dev/eisa/dpt_eisa.c    |   45 +++++-------
 sys/dev/eisa/if_ep_eisa.c  |  154 +++++++++++++++++++++++++++-----------------
 sys/dev/eisa/if_tlp_eisa.c |   54 ++++++---------
 sys/dev/eisa/mlx_eisa.c    |   53 ++++++---------
 sys/dev/eisa/uha_eisa.c    |   24 ++++--
 9 files changed, 266 insertions(+), 232 deletions(-)

diffs (truncated from 932 to 300 lines):

diff -r f5e5f4ba479b -r 4a595bd5c059 sys/dev/eisa/ahb.c
--- a/sys/dev/eisa/ahb.c        Wed Jan 27 04:31:36 2021 +0000
+++ b/sys/dev/eisa/ahb.c        Wed Jan 27 04:35:15 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ahb.c,v 1.64 2016/07/14 04:00:45 msaitoh Exp $ */
+/*     $NetBSD: ahb.c,v 1.65 2021/01/27 04:35:15 thorpej Exp $ */
 
 /*-
  * Copyright (c) 1997, 1998 The NetBSD Foundation, Inc.
@@ -46,7 +46,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ahb.c,v 1.64 2016/07/14 04:00:45 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ahb.c,v 1.65 2021/01/27 04:35:15 thorpej Exp $");
 
 #include "opt_ddb.h"
 
@@ -142,6 +142,14 @@
 
 #define        AHB_ABORT_TIMEOUT       2000    /* time to wait for abort (mSec) */
 
+static const struct device_compatible_entry compat_data[] = {
+       { .compat = "ADP0000",  .data = EISA_PRODUCT_ADP0000 },
+       { .compat = "ADP0001",  .data = EISA_PRODUCT_ADP0001 },
+       { .compat = "ADP0002",  .data = EISA_PRODUCT_ADP0002 },
+       { .compat = "ADP0400",  .data = EISA_PRODUCT_ADP0400 },
+       DEVICE_COMPAT_EOL
+};
+
 /*
  * Check the slots looking for a board we recognise
  * If we find one, note its address (slot) and call
@@ -155,11 +163,7 @@
        bus_space_handle_t ioh;
        int rv;
 
-       /* must match one of our known ID strings */
-       if (strcmp(ea->ea_idstring, "ADP0000") &&
-           strcmp(ea->ea_idstring, "ADP0001") &&
-           strcmp(ea->ea_idstring, "ADP0002") &&
-           strcmp(ea->ea_idstring, "ADP0400"))
+       if (!eisa_compatible_match(ea, compat_data))
                return (0);
 
        if (bus_space_map(iot,
@@ -182,11 +186,12 @@
 {
        struct eisa_attach_args *ea = aux;
        struct ahb_softc *sc = device_private(self);
+       const struct device_compatible_entry *dce;
        bus_space_tag_t iot = ea->ea_iot;
        bus_space_handle_t ioh;
        eisa_chipset_tag_t ec = ea->ea_ec;
        eisa_intr_handle_t ih;
-       const char *model, *intrstr;
+       const char *intrstr;
        struct ahb_probe_data apd;
        struct scsipi_adapter *adapt = &sc->sc_adapter;
        struct scsipi_channel *chan = &sc->sc_channel;
@@ -194,18 +199,11 @@
 
        sc->sc_dev = self;
 
-       if (!strcmp(ea->ea_idstring, "ADP0000"))
-               model = EISA_PRODUCT_ADP0000;
-       else if (!strcmp(ea->ea_idstring, "ADP0001"))
-               model = EISA_PRODUCT_ADP0001;
-       else if (!strcmp(ea->ea_idstring, "ADP0002"))
-               model = EISA_PRODUCT_ADP0002;
-       else if (!strcmp(ea->ea_idstring, "ADP0400"))
-               model = EISA_PRODUCT_ADP0400;
-       else
-               model = "unknown model!";
+       dce = eisa_compatible_lookup(ea, compat_data);
+       KASSERT(dce != NULL);
+
        aprint_naive("\n");
-       aprint_normal(": %s\n", model);
+       aprint_normal(": %s\n", (const char *)dce->data);
 
        if (bus_space_map(iot,
            EISA_SLOT_ADDR(ea->ea_slot) + AHB_EISA_SLOT_OFFSET,
diff -r f5e5f4ba479b -r 4a595bd5c059 sys/dev/eisa/ahc_eisa.c
--- a/sys/dev/eisa/ahc_eisa.c   Wed Jan 27 04:31:36 2021 +0000
+++ b/sys/dev/eisa/ahc_eisa.c   Wed Jan 27 04:35:15 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ahc_eisa.c,v 1.41 2016/07/11 11:31:50 msaitoh Exp $    */
+/*     $NetBSD: ahc_eisa.c,v 1.42 2021/01/27 04:35:15 thorpej Exp $    */
 
 /*
  * Product specific probe and attach routines for:
@@ -32,7 +32,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ahc_eisa.c,v 1.41 2016/07/11 11:31:50 msaitoh Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ahc_eisa.c,v 1.42 2021/01/27 04:35:15 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -63,6 +63,12 @@
 CFATTACH_DECL_NEW(ahc_eisa, sizeof(struct ahc_softc),
     ahc_eisa_match, ahc_eisa_attach, NULL, NULL);
 
+static const struct device_compatible_entry compat_data[] = {
+       { .compat = "ADP7770",  .data = EISA_PRODUCT_ADP7770 },
+       { .compat = "ADP7771",  .data = EISA_PRODUCT_ADP7771 },
+       DEVICE_COMPAT_EOL
+};
+
 /*
  * Check the slots looking for a board we recognise
  * If we find one, note its address (slot) and call
@@ -76,9 +82,7 @@
        bus_space_handle_t ioh;
        int irq;
 
-       /* must match one of our known ID strings */
-       if (strcmp(ea->ea_idstring, "ADP7770") &&
-           strcmp(ea->ea_idstring, "ADP7771"))
+       if (!eisa_compatible_match(ea, compat_data))
                return (0);
 
        if (bus_space_map(iot, EISA_SLOT_ADDR(ea->ea_slot) +
@@ -97,6 +101,7 @@
 {
        struct ahc_softc *ahc = device_private(self);
        struct eisa_attach_args *ea = aux;
+       const struct device_compatible_entry *dce;
        eisa_chipset_tag_t ec = ea->ea_ec;
        eisa_intr_handle_t ih;
        bus_space_tag_t iot = ea->ea_iot;
@@ -114,6 +119,9 @@
 
        ahc->sc_dev = self;
 
+       dce = eisa_compatible_lookup(ea, compat_data);
+       KASSERT(dce != NULL);
+
        if (bus_space_map(iot, EISA_SLOT_ADDR(ea->ea_slot) +
            AHC_EISA_SLOT_OFFSET, AHC_EISA_IOSIZE, 0, &ioh)) {
                aprint_error_dev(ahc->sc_dev, "could not map I/O addresses");
@@ -124,14 +132,7 @@
                goto free_io;
        }
 
-       if (strcmp(ea->ea_idstring, "ADP7770") == 0) {
-               printf(": %s\n", EISA_PRODUCT_ADP7770);
-       } else if (strcmp(ea->ea_idstring, "ADP7771") == 0) {
-               printf(": %s\n", EISA_PRODUCT_ADP7771);
-       } else {
-               printf(": Unknown device type %s", ea->ea_idstring);
-               goto free_io;
-       }
+       printf(": %s\n", (const char *)dce->data);
 
        ahc_set_name(ahc, device_xname(ahc->sc_dev));
        ahc->parent_dmat = ea->ea_dmat;
diff -r f5e5f4ba479b -r 4a595bd5c059 sys/dev/eisa/bha_eisa.c
--- a/sys/dev/eisa/bha_eisa.c   Wed Jan 27 04:31:36 2021 +0000
+++ b/sys/dev/eisa/bha_eisa.c   Wed Jan 27 04:35:15 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: bha_eisa.c,v 1.37 2014/10/18 08:33:27 snj Exp $        */
+/*     $NetBSD: bha_eisa.c,v 1.38 2021/01/27 04:35:15 thorpej Exp $    */
 
 /*-
  * Copyright (c) 1998 The NetBSD Foundation, Inc.
@@ -30,7 +30,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: bha_eisa.c,v 1.37 2014/10/18 08:33:27 snj Exp $");
+__KERNEL_RCSID(0, "$NetBSD: bha_eisa.c,v 1.38 2021/01/27 04:35:15 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -93,6 +93,12 @@
        return (0);
 }
 
+static const struct device_compatible_entry compat_data[] = {
+       { .compat = "BUS4201",  .data = EISA_PRODUCT_BUS4201 },
+       { .compat = "BUS4202",  .data = EISA_PRODUCT_BUS4202 },
+       DEVICE_COMPAT_EOL
+};
+
 /*
  * Check the slots looking for a board we recognise
  * If we find one, note its address (slot) and call
@@ -107,9 +113,7 @@
        int port;
        int rv;
 
-       /* must match one of our known ID strings */
-       if (strcmp(ea->ea_idstring, "BUS4201") &&
-           strcmp(ea->ea_idstring, "BUS4202"))
+       if (!eisa_compatible_match(ea, compat_data))
                return (0);
 
        if (bus_space_map(iot,
@@ -139,24 +143,22 @@
 {
        struct eisa_attach_args *ea = aux;
        struct bha_softc *sc = device_private(self);
+       const struct device_compatible_entry *dce;
        bus_space_tag_t iot = ea->ea_iot;
        bus_space_handle_t ioh, ioh2;
        int port;
        struct bha_probe_data bpd;
        eisa_chipset_tag_t ec = ea->ea_ec;
        eisa_intr_handle_t ih;
-       const char *model, *intrstr;
+       const char *intrstr;
        char intrbuf[EISA_INTRSTR_LEN];
 
        sc->sc_dev = self;
 
-       if (!strcmp(ea->ea_idstring, "BUS4201"))
-               model = EISA_PRODUCT_BUS4201;
-       else if (!strcmp(ea->ea_idstring, "BUS4202"))
-               model = EISA_PRODUCT_BUS4202;
-       else
-               model = "unknown model!";
-       printf(": %s\n", model);
+       dce = eisa_compatible_lookup(ea, compat_data);
+       KASSERT(dce != NULL);
+
+       printf(": %s\n", (const char *)dce->data);
 
        if (bus_space_map(iot,
            EISA_SLOT_ADDR(ea->ea_slot) + BHA_EISA_SLOT_OFFSET, BHA_EISA_IOSIZE,
diff -r f5e5f4ba479b -r 4a595bd5c059 sys/dev/eisa/cac_eisa.c
--- a/sys/dev/eisa/cac_eisa.c   Wed Jan 27 04:31:36 2021 +0000
+++ b/sys/dev/eisa/cac_eisa.c   Wed Jan 27 04:35:15 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cac_eisa.c,v 1.25 2016/09/27 03:33:32 pgoyette Exp $   */
+/*     $NetBSD: cac_eisa.c,v 1.26 2021/01/27 04:35:15 thorpej Exp $    */
 
 /*-
  * Copyright (c) 2000 The NetBSD Foundation, Inc.
@@ -61,7 +61,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cac_eisa.c,v 1.25 2016/09/27 03:33:32 pgoyette Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cac_eisa.c,v 1.26 2021/01/27 04:35:15 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -102,47 +102,68 @@
        cac_eisa_l0_submit
 };
 
-static struct cac_eisa_type {
-       const char      *ct_prodstr;
+struct cac_eisa_type {
        const char      *ct_typestr;
        const struct    cac_linkage *ct_linkage;
-} cac_eisa_type[] = {
-       { "CPQ4001",    "IDA",          &cac_eisa_l0 },
-       { "CPQ4002",    "IDA-2",        &cac_eisa_l0 },
-       { "CPQ4010",    "IEAS",         &cac_eisa_l0 },
-       { "CPQ4020",    "SMART",        &cac_eisa_l0 },
-       { "CPQ4030",    "SMART-2/E",    &cac_l0 },
+};
+
+static const struct cac_eisa_type cpq4001 = {
+       .ct_typestr = "IDA",
+       .ct_linkage = &cac_eisa_l0
+};
+
+static const struct cac_eisa_type cpq4002 = {
+       .ct_typestr = "IDA-2",
+       .ct_linkage = &cac_eisa_l0
+};
+
+static const struct cac_eisa_type cpq4010 = {
+       .ct_typestr = "IEAS",
+       .ct_linkage = &cac_eisa_l0
+};
+
+static const struct cac_eisa_type cpq4020 = {
+       .ct_typestr = "SMART",
+       .ct_linkage = &cac_eisa_l0
+};
+
+static const struct cac_eisa_type cpq4030 = {
+       .ct_typestr = "SMART-2/E",
+       .ct_linkage = &cac_l0
+};
+
+static const struct device_compatible_entry compat_data[] = {
+       { .compat = "CPQ4001",  .data = &cpq4001 },
+       { .compat = "CPQ4002",  .data = &cpq4002 },
+       { .compat = "CPQ4010",  .data = &cpq4010 },
+       { .compat = "CPQ4020",  .data = &cpq4020 },
+       { .compat = "CPQ4030",  .data = &cpq4030 },
+       DEVICE_COMPAT_EOL
 };



Home | Main Index | Thread Index | Old Index