summaryrefslogtreecommitdiff
path: root/sys/arch/vax/if/if_le.c
diff options
context:
space:
mode:
Diffstat (limited to 'sys/arch/vax/if/if_le.c')
-rw-r--r--sys/arch/vax/if/if_le.c44
1 files changed, 30 insertions, 14 deletions
diff --git a/sys/arch/vax/if/if_le.c b/sys/arch/vax/if/if_le.c
index 67ab2fec5e4..2982f30160b 100644
--- a/sys/arch/vax/if/if_le.c
+++ b/sys/arch/vax/if/if_le.c
@@ -1,7 +1,6 @@
-/* $OpenBSD: if_le.c,v 1.2 1997/05/29 00:04:32 niklas Exp $ */
-/* $NetBSD: if_le.c,v 1.3 1996/10/13 03:34:53 christos Exp $ */
+/* $OpenBSD: if_le.c,v 1.3 1997/09/10 08:28:40 maja Exp $ */
+/* $NetBSD: if_le.c,v 1.8 1997/04/21 22:04:23 ragge Exp $ */
-#define LEDEBUG 1 /* debug-level: 0 or 1 */
/* #define LE_CHIP_IS_POKEY /* does VS2000 need this ??? */
/*-
@@ -49,6 +48,7 @@
#include <sys/syslog.h>
#include <sys/socket.h>
#include <sys/device.h>
+#include <sys/reboot.h>
#include <net/if.h>
@@ -69,6 +69,7 @@
#include <machine/uvax.h>
#include <machine/ka410.h>
#include <machine/vsbus.h>
+#include <machine/rpb.h>
#include <dev/ic/am7990reg.h>
#define LE_NEED_BUF_CONTIG
@@ -104,12 +105,15 @@ struct cfattach le_ca = {
sizeof(struct le_softc), lematch, leattach
};
-integrate void
+hide void lewrcsr __P ((struct am7990_softc *, u_int16_t, u_int16_t));
+hide u_int16_t lerdcsr __P ((struct am7990_softc *, u_int16_t));
+
+hide void
lewrcsr(sc, port, val)
- struct le_softc *sc;
+ struct am7990_softc *sc;
u_int16_t port, val;
{
- struct lereg1 *ler1 = sc->sc_r1;
+ struct lereg1 *ler1 = ((struct le_softc *)sc)->sc_r1;
#ifdef LE_CHIP_IS_POKEY
LEWREG(port, ler1->ler1_rap);
@@ -120,12 +124,12 @@ lewrcsr(sc, port, val)
#endif
}
-integrate u_int16_t
+hide u_int16_t
lerdcsr(sc, port)
- struct le_softc *sc;
+ struct am7990_softc *sc;
u_int16_t port;
{
- struct lereg1 *ler1 = sc->sc_r1;
+ struct lereg1 *ler1 = ((struct le_softc *)sc)->sc_r1;
u_int16_t val;
#ifdef LE_CHIP_IS_POKEY
@@ -138,6 +142,12 @@ lerdcsr(sc, port)
return (val);
}
+integrate void
+lehwinit(sc)
+ struct am7990_softc *sc;
+{
+}
+
int
lematch(parent, match, aux)
struct device *parent;
@@ -176,6 +186,10 @@ leattach(parent, self, aux)
sc->sc_am7990.sc_mem = le_iomem;
sc->sc_am7990.sc_addr = le_ioaddr;
sc->sc_am7990.sc_memsize = LE_IOSIZE;
+ sc->sc_am7990.sc_wrcsr = lewrcsr;
+ sc->sc_am7990.sc_rdcsr = lerdcsr;
+ sc->sc_am7990.sc_hwinit = lehwinit;
+ sc->sc_am7990.sc_nocarrier = NULL;
xdebug(("leattach: mem=%x, addr=%x, size=%x (%d)\n",
sc->sc_am7990.sc_mem, sc->sc_am7990.sc_addr,
@@ -204,12 +218,14 @@ leattach(parent, self, aux)
vsbus_intr_register(ca, am7990_intr, &sc->sc_am7990);
vsbus_intr_enable(ca);
-}
-integrate void
-lehwinit(sc)
- struct le_softc *sc;
-{
+ /*
+ * Register this device as boot device if we booted from it.
+ * This will fail if there are more than one le in a machine,
+ * fortunately there may be only one.
+ */
+ if (B_TYPE(bootdev) == BDEV_LE)
+ booted_from = self;
}
#ifdef LE_CHIP_IS_POKEY