Source-Changes-HG archive

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

[src/trunk]: src/sys/dev/sbus Fix botch on device_t/softc split caused by awf...



details:   https://anonhg.NetBSD.org/src/rev/2b056c00b814
branches:  trunk
changeset: 747287:2b056c00b814
user:      tsutsui <tsutsui%NetBSD.org@localhost>
date:      Tue Sep 08 18:15:17 2009 +0000

description:
Fix botch on device_t/softc split caused by awful casts around
registration of (*sd_reset)(device_t) in struct sbusdev via sbus_establish().

XXX: (*sd_reset)() in struct sbusdev seems called from only sbusreset(),
XXX: but there is no function which calls sbusreset()???

diffstat:

 sys/dev/sbus/esp_sbus.c       |  21 ++++++++++++++++-----
 sys/dev/sbus/if_hme_sbus.c    |  17 ++++++++++++++---
 sys/dev/sbus/if_le.c          |  17 ++++++++++++++---
 sys/dev/sbus/if_le_lebuffer.c |  17 ++++++++++++++---
 sys/dev/sbus/if_le_ledma.c    |  17 ++++++++++++++---
 5 files changed, 72 insertions(+), 17 deletions(-)

diffs (266 lines):

diff -r 31defeb2b3d6 -r 2b056c00b814 sys/dev/sbus/esp_sbus.c
--- a/sys/dev/sbus/esp_sbus.c   Tue Sep 08 18:01:34 2009 +0000
+++ b/sys/dev/sbus/esp_sbus.c   Tue Sep 08 18:15:17 2009 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: esp_sbus.c,v 1.48 2009/05/12 14:43:59 cegger Exp $     */
+/*     $NetBSD: esp_sbus.c,v 1.49 2009/09/08 18:15:17 tsutsui Exp $    */
 
 /*-
  * Copyright (c) 1997, 1998 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: esp_sbus.c,v 1.48 2009/05/12 14:43:59 cegger Exp $");
+__KERNEL_RCSID(0, "$NetBSD: esp_sbus.c,v 1.49 2009/09/08 18:15:17 tsutsui Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -101,6 +101,8 @@
 static void    esp_dma_stop(struct ncr53c9x_softc *);
 static int     esp_dma_isactive(struct ncr53c9x_softc *);
 
+static void    esp_sbus_reset(device_t);
+
 #ifdef DDB
 static void    esp_init_ddb_cmds(void);
 #endif
@@ -287,7 +289,7 @@
                esc->sc_pri = sa->sa_pri;
 
                /* add me to the sbus structures */
-               esc->sc_sd.sd_reset = (void *)ncr53c9x_reset;
+               esc->sc_sd.sd_reset = esp_sbus_reset;
                sbus_establish(&esc->sc_sd, self);
 
                espattach(esc, &esp_sbus_glue);
@@ -347,7 +349,7 @@
        esc->sc_pri = sa->sa_pri;
 
        /* add me to the sbus structures */
-       esc->sc_sd.sd_reset = (void *)ncr53c9x_reset;
+       esc->sc_sd.sd_reset = esp_sbus_reset;
        sbus_establish(&esc->sc_sd, self);
 
        if (strcmp("ptscII", sa->sa_name) == 0) {
@@ -407,7 +409,7 @@
        esc->sc_pri = sa->sa_pri;
 
        /* Assume SBus is grandparent */
-       esc->sc_sd.sd_reset = (void *)ncr53c9x_reset;
+       esc->sc_sd.sd_reset = esp_sbus_reset;
        sbus_establish(&esc->sc_sd, parent);
 
        espattach(esc, &esp_sbus_glue);
@@ -700,6 +702,15 @@
        return DMA_ISACTIVE(esc->sc_dma);
 }
 
+void
+esp_sbus_reset(device_t self)
+{
+       struct esp_softc *esc = device_private(self);
+       struct ncr53c9x_softc *sc = &esc->sc_ncr53c9x;
+
+       ncr53c9x_reset(sc);
+}
+
 #ifdef DDB
 #include <machine/db_machdep.h>
 #include <ddb/db_output.h>
diff -r 31defeb2b3d6 -r 2b056c00b814 sys/dev/sbus/if_hme_sbus.c
--- a/sys/dev/sbus/if_hme_sbus.c        Tue Sep 08 18:01:34 2009 +0000
+++ b/sys/dev/sbus/if_hme_sbus.c        Tue Sep 08 18:15:17 2009 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_hme_sbus.c,v 1.31 2009/05/17 01:33:24 tsutsui Exp $ */
+/*     $NetBSD: if_hme_sbus.c,v 1.32 2009/09/08 18:15:17 tsutsui Exp $ */
 
 /*-
  * Copyright (c) 1999 The NetBSD Foundation, Inc.
@@ -34,7 +34,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_hme_sbus.c,v 1.31 2009/05/17 01:33:24 tsutsui Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_hme_sbus.c,v 1.32 2009/09/08 18:15:17 tsutsui Exp $");
 
 #include <sys/param.h>
 #include <sys/systm.h>
@@ -66,6 +66,8 @@
 int    hmematch_sbus(device_t, cfdata_t, void *);
 void   hmeattach_sbus(device_t, device_t, void *);
 
+static void hme_sbus_reset(device_t);
+
 CFATTACH_DECL_NEW(hme_sbus, sizeof(struct hmesbus_softc),
     hmematch_sbus, hmeattach_sbus, NULL, NULL);
 
@@ -157,7 +159,7 @@
                return;
        }
 
-       sd->sd_reset = (void *)hme_reset;
+       sd->sd_reset = hme_sbus_reset;
        sbus_establish(sd, self);
 
        prom_getether(node, sc->sc_enaddr);
@@ -190,3 +192,12 @@
                (void)bus_intr_establish(sa->sa_bustag, sa->sa_pri, IPL_NET,
                                         hme_intr, sc);
 }
+
+void
+hme_sbus_reset(device_t self)
+{
+       struct hmesbus_softc *hsc = device_private(self);
+       struct hme_softc *sc = &hsc->hsc_hme;
+
+       hme_reset(sc);
+}
diff -r 31defeb2b3d6 -r 2b056c00b814 sys/dev/sbus/if_le.c
--- a/sys/dev/sbus/if_le.c      Tue Sep 08 18:01:34 2009 +0000
+++ b/sys/dev/sbus/if_le.c      Tue Sep 08 18:15:17 2009 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_le.c,v 1.36 2008/04/28 20:23:57 martin Exp $        */
+/*     $NetBSD: if_le.c,v 1.37 2009/09/08 18:15:17 tsutsui Exp $       */
 
 /*-
  * Copyright (c) 1997, 1998 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_le.c,v 1.36 2008/04/28 20:23:57 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_le.c,v 1.37 2009/09/08 18:15:17 tsutsui Exp $");
 
 #include "opt_inet.h"
 #include "bpfilter.h"
@@ -82,6 +82,8 @@
 int    lematch_sbus(device_t, cfdata_t, void *);
 void   leattach_sbus(device_t, device_t, void *);
 
+static void le_sbus_reset(device_t);
+
 /*
  * Media types supported.
  */
@@ -191,7 +193,7 @@
                break;
        }
 
-       lesc->sc_sd.sd_reset = (void *)lance_reset;
+       lesc->sc_sd.sd_reset = le_sbus_reset;
        sbus_establish(&lesc->sc_sd, self);
 
        if (sc->sc_mem == 0) {
@@ -264,3 +266,12 @@
                (void)bus_intr_establish(lesc->sc_bustag, sa->sa_pri,
                                         IPL_NET, am7990_intr, sc);
 }
+
+void
+le_sbus_reset(device_t self)
+{
+       struct le_softc *lesc = device_private(self);
+       struct lance_softc *sc = &lesc->sc_am7990.lsc;
+
+       lance_reset(sc);
+}
diff -r 31defeb2b3d6 -r 2b056c00b814 sys/dev/sbus/if_le_lebuffer.c
--- a/sys/dev/sbus/if_le_lebuffer.c     Tue Sep 08 18:01:34 2009 +0000
+++ b/sys/dev/sbus/if_le_lebuffer.c     Tue Sep 08 18:15:17 2009 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_le_lebuffer.c,v 1.24 2008/04/28 20:23:57 martin Exp $       */
+/*     $NetBSD: if_le_lebuffer.c,v 1.25 2009/09/08 18:15:17 tsutsui Exp $      */
 
 /*-
  * Copyright (c) 1997, 1998 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_le_lebuffer.c,v 1.24 2008/04/28 20:23:57 martin Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_le_lebuffer.c,v 1.25 2009/09/08 18:15:17 tsutsui Exp $");
 
 #include "opt_inet.h"
 #include "bpfilter.h"
@@ -85,6 +85,8 @@
 int    lematch_lebuffer(device_t, cfdata_t, void *);
 void   leattach_lebuffer(device_t, device_t, void *);
 
+static void le_lebuffer_reset(device_t);
+
 /*
  * Media types supported.
  */
@@ -174,7 +176,7 @@
                                  LE_C3_BSWP | LE_C3_ACON | LE_C3_BCON);
 
        /* Assume SBus is grandparent */
-       lesc->sc_sd.sd_reset = (void *)lance_reset;
+       lesc->sc_sd.sd_reset = le_lebuffer_reset;
        sbus_establish(&lesc->sc_sd, parent);
 
        sc->sc_supmedia = lemedia;
@@ -199,3 +201,12 @@
                (void)bus_intr_establish(lesc->sc_bustag, sa->sa_pri,
                                         IPL_NET, am7990_intr, sc);
 }
+
+void
+le_lebuffer_reset(device_t self)
+{
+       struct le_softc *lesc = device_private(self);
+       struct lance_softc *sc = &lesc->sc_am7990.lsc;
+
+       lance_reset(sc);
+}
diff -r 31defeb2b3d6 -r 2b056c00b814 sys/dev/sbus/if_le_ledma.c
--- a/sys/dev/sbus/if_le_ledma.c        Tue Sep 08 18:01:34 2009 +0000
+++ b/sys/dev/sbus/if_le_ledma.c        Tue Sep 08 18:15:17 2009 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: if_le_ledma.c,v 1.31 2009/04/12 11:10:28 tsutsui Exp $ */
+/*     $NetBSD: if_le_ledma.c,v 1.32 2009/09/08 18:15:17 tsutsui Exp $ */
 
 /*-
  * Copyright (c) 1997, 1998 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
  */
 
 #include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_le_ledma.c,v 1.31 2009/04/12 11:10:28 tsutsui Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_le_ledma.c,v 1.32 2009/09/08 18:15:17 tsutsui Exp $");
 
 #include "opt_inet.h"
 #include "bpfilter.h"
@@ -93,6 +93,8 @@
 int    lematch_ledma(device_t, cfdata_t, void *);
 void   leattach_ledma(device_t, device_t, void *);
 
+static void le_ledma_reset(device_t);
+
 /*
  * Media types supported by the Sun4m.
  */
@@ -390,7 +392,7 @@
        lesc->sc_lostcount = 0;
 
        /* Assume SBus is grandparent */
-       lesc->sc_sd.sd_reset = (void *)lance_reset;
+       lesc->sc_sd.sd_reset = le_ledma_reset;
        sbus_establish(&lesc->sc_sd, parent);
 
        sc->sc_mediachange = lemediachange;
@@ -423,3 +425,12 @@
        /* now initialize DMA */
        lehwreset(sc);
 }
+
+void
+le_ledma_reset(device_t self)
+{
+       struct le_softc *lesc = device_private(self);
+       struct lance_softc *sc = &lesc->sc_am7990.lsc;
+
+       lance_reset(sc);
+}



Home | Main Index | Thread Index | Old Index