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/sys Add a devhandle_subclass() helper fu...
details:   https://anonhg.NetBSD.org/src/rev/f2e485dd2298
branches:  thorpej-i2c-spi-conf2
changeset: 985865:f2e485dd2298
user:      thorpej <thorpej%NetBSD.org@localhost>
date:      Sat Sep 11 17:22:35 2021 +0000
description:
Add a devhandle_subclass() helper function to simplify the common case
and use it.  Improve some comments.
diffstat:
 sys/arch/macppc/dev/cuda.c           |  19 +++++++------------
 sys/arch/macppc/dev/ki2c.c           |   6 +++---
 sys/arch/sparc64/sparc64/ofw_patch.c |  12 +++++-------
 sys/kern/subr_device.c               |  20 ++++++++++++++++++--
 sys/sys/device.h                     |   5 ++++-
 5 files changed, 37 insertions(+), 25 deletions(-)
diffs (160 lines):
diff -r 14373fa547bc -r f2e485dd2298 sys/arch/macppc/dev/cuda.c
--- a/sys/arch/macppc/dev/cuda.c        Sat Sep 11 15:22:57 2021 +0000
+++ b/sys/arch/macppc/dev/cuda.c        Sat Sep 11 17:22:35 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: cuda.c,v 1.29.2.4 2021/09/11 15:22:57 thorpej Exp $ */
+/*     $NetBSD: cuda.c,v 1.29.2.5 2021/09/11 17:22:35 thorpej Exp $ */
 
 /*-
  * Copyright (c) 2006 Michael Lorenz
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: cuda.c,v 1.29.2.4 2021/09/11 15:22:57 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: cuda.c,v 1.29.2.5 2021/09/11 17:22:35 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -307,17 +307,12 @@
        }
 
        /*
-        * Normally the i2c bus instance would automatically inherit
-        * our devhandle, but we provide our own i2c device enumeration
-        * method, so we need to supply the bus instance with our own
-        * device handle implementation, using the one we got from
-        * OpenFirmware as the "super".
+        * Subclass our device handle so we can override
+        * "i2c-enumerate-devices" and give that to the
+        * i2c bus instance.
         */
-       devhandle_t devhandle = devhandle_from_of(sc->sc_node);
-       devhandle_impl_inherit(&sc->sc_devhandle_impl, devhandle.impl);
-       sc->sc_devhandle_impl.lookup_device_call =
-           cuda_devhandle_lookup_device_call;
-       devhandle.impl = &sc->sc_devhandle_impl;
+       devhandle_t devhandle = devhandle_subclass(device_handle(self),
+           &sc->sc_devhandle_impl, cuda_devhandle_lookup_device_call);
 
        iic_tag_init(&sc->sc_i2c);
        sc->sc_i2c.ic_cookie = sc;
diff -r 14373fa547bc -r f2e485dd2298 sys/arch/macppc/dev/ki2c.c
--- a/sys/arch/macppc/dev/ki2c.c        Sat Sep 11 15:22:57 2021 +0000
+++ b/sys/arch/macppc/dev/ki2c.c        Sat Sep 11 17:22:35 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ki2c.c,v 1.32.2.3 2021/09/11 14:47:06 thorpej Exp $    */
+/*     $NetBSD: ki2c.c,v 1.32.2.4 2021/09/11 17:22:35 thorpej Exp $    */
 /*     Id: ki2c.c,v 1.7 2002/10/05 09:56:05 tsubai Exp */
 
 /*-
@@ -381,8 +381,8 @@
        }
 
        /*
-        * Set up our handle implementation (we provide our own
-        * i2c enumeration call).
+        * Set up our handle implementation so that we can override
+        * "i2c-enumerate-devices".
         */
        devhandle = device_handle(self);
        devhandle_impl_inherit(&sc->sc_devhandle_impl, devhandle.impl);
diff -r 14373fa547bc -r f2e485dd2298 sys/arch/sparc64/sparc64/ofw_patch.c
--- a/sys/arch/sparc64/sparc64/ofw_patch.c      Sat Sep 11 15:22:57 2021 +0000
+++ b/sys/arch/sparc64/sparc64/ofw_patch.c      Sat Sep 11 17:22:35 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: ofw_patch.c,v 1.7.14.4 2021/09/11 13:02:29 thorpej Exp $ */
+/*     $NetBSD: ofw_patch.c,v 1.7.14.5 2021/09/11 17:22:36 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.4 2021/09/11 13:02:29 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: ofw_patch.c,v 1.7.14.5 2021/09/11 17:22:36 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/kmem.h>
@@ -163,17 +163,15 @@
        devhandle_t devhandle = device_handle(dev);
        fixup->i2c_super_handle = devhandle;
 
-       /* Sub-class the devhandle_impl. */
-       devhandle_impl_inherit(&fixup->i2c_devhandle_impl, devhandle.impl);
-       fixup->i2c_devhandle_impl.lookup_device_call =
-           i2c_fixup_lookup_device_call;
+       /* Sub-class it so we can override "i2c-enumerate-devices". */
+       devhandle = devhandle_subclass(devhandle, &fixup->i2c_devhandle_impl,
+           i2c_fixup_lookup_device_call);
 
        /*
         * ...and slide that on into the device.  This handle will be
         * passed on to the iic bus instance, and our enumeration method
         * will get called to enumerate the child devices.
         */
-       devhandle.impl = &fixup->i2c_devhandle_impl;
        device_set_handle(dev, devhandle);
 }
 
diff -r 14373fa547bc -r f2e485dd2298 sys/kern/subr_device.c
--- a/sys/kern/subr_device.c    Sat Sep 11 15:22:57 2021 +0000
+++ b/sys/kern/subr_device.c    Sat Sep 11 17:22:35 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: subr_device.c,v 1.8 2021/08/07 18:16:42 thorpej Exp $  */
+/*     $NetBSD: subr_device.c,v 1.8.2.1 2021/09/11 17:22:36 thorpej Exp $      */
 
 /*
  * Copyright (c) 2006, 2021 The NetBSD Foundation, Inc.
@@ -27,7 +27,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: subr_device.c,v 1.8 2021/08/07 18:16:42 thorpej Exp $");
+__KERNEL_RCSID(0, "$NetBSD: subr_device.c,v 1.8.2.1 2021/09/11 17:22:36 thorpej Exp $");
 
 #include <sys/param.h>
 #include <sys/device.h>
@@ -106,6 +106,22 @@
 }
 
 /*
+ * Helper function that provides a short-hand method of the common
+ * "subclass a device handle" flow.
+ */
+devhandle_t
+devhandle_subclass(devhandle_t handle,
+    struct devhandle_impl *new_impl,
+    device_call_t (*new_lookup)(devhandle_t, const char *, devhandle_t *))
+{
+       devhandle_impl_inherit(new_impl, handle.impl);
+       new_impl->lookup_device_call = new_lookup;
+       handle.impl = new_impl;
+
+       return handle;
+}
+
+/*
  * Accessor functions for the device_t type.
  */
 
diff -r 14373fa547bc -r f2e485dd2298 sys/sys/device.h
--- a/sys/sys/device.h  Sat Sep 11 15:22:57 2021 +0000
+++ b/sys/sys/device.h  Sat Sep 11 17:22:35 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: device.h,v 1.173 2021/08/07 18:16:42 thorpej Exp $ */
+/* $NetBSD: device.h,v 1.173.2.1 2021/09/11 17:22:36 thorpej Exp $ */
 
 /*
  * Copyright (c) 2021 The NetBSD Foundation, Inc.
@@ -670,6 +670,9 @@
 bool           devhandle_is_valid(devhandle_t);
 void           devhandle_invalidate(devhandle_t *);
 devhandle_type_t devhandle_type(devhandle_t);
+devhandle_t    devhandle_subclass(devhandle_t, struct devhandle_impl *,
+                   device_call_t (*)(devhandle_t, const char *,
+                                     devhandle_t *));
 
 device_call_t  devhandle_lookup_device_call(devhandle_t, const char *,
                    devhandle_t *);
Home |
Main Index |
Thread Index |
Old Index