Module Name: src Committed By: tsutsui Date: Tue Sep 8 18:15:17 UTC 2009
Modified Files: src/sys/dev/sbus: esp_sbus.c if_hme_sbus.c if_le.c if_le_lebuffer.c if_le_ledma.c Log Message: 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()??? To generate a diff of this commit: cvs rdiff -u -r1.48 -r1.49 src/sys/dev/sbus/esp_sbus.c cvs rdiff -u -r1.31 -r1.32 src/sys/dev/sbus/if_hme_sbus.c \ src/sys/dev/sbus/if_le_ledma.c cvs rdiff -u -r1.36 -r1.37 src/sys/dev/sbus/if_le.c cvs rdiff -u -r1.24 -r1.25 src/sys/dev/sbus/if_le_lebuffer.c Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/sys/dev/sbus/esp_sbus.c diff -u src/sys/dev/sbus/esp_sbus.c:1.48 src/sys/dev/sbus/esp_sbus.c:1.49 --- src/sys/dev/sbus/esp_sbus.c:1.48 Tue May 12 14:43:59 2009 +++ src/sys/dev/sbus/esp_sbus.c Tue Sep 8 18:15:17 2009 @@ -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> Index: src/sys/dev/sbus/if_hme_sbus.c diff -u src/sys/dev/sbus/if_hme_sbus.c:1.31 src/sys/dev/sbus/if_hme_sbus.c:1.32 --- src/sys/dev/sbus/if_hme_sbus.c:1.31 Sun May 17 01:33:24 2009 +++ src/sys/dev/sbus/if_hme_sbus.c Tue Sep 8 18:15:17 2009 @@ -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); +} Index: src/sys/dev/sbus/if_le_ledma.c diff -u src/sys/dev/sbus/if_le_ledma.c:1.31 src/sys/dev/sbus/if_le_ledma.c:1.32 --- src/sys/dev/sbus/if_le_ledma.c:1.31 Sun Apr 12 11:10:28 2009 +++ src/sys/dev/sbus/if_le_ledma.c Tue Sep 8 18:15:17 2009 @@ -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); +} Index: src/sys/dev/sbus/if_le.c diff -u src/sys/dev/sbus/if_le.c:1.36 src/sys/dev/sbus/if_le.c:1.37 --- src/sys/dev/sbus/if_le.c:1.36 Mon Apr 28 20:23:57 2008 +++ src/sys/dev/sbus/if_le.c Tue Sep 8 18:15:17 2009 @@ -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); +} Index: src/sys/dev/sbus/if_le_lebuffer.c diff -u src/sys/dev/sbus/if_le_lebuffer.c:1.24 src/sys/dev/sbus/if_le_lebuffer.c:1.25 --- src/sys/dev/sbus/if_le_lebuffer.c:1.24 Mon Apr 28 20:23:57 2008 +++ src/sys/dev/sbus/if_le_lebuffer.c Tue Sep 8 18:15:17 2009 @@ -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); +}