Source-Changes-HG archive

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

[src/thorpej-i2c-spi-conf2]: src/sys/dev/i2c Re-factor the code in sandpoint ...



details:   https://anonhg.NetBSD.org/src/rev/97fff5cfd1b8
branches:  thorpej-i2c-spi-conf2
changeset: 1024891:97fff5cfd1b8
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Sat Sep 11 01:03:18 2021 +0000

description:
Re-factor the code in sandpoint and sparc64 that enumerates a static
table of i2c device entries into something sharable.

diffstat:

 sys/arch/sandpoint/sandpoint/autoconf.c |  134 ++++++++++++++++++-------------
 sys/arch/sparc64/sparc64/ofw_patch.c    |   87 +++++--------------
 sys/dev/i2c/i2c.c                       |   39 ++++++++-
 sys/dev/i2c/i2cvar.h                    |   15 +++-
 4 files changed, 153 insertions(+), 122 deletions(-)

diffs (truncated from 483 to 300 lines):

diff -r 51b9ca1f6fc0 -r 97fff5cfd1b8 sys/arch/sandpoint/sandpoint/autoconf.c
--- a/sys/arch/sandpoint/sandpoint/autoconf.c   Fri Sep 10 15:45:27 2021 +0000
+++ b/sys/arch/sandpoint/sandpoint/autoconf.c   Sat Sep 11 01:03:18 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: autoconf.c,v 1.29.16.3 2021/09/10 15:45:28 thorpej Exp $       */
+/*     $NetBSD: autoconf.c,v 1.29.16.4 2021/09/11 01:03:18 thorpej Exp $       */
 
 /*-
  * Copyright (c) 1990 The Regents of the University of California.
@@ -35,7 +35,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: autoconf.c,v 1.29.16.3 2021/09/10 15:45:28 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: autoconf.c,v 1.29.16.4 2021/09/11 01:03:18 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -58,54 +58,82 @@
 static struct btinfo_prodfamily *bi_pfam;
 static struct btinfo_model *bi_model;
 
-struct sandpoint_i2cdev {
-       const char *    name;
-       const char *    compat;
-       uint32_t        model_mask;
-       i2c_addr_t      addr;
+struct sandpoint_i2c_data {
+       const struct i2c_deventry *entries;
+       unsigned int               nentries;
+       uint32_t                   model_mask;
+};
+
+static const struct i2c_deventry dlink_i2cdevs[] = {
+       { .name = "strtc", .compat = "st,m41t80", .addr = 0x68, },
+};
+static const struct sandpoint_i2c_data dlink_i2cdata[] = {
+       { .entries = dlink_i2cdevs,
+         .nentries = __arraycount(dlink_i2cdevs), },
+       { .entries = NULL },
 };
 
-static const struct sandpoint_i2cdev dlink_i2cdevs[] = {
-       { .name = "strtc", .compat = "st,m41t80", .addr = 0x68, },
-       { .name = NULL }
+static const struct i2c_deventry iomega_i2cdevs[] = {
+       { .name = "dsrtc", .compat = "dallas,ds1307", .addr = 0x68, },
+};
+static const struct sandpoint_i2c_data iomega_i2cdata[] = {
+       { .entries = iomega_i2cdevs,
+         .nentries = __arraycount(iomega_i2cdevs), },
+       { .entries = NULL },
 };
 
-static const struct sandpoint_i2cdev iomega_i2cdevs[] = {
-       { .name = "dsrtc", .compat = "dallas,ds1307", .addr = 0x68, },
-       { .name = NULL }
+static const struct i2c_deventry kurobox_i2cdevs[] = {
+       { .name = "rs5c372rtc", .compat = "ricoh,rs5c372a", .addr = 0x32, },
+};
+static const struct sandpoint_i2c_data kurobox_i2cdata[] = {
+       { .entries = kurobox_i2cdevs,
+         .nentries = __arraycount(kurobox_i2cdevs), },
+       { .entries = NULL },
 };
 
-static const struct sandpoint_i2cdev kurobox_i2cdevs[] = {
-       { .name = "rs5c372rtc", .compat = "ricoh,rs5c372a", .addr = 0x32, },
-       { .name = NULL }
+static const struct i2c_deventry nhnas_i2cdevs[] = {
+       { .name = "pcf8563rtc", .compat = "nxp,pcf8563", .addr = 0x51, },
 };
-
-static const struct sandpoint_i2cdev nhnas_i2cdevs[] = {
-       { .name = "pcf8563rtc", .compat = "nxp,pcf8563", .addr = 0x51, },
-       { .name = NULL }
+static const struct sandpoint_i2c_data nhnas_i2cdata[] = {
+       { .entries = nhnas_i2cdevs,
+         .nentries = __arraycount(nhnas_i2cdevs), },
+       { .entries = NULL },
 };
 
-static const struct sandpoint_i2cdev qnap_i2cdevs[] = {
+static const struct i2c_deventry qnap_i2cdevs[] = {
        { .name = "s390rtc", .compat = "sii,s35390a", .addr = 0x30, },
-       { .name = NULL }
+};
+static const struct sandpoint_i2c_data qnap_i2cdata[] = {
+       { .entries = qnap_i2cdevs,
+         .nentries = __arraycount(qnap_i2cdevs), },
+       { .entries = NULL },
 };
 
-static const struct sandpoint_i2cdev synology_i2cdevs[] = {
+static const struct i2c_deventry synology_thermal_i2cdevs[] = {
+       { .name = "rs5c372rtc", .compat = "ricoh,rs5c372a", .addr = 0x32, },
+       { .name = "lmtemp", .compat = "national,lm75", .addr = 0x48, },
+};
+static const struct i2c_deventry synology_i2cdevs[] = {
        { .name = "rs5c372rtc", .compat = "ricoh,rs5c372a", .addr = 0x32, },
-       { .name = "lmtemp", .compat = "national,lm75", .addr = 0x48,
-          .model_mask = BI_MODEL_THERMAL, },
-       { .name = NULL }
+};
+static const struct sandpoint_i2c_data synology_i2cdata[] = {
+       { .entries = synology_thermal_i2cdevs,
+         .nentries = __arraycount(synology_thermal_i2cdevs),
+         .model_mask  = BI_MODEL_THERMAL, },
+       { .entries = synology_i2cdevs,
+         .nentries = __arraycount(synology_i2cdevs), },
+       { .entries = NULL },
 };
 
 static const struct device_compatible_entry sandpoint_i2c_compat[] = {
-       { .compat = "dlink",            .data = &dlink_i2cdevs },
-       { .compat = "iomega",           .data = &iomega_i2cdevs },
-       { .compat = "kurobox",          .data = &kurobox_i2cdevs },
+       { .compat = "dlink",            .data = dlink_i2cdata },
+       { .compat = "iomega",           .data = iomega_i2cdata },
+       { .compat = "kurobox",          .data = kurobox_i2cdata },
        /* kurot4 has same i2c devices as kurobox */
-       { .compat = "kurot4",           .data = &kurobox_i2cdevs },
-       { .compat = "nhnas",            .data = &nhnas_i2cdevs },
-       { .compat = "qnap",             .data = &qnap_i2cdevs },
-       { .compat = "synology",         .data = &synology_i2cdevs },
+       { .compat = "kurot4",           .data = kurobox_i2cdata },
+       { .compat = "nhnas",            .data = nhnas_i2cdata },
+       { .compat = "qnap",             .data = qnap_i2cdata },
+       { .compat = "synology",         .data = synology_i2cdata },
        DEVICE_COMPAT_EOL
 };
 
@@ -115,10 +143,8 @@
 static int
 sandpoint_i2c_enumerate_devices(device_t dev, devhandle_t call_handle, void *v)
 {
-       struct i2c_enumerate_devices_args *args = v;
        const struct device_compatible_entry *dce;
-       const struct sandpoint_i2cdev *i2cdev;
-       bool cbrv;
+       const struct sandpoint_i2c_data *data;
 
        KASSERT(bi_pfam != NULL);
 
@@ -128,33 +154,27 @@
                /* no i2c devices for this model. */
                return 0;
        }
-       i2cdev = dce->data;
-       KASSERT(i2cdev != NULL);
+       data = dce->data;
+       KASSERT(data != NULL);
 
-       for (; i2cdev->name != NULL; i2cdev++) {
-               if (i2cdev->model_mask != 0) {
-                       KASSERT(bi_model != NULL);
-                       if ((i2cdev->model_mask & bi_model->flags) == 0) {
-                               /* skip this device. */
-                               continue;
-                       }
+       /* Filter by model_mask if necessary. */
+       for (; data->entries != NULL; data++) {
+               if (data->model_mask == 0) {
+                       /* We'll use this one! */
+                       break;
                }
-
-               args->ia->ia_addr = i2cdev->addr;
-               args->ia->ia_name = i2cdev->name;
-               args->ia->ia_clist = i2cdev->compat;
-               args->ia->ia_clist_size = strlen(i2cdev->compat) + 1;
-               /* no devhandle for child devices. */
-               devhandle_invalidate(&args->ia->ia_devhandle);
-
-               cbrv = args->callback(dev, args);
-
-               if (!cbrv) {
+               if ((data->model_mask & bi_model->flags) == data->model_mask) {
+                       /* We'll use this one! */
                        break;
                }
        }
+       if (data->entries == NULL) {
+               /* no i2c devies for this model. */
+               return 0;
+       }
 
-       return 0;
+       return i2c_enumerate_deventries(dev, call_handle, v,
+           data->entries, data->nentries);
 }
 
 static device_call_t
diff -r 51b9ca1f6fc0 -r 97fff5cfd1b8 sys/arch/sparc64/sparc64/ofw_patch.c
--- a/sys/arch/sparc64/sparc64/ofw_patch.c      Fri Sep 10 15:45:27 2021 +0000
+++ b/sys/arch/sparc64/sparc64/ofw_patch.c      Sat Sep 11 01:03:18 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ofw_patch.c,v 1.7.14.2 2021/09/10 15:45:28 thorpej Exp $ */
+/*     $NetBSD: ofw_patch.c,v 1.7.14.3 2021/09/11 01:03:18 thorpej Exp $ */
 
 /*-
  * Copyright (c) 2020, 2021 The NetBSD Foundation, Inc.
@@ -29,7 +29,7 @@
  * POSSIBILITY OF SUCH DAMAGE.
  */
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: ofw_patch.c,v 1.7.14.2 2021/09/10 15:45:28 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ofw_patch.c,v 1.7.14.3 2021/09/11 01:03:18 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/kmem.h>
@@ -90,12 +90,11 @@
  * On some systems, there are lots of i2c devices missing from the
  * device tree.
  *
- * The way we deal with this is by defining a devhandle_impl subclass
- * of the i2c controller's devhandle, create a new OF-type devhandle
- * with the new devhandle_impl, and stuff that into the controller
- * device's handle, which will then pass that handle on down to the iic bus
- * instance.  This devhandle_impl will implement "i2c-enumerate-devices",
- * and pass everything else along to the super.
+ * The way we deal with this is by subclassing the controller's
+ * devhandle_impl and overriding the "i2c-enumerate-devices" device
+ * call.  Our implementation will enumerate using the super-class
+ * (OpenFirmware enumeration), and then enumerate the missing entries
+ * from our own static tables.
  *
  * This devhandle_impl will be wrapped inside of a container structure
  * that will point to the extra devices that need to be added as children
@@ -104,18 +103,11 @@
  * additions.
  */
 
-struct i2c_addition {
-       const char *name;
-       const char *compat;
-       i2c_addr_t addr;
-};
-
 struct i2c_fixup_container {
        struct devhandle_impl i2c_devhandle_impl;
        devhandle_t i2c_super_handle;
-       const struct i2c_addition *i2c_additions;
+       const struct i2c_deventry *i2c_additions;
        int i2c_nadditions;
-       int i2c_phandle;
 };
 
 static int
@@ -128,46 +120,20 @@
                         struct i2c_fixup_container, i2c_devhandle_impl);
        devhandle_t super_handle = fixup->i2c_super_handle;
        device_call_t super_call;
-       int error;
+       int super_error, error;
 
        /* First, enumerate using whatever is in the device tree. */
        super_call = devhandle_lookup_device_call(super_handle,
            "i2c-enumerate-devices", &super_handle);
-       if (super_call != NULL) {
-               error = super_call(dev, super_handle, args);
-               if (error) {
-                       return error;
-               }
-       }
+       super_error = super_call != NULL ? super_call(dev, super_handle, args)
+                                        : 0;
 
        /* Now enumerate our additions. */
-       const struct i2c_addition *i2c_adds = fixup->i2c_additions;
-       KASSERT(i2c_adds != NULL);
-       int i;
-       bool cbrv;
+       KASSERT(fixup->i2c_additions != NULL);
+       error = i2c_enumerate_deventries(dev, call_handle, args,
+           fixup->i2c_additions, fixup->i2c_nadditions);
 
-       for (i = 0; i < fixup->i2c_nadditions; i++) {
-               args->ia->ia_addr = i2c_adds[i].addr;
-               args->ia->ia_name = i2c_adds[i].name;
-               args->ia->ia_clist = i2c_adds[i].compat;
-               args->ia->ia_clist_size = args->ia->ia_clist != NULL
-                   ? strlen(i2c_adds[i].compat) + 1
-                   : 0;
-               if (fixup->i2c_phandle != 0) {
-                       args->ia->ia_devhandle =
-                           devhandle_from_of(fixup->i2c_phandle);
-               } else {
-                       devhandle_invalidate(&args->ia->ia_devhandle);
-               }
-
-               cbrv = args->callback(dev, args);
-
-               if (! cbrv) {
-                       break;
-               }
-       }
-
-       return 0;
+       return super_error != 0 ? super_error : error;



Home | Main Index | Thread Index | Old Index