The branch main has been updated by jhb:

URL: 
https://cgit.FreeBSD.org/src/commit/?id=cf416f56eb73006b32f9279da6a848299ede3f1d

commit cf416f56eb73006b32f9279da6a848299ede3f1d
Author:     John Baldwin <j...@freebsd.org>
AuthorDate: 2025-01-02 18:22:20 +0000
Commit:     John Baldwin <j...@freebsd.org>
CommitDate: 2025-01-02 18:22:20 +0000

    Use the new bus_generic_detach directly in place of home-grown versions
    
    Differential Revision:  https://reviews.freebsd.org/D47960
---
 sys/dev/bwn/if_bwn_pci.c        | 13 +------------
 sys/dev/iicbus/iicbb.c          | 13 +------------
 sys/dev/imcsmb/imcsmb.c         | 27 +--------------------------
 sys/dev/imcsmb/imcsmb_pci.c     | 27 +--------------------------
 sys/dev/p2sb/lewisburg_gpiocm.c | 14 +-------------
 sys/dev/pci/vga_pci.c           | 13 +------------
 sys/dev/ppbus/ppbconf.c         | 17 +----------------
 sys/dev/pwm/pwmbus.c            | 13 +------------
 sys/dev/usb/misc/cp2112.c       | 17 ++---------------
 9 files changed, 10 insertions(+), 144 deletions(-)

diff --git a/sys/dev/bwn/if_bwn_pci.c b/sys/dev/bwn/if_bwn_pci.c
index e2ba15dd67c8..a81284158443 100644
--- a/sys/dev/bwn/if_bwn_pci.c
+++ b/sys/dev/bwn/if_bwn_pci.c
@@ -189,17 +189,6 @@ bwn_pci_attach(device_t dev)
        return (0);
 }
 
-static int
-bwn_pci_detach(device_t dev)
-{
-       int error;
-
-       if ((error = bus_generic_detach(dev)))
-               return (error);
-
-       return (device_delete_children(dev));
-}
-
 static void
 bwn_pci_probe_nomatch(device_t dev, device_t child)
 {
@@ -268,7 +257,7 @@ static device_method_t bwn_pci_methods[] = {
        /* Device interface */
        DEVMETHOD(device_probe,                 bwn_pci_probe),
        DEVMETHOD(device_attach,                bwn_pci_attach),
-       DEVMETHOD(device_detach,                bwn_pci_detach),
+       DEVMETHOD(device_detach,                bus_generic_detach),
        DEVMETHOD(device_shutdown,              bus_generic_shutdown),
        DEVMETHOD(device_suspend,               bus_generic_suspend),
        DEVMETHOD(device_resume,                bus_generic_resume),
diff --git a/sys/dev/iicbus/iicbb.c b/sys/dev/iicbus/iicbb.c
index dec5e4bc0c7e..c344bda930b0 100644
--- a/sys/dev/iicbus/iicbb.c
+++ b/sys/dev/iicbus/iicbb.c
@@ -80,7 +80,6 @@ struct iicbb_softc {
 
 static int iicbb_attach(device_t);
 static void iicbb_child_detached(device_t, device_t);
-static int iicbb_detach(device_t);
 static int iicbb_print_child(device_t, device_t);
 static int iicbb_probe(device_t);
 
@@ -101,7 +100,7 @@ static device_method_t iicbb_methods[] = {
        /* device interface */
        DEVMETHOD(device_probe,         iicbb_probe),
        DEVMETHOD(device_attach,        iicbb_attach),
-       DEVMETHOD(device_detach,        iicbb_detach),
+       DEVMETHOD(device_detach,        bus_generic_detach),
 
        /* bus interface */
        DEVMETHOD(bus_child_detached,   iicbb_child_detached),
@@ -168,16 +167,6 @@ iicbb_attach(device_t dev)
        return (0);
 }
 
-static int
-iicbb_detach(device_t dev)
-{
-
-       bus_generic_detach(dev);
-       device_delete_children(dev);
-
-       return (0);
-}
-
 #ifdef FDT
 static phandle_t
 iicbb_get_node(device_t bus, device_t dev)
diff --git a/sys/dev/imcsmb/imcsmb.c b/sys/dev/imcsmb/imcsmb.c
index 2507d948e8e4..50280ad1b0f7 100644
--- a/sys/dev/imcsmb/imcsmb.c
+++ b/sys/dev/imcsmb/imcsmb.c
@@ -53,7 +53,6 @@
 
 /* Device methods */
 static int imcsmb_attach(device_t dev);
-static int imcsmb_detach(device_t dev);
 static int imcsmb_probe(device_t dev);
 
 /* SMBus methods */
@@ -106,30 +105,6 @@ out:
        return (rc);
 }
 
-/**
- * device_detach() method. attach() didn't do any allocations, so all that's
- * needed here is to free up any downstream drivers and children.
- *
- * @author Joe Kloss
- *
- * @param[in] dev
- *      Device being detached.
- */
-static int
-imcsmb_detach(device_t dev)
-{
-       int rc;
-
-       /* Detach any attached drivers */
-       rc = bus_generic_detach(dev);
-       if (rc == 0) {
-               /* Remove all children */
-               rc = device_delete_children(dev);
-       }
-
-       return (rc);
-}
-
 /**
  * device_probe() method. All the actual probing was done by the imcsmb_pci
  * parent, so just report success.
@@ -522,7 +497,7 @@ out:
 static device_method_t imcsmb_methods[] = {
        /* Device interface */
        DEVMETHOD(device_attach,        imcsmb_attach),
-       DEVMETHOD(device_detach,        imcsmb_detach),
+       DEVMETHOD(device_detach,        bus_generic_detach),
        DEVMETHOD(device_probe,         imcsmb_probe),
 
        /* smbus methods */
diff --git a/sys/dev/imcsmb/imcsmb_pci.c b/sys/dev/imcsmb/imcsmb_pci.c
index c6e5d1d690c0..6e9e601989b1 100644
--- a/sys/dev/imcsmb/imcsmb_pci.c
+++ b/sys/dev/imcsmb/imcsmb_pci.c
@@ -146,7 +146,6 @@ static struct imcsmb_pci_device {
 
 /* Device methods. */
 static int imcsmb_pci_attach(device_t dev);
-static int imcsmb_pci_detach(device_t dev);
 static int imcsmb_pci_probe(device_t dev);
 
 /**
@@ -195,30 +194,6 @@ out:
        return (rc);
 }
 
-/**
- * device_detach() method. attach() didn't do any allocations, so all that's
- * needed here is to free up any downstream drivers and children.
- *
- * @author Joe Kloss
- *
- * @param[in] dev
- *      Device being detached.
- */
-static int
-imcsmb_pci_detach(device_t dev)
-{
-       int rc;
-
-       /* Detach any attached drivers */
-       rc = bus_generic_detach(dev);
-       if (rc == 0) {
-               /* Remove all children */
-               rc = device_delete_children(dev);
-       }
-
-       return (rc);
-}
-
 /**
  * device_probe() method. Look for the right PCI vendor/device IDs.
  *
@@ -318,7 +293,7 @@ imcsmb_pci_request_bus(device_t dev)
 static device_method_t imcsmb_pci_methods[] = {
        /* Device interface */
        DEVMETHOD(device_attach,        imcsmb_pci_attach),
-       DEVMETHOD(device_detach,        imcsmb_pci_detach),
+       DEVMETHOD(device_detach,        bus_generic_detach),
        DEVMETHOD(device_probe,         imcsmb_pci_probe),
 
        DEVMETHOD_END
diff --git a/sys/dev/p2sb/lewisburg_gpiocm.c b/sys/dev/p2sb/lewisburg_gpiocm.c
index 7eeab669d625..f5c1792c69e1 100644
--- a/sys/dev/p2sb/lewisburg_gpiocm.c
+++ b/sys/dev/p2sb/lewisburg_gpiocm.c
@@ -322,23 +322,11 @@ lbggpiocm_attach(device_t dev)
        return (0);
 }
 
-static int
-lbggpiocm_detach(device_t dev)
-{
-       int error;
-
-       error = device_delete_children(dev);
-       if (error)
-               return (error);
-
-       return (bus_generic_detach(dev));
-}
-
 static device_method_t lbggpiocm_methods[] = {
        /* Device interface */
        DEVMETHOD(device_probe,         lbggpiocm_probe),
        DEVMETHOD(device_attach,        lbggpiocm_attach),
-       DEVMETHOD(device_detach,        lbggpiocm_detach),
+       DEVMETHOD(device_detach,        bus_generic_detach),
 
        DEVMETHOD_END
 };
diff --git a/sys/dev/pci/vga_pci.c b/sys/dev/pci/vga_pci.c
index 243c0b53dda4..09166c0cbea6 100644
--- a/sys/dev/pci/vga_pci.c
+++ b/sys/dev/pci/vga_pci.c
@@ -378,17 +378,6 @@ vga_pci_attach(device_t dev)
        return (0);
 }
 
-static int
-vga_pci_detach(device_t dev)
-{
-       int error; 
-
-       error = bus_generic_detach(dev);
-       if (error == 0)
-               error = device_delete_children(dev);
-       return (error);
-}
-
 /* Bus interface. */
 
 static int
@@ -719,7 +708,7 @@ static device_method_t vga_pci_methods[] = {
        DEVMETHOD(device_attach,        vga_pci_attach),
        DEVMETHOD(device_shutdown,      bus_generic_shutdown),
        DEVMETHOD(device_suspend,       bus_generic_suspend),
-       DEVMETHOD(device_detach,        vga_pci_detach),
+       DEVMETHOD(device_detach,        bus_generic_detach),
        DEVMETHOD(device_resume,        bus_generic_resume),
 
        /* Bus interface */
diff --git a/sys/dev/ppbus/ppbconf.c b/sys/dev/ppbus/ppbconf.c
index 17fef1eebde7..2c3f17318747 100644
--- a/sys/dev/ppbus/ppbconf.c
+++ b/sys/dev/ppbus/ppbconf.c
@@ -419,21 +419,6 @@ ppbus_attach(device_t dev)
        return (0);
 }
 
-static int
-ppbus_detach(device_t dev)
-{
-       int error;
-
-       error = bus_generic_detach(dev);
-       if (error)
-               return (error);
-
-       /* detach & delete all children */
-       device_delete_children(dev);
-
-       return (0);
-}
-
 static int
 ppbus_intr(void *arg)
 {
@@ -578,7 +563,7 @@ static device_method_t ppbus_methods[] = {
        /* device interface */
        DEVMETHOD(device_probe,         ppbus_probe),
        DEVMETHOD(device_attach,        ppbus_attach),
-       DEVMETHOD(device_detach,        ppbus_detach),
+       DEVMETHOD(device_detach,        bus_generic_detach),
 
        /* bus interface */
        DEVMETHOD(bus_add_child,        ppbus_add_child),
diff --git a/sys/dev/pwm/pwmbus.c b/sys/dev/pwm/pwmbus.c
index ae40a23d0d45..c0c07a36c277 100644
--- a/sys/dev/pwm/pwmbus.c
+++ b/sys/dev/pwm/pwmbus.c
@@ -188,17 +188,6 @@ pwmbus_attach(device_t dev)
        return (0);
 }
 
-static int
-pwmbus_detach(device_t dev)
-{
-       int rv;
-
-       if ((rv = bus_generic_detach(dev)) == 0)
-               rv = device_delete_children(dev);
-
-       return (rv);
-}
-
 /*
  * pwmbus_if methods...
  */
@@ -249,7 +238,7 @@ static device_method_t pwmbus_methods[] = {
        /* device_if */
        DEVMETHOD(device_probe,  pwmbus_probe),
        DEVMETHOD(device_attach, pwmbus_attach),
-       DEVMETHOD(device_detach, pwmbus_detach),
+       DEVMETHOD(device_detach, bus_generic_detach),
 
         /* bus_if */
        DEVMETHOD(bus_add_child,                pwmbus_add_child),
diff --git a/sys/dev/usb/misc/cp2112.c b/sys/dev/usb/misc/cp2112.c
index 2492eae978bb..e3587241f412 100644
--- a/sys/dev/usb/misc/cp2112.c
+++ b/sys/dev/usb/misc/cp2112.c
@@ -252,7 +252,6 @@ struct cp2112iic_softc {
        }               io;
 };
 
-static int cp2112_detach(device_t dev);
 static int cp2112gpio_detach(device_t dev);
 static int cp2112iic_detach(device_t dev);
 
@@ -351,22 +350,10 @@ cp2112_attach(device_t dev)
        return (0);
 
 detach:
-       cp2112_detach(dev);
+       bus_generic_detach(dev);
        return (ENXIO);
 }
 
-static int
-cp2112_detach(device_t dev)
-{
-       int err;
-
-       err = bus_generic_detach(dev);
-       if (err != 0)
-               return (err);
-       device_delete_children(dev);
-       return (0);
-}
-
 static int
 cp2112_gpio_read_pin(device_t dev, uint32_t pin_num, bool *on)
 {
@@ -1374,7 +1361,7 @@ cp2112iic_detach(device_t dev)
 static device_method_t cp2112hid_methods[] = {
        DEVMETHOD(device_probe,         cp2112_probe),
        DEVMETHOD(device_attach,        cp2112_attach),
-       DEVMETHOD(device_detach,        cp2112_detach),
+       DEVMETHOD(device_detach,        bus_generic_detach),
 
        DEVMETHOD_END
 };

Reply via email to