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