summaryrefslogtreecommitdiff
path: root/sys/dev/ic
diff options
context:
space:
mode:
Diffstat (limited to 'sys/dev/ic')
-rw-r--r--sys/dev/ic/rl2reg.h250
-rw-r--r--sys/dev/ic/rl2var.h141
-rw-r--r--sys/dev/ic/rln.c (renamed from sys/dev/ic/rl2.c)494
-rw-r--r--sys/dev/ic/rln.h (renamed from sys/dev/ic/rl2.h)26
-rw-r--r--sys/dev/ic/rlncmd.h (renamed from sys/dev/ic/rl2cmd.h)170
-rw-r--r--sys/dev/ic/rlnreg.h250
-rw-r--r--sys/dev/ic/rlnsubr.c (renamed from sys/dev/ic/rl2subr.c)473
-rw-r--r--sys/dev/ic/rlnvar.h141
8 files changed, 978 insertions, 967 deletions
diff --git a/sys/dev/ic/rl2reg.h b/sys/dev/ic/rl2reg.h
deleted file mode 100644
index e311609e69e..00000000000
--- a/sys/dev/ic/rl2reg.h
+++ /dev/null
@@ -1,250 +0,0 @@
-/* $OpenBSD: rl2reg.h,v 1.2 1999/07/14 03:52:55 d Exp $ */
-/*
- * David Leonard <d@openbsd.org>, 1999. Public Domain.
- *
- * RangeLAN2 registers
- */
-
-/*
- * The RangeLAN2 cards provide four control registers for transferring
- * messaged between the host and the card using programmed i/o.
- *
- * A transfer protocol is followed when sending asynchronous messages to,
- * and receiving messages from, the card.
- *
- * DATA
- * 7 6 5 4 3 2 1 0
- * +-------+-------+-------+-------+-------+-------+-------+-------+
- * | data |
- * +-------+-------+-------+-------+-------+-------+-------+-------+
- *
- * STATUS
- * 7 6 5 4 3 2 1 0
- * +-------+-------+-------+-------+-------+-------+-------+-------+
- * |WAKEUP | tx message state |CLRNAK | rx message state |
- * +-------+-------+-------+-------+-------+-------+-------+-------+
- *
- * CONTROL
- * 7 6 5 4 3 2 1 0
- * +-------+-------+-------+-------+-------+-------+-------+-------+
- * | | | 16BIT | RESET | | | TXINT | RXINT |
- * +-------+-------+-------+-------+-------+-------+-------+-------+
- *
- * INTSEL
- * 7 6 5 4 3 2 1 0
- * +-------+-------+-------+-------+-------+-------+-------+-------+
- * | | | |ENABLE | interrupt line |
- * +-------+-------+-------+-------+-------+-------+-------+-------+
- */
-
-/* Register offsets. */
-#define RL2_REG_DATA 0
-#define RL2_REG_STATUS 2
-#define RL2_REG_CONTROL 4
-#define RL2_REG_EOI 5
-#define RL2_REG_INTSEL 6
-#define RL2_NPORTS 8
-
-/*
- * A short delay is needed (16ms?) after register writes on some cards.
- * XXX This is done by performing an innocent and harmless bus read. (i386)
- * This is what Proxim's driver does, anyway.
- */
-#define _rl2_regacc_delay() \
- bus_space_read_1(I386_BUS_SPACE_IO, 0, 0x61)
-
-static void _rl2_register_write_1 __P((struct rl2_softc *, u_int8_t,
- u_int8_t));
-static u_int8_t _rl2_register_read_1 __P((struct rl2_softc *, u_int8_t));
-static int rl2_status_rx_ready __P((struct rl2_softc *));
-
-/* Write to a register. */
-static inline void
-_rl2_register_write_1(sc, regoff, value)
- struct rl2_softc *sc;
- u_int8_t regoff;
- u_int8_t value;
-{
-
-#ifdef RL2DEBUG_REG
- printf(" %c<%02x", "DDS3CEI7"[regoff], value);
-#endif
- bus_space_write_1((sc)->sc_iot, (sc)->sc_ioh, (regoff), (value));
- _rl2_regacc_delay();
-}
-
-/* Read from a register. */
-static inline u_int8_t
-_rl2_register_read_1(sc, regoff)
- struct rl2_softc *sc;
- u_int8_t regoff;
-{
- u_int8_t ret;
-
- ret = bus_space_read_1((sc)->sc_iot, (sc)->sc_ioh, (regoff));
-#ifdef RL2DEBUG_REG
- if (ret != (sc)->dbg_oreg[regoff]) {
- /* avoid spewing out too much debug info */
- printf(" %c>%02x", "DDS3CEI7"[regoff], ret);
- (sc)->dbg_oreg[regoff] = ret;
- }
-#endif
- return (ret);
-}
-
-/* 8-bit data register access. */
-#define rl2_data_write_1(sc, value) \
- _rl2_register_write_1(sc, RL2_REG_DATA, (value))
-#define rl2_data_read_1(sc) \
- _rl2_register_read_1(sc, RL2_REG_DATA)
-#define rl2_data_write_multi_1(sc, buf, len) \
- bus_space_write_multi_1((sc)->sc_iot, (sc)->sc_ioh, \
- RL2_REG_DATA, (buf), (len))
-#define rl2_data_read_multi_1(sc, buf, len) \
- bus_space_read_multi_1((sc)->sc_iot, (sc)->sc_ioh, \
- RL2_REG_DATA, (buf), (len))
-
-/* 16-bit data register access. */
-#define rl2_data_write_2(sc, value) \
- bus_space_write_2((sc)->sc_iot, (sc)->sc_ioh, \
- RL2_REG_DATA, (value))
-#define rl2_data_read_2(sc) \
- bus_space_read_2((sc)->sc_iot, (sc)->sc_ioh, \
- RL2_REG_DATA)
-#define rl2_data_write_multi_2(sc, buf, len) \
- bus_space_write_multi_2((sc)->sc_iot, (sc)->sc_ioh, \
- RL2_REG_DATA, (buf), (len))
-#define rl2_data_read_multi_2(sc, buf, len) \
- bus_space_read_multi_2((sc)->sc_iot, (sc)->sc_ioh, \
- RL2_REG_DATA, (buf), (len))
-
-/* Status register. */
-#define RL2_STATUS_CLRNAK 0x08
-#define RL2_STATUS_WAKEUP 0x80
-
-#define RL2_STATUS_TX_IDLE 0x00
-#define RL2_STATUS_TX_HILEN_AVAIL 0x01
-#define RL2_STATUS_TX_HILEN_ACCEPT 0x02
-#define RL2_STATUS_TX_XFR_COMPLETE 0x03
-#define RL2_STATUS_TX_XFR 0x04
-#define RL2_STATUS_TX_ERROR 0x05
-#define RL2_STATUS_TX_LOLEN_AVAIL 0x06
-#define RL2_STATUS_TX_LOLEN_ACCEPT 0x07
-#define RL2_STATUS_TX_MASK 0x0f
-
-#define RL2_STATUS_RX_IDLE 0x00
-#define RL2_STATUS_RX_HILEN_AVAIL 0x10
-#define RL2_STATUS_RX_HILEN_ACCEPT 0x20
-#define RL2_STATUS_RX_XFR_COMPLETE 0x30
-#define RL2_STATUS_RX_XFR 0x40
-#define RL2_STATUS_RX_ERROR 0x50
-#define RL2_STATUS_RX_LOLEN_AVAIL 0x60
-#define RL2_STATUS_RX_LOLEN_ACCEPT 0x70
-#define RL2_STATUS_RX_MASK 0x70
-
-#define rl2_status_write(sc, value) \
- _rl2_register_write_1(sc, RL2_REG_STATUS, (value))
-#define rl2_status_set(sc, bits) \
- rl2_status_write(sc, (sc)->sc_status |= (bits))
-#define rl2_status_clear(sc, bits) \
- rl2_status_write(sc, (sc)->sc_status &= ~(bits))
-#define _rl2_status_setmask(sc, mask, bits) \
-do { \
- int _s; \
- \
- _s = splhigh(); \
- (sc)->sc_status = ((sc)->sc_status & (mask)) | (bits); \
- rl2_status_write(sc, (sc)->sc_status); \
- splx(_s); \
-} while (0);
-#define rl2_status_rx_write(sc, state) \
- _rl2_status_setmask((sc), ~RL2_STATUS_RX_MASK, state)
-#define rl2_status_tx_write(sc, state) \
- _rl2_status_setmask((sc), ~RL2_STATUS_TX_MASK, state)
-#define rl2_status_read(sc) \
- _rl2_register_read_1(sc, RL2_REG_STATUS)
-#define rl2_status_rx_read(sc) \
- (rl2_status_read(sc) & ~RL2_STATUS_TX_MASK)
-#define rl2_status_tx_read(sc) \
- (rl2_status_read(sc) & ~RL2_STATUS_RX_MASK)
-
-static inline int
-rl2_status_rx_ready(sc)
- struct rl2_softc *sc;
-{
- u_int8_t status;
-
- status = rl2_status_rx_read(sc);
- return (status == RL2_STATUS_RX_LOLEN_AVAIL ||
- status == RL2_STATUS_RX_HILEN_AVAIL ||
- status == RL2_STATUS_RX_ERROR);
-}
-
-#define rl2_status_tx_int(sc) do { \
- int _s = splhigh(); \
- \
- rl2_control_clear(sc, RL2_CONTROL_TXINT); \
- rl2_control_set(sc, RL2_CONTROL_TXINT); \
- splx(_s); \
-} while (0)
-#define rl2_status_rx_int(sc) do { \
- int _s = splhigh(); \
- \
- rl2_control_clear(sc, RL2_CONTROL_RXINT); \
- rl2_control_set(sc, RL2_CONTROL_RXINT); \
- splx(_s); \
-} while (0)
-
-/* Control register. */
-#define RL2_CONTROL_RXINT 0x01
-#define RL2_CONTROL_TXINT 0x02
-#define RL2_CONTROL_BIT2 0x04
-#define RL2_CONTROL_BIT3 0x08
-#define RL2_CONTROL_RESET 0x10
-#define RL2_CONTROL_16BIT 0x20
-#define RL2_CONTROL_MASK 0x3f
-
-#define rl2_control_write(sc, value) \
- _rl2_register_write_1(sc, RL2_REG_CONTROL, \
- (sc)->sc_control = (value))
-#define rl2_control_read(sc) \
- _rl2_register_read_1(sc, RL2_REG_CONTROL)
-#define rl2_control_set(sc, bits) \
- rl2_control_write(sc, (sc)->sc_control | (bits))
-#define rl2_control_clear(sc, bits) \
- rl2_control_write(sc, (sc)->sc_control & ~(bits))
-#define rl2_control_outofstandby(sc) do { \
- rl2_control_write(sc, (sc)->sc_control | RL2_CONTROL_RESET);\
- DELAY(30000); \
- rl2_control_write(sc, (sc)->sc_control); \
-} while (0)
-
-/* Interrupt selection register. */
-#define RL2_INTSEL_IRQMASK 0x07
-#define RL2_INTSEL_ENABLE 0x10
-#define RL2_INTSEL_BIT7 0x80
-
-#define rl2_intsel_disable(sc) do { \
- int _s; \
- \
- _s = splhigh(); \
- _rl2_register_write_1(sc, RL2_REG_INTSEL, \
- (sc)->sc_intsel &= ~RL2_INTSEL_ENABLE); \
- splx(_s); \
-} while (0)
-#define rl2_intsel_enable(sc) do { \
- int _s; \
- \
- _s = splhigh(); \
- _rl2_register_write_1(sc, RL2_REG_INTSEL, \
- (sc)->sc_intsel |= RL2_INTSEL_ENABLE); \
- splx(_s); \
-} while (0)
-#define rl2_intsel_write(sc, value) \
- _rl2_register_write_1(sc, RL2_REG_INTSEL, \
- (sc)->sc_intsel |= (value))
-
-/* End of interrupt signal, used on some newer cards. */
-#define rl2_eoi(sc) \
- (void) _rl2_register_read_1(sc, RL2_REG_EOI)
-
diff --git a/sys/dev/ic/rl2var.h b/sys/dev/ic/rl2var.h
deleted file mode 100644
index be369148f92..00000000000
--- a/sys/dev/ic/rl2var.h
+++ /dev/null
@@ -1,141 +0,0 @@
-/* $OpenBSD: rl2var.h,v 1.3 1999/07/14 03:54:38 d Exp $ */
-/*
- * David Leonard <d@openbsd.org>, 1999. Public domain.
- *
- * Proxim RangeLAN2 soft state copy.
- */
-
-/*
- * Mailboxes are used to communicate card-initiated messages
- * from the interrupt handler to other kernel threads.
- */
-struct rl2_mbox {
- void * mb_buf; /* Message buffer */
- size_t mb_len; /* Message buffer size */
- size_t mb_actlen; /* Actual message size */
- u_int8_t mb_state; /* Mailbox state */
-#define RL2MBOX_VOID 0
-#define RL2MBOX_EMPTY 1
-#define RL2MBOX_FILLING 2
-#define RL2MBOX_FILLED 3
-};
-
-#define RL2_NMBOX 0x7c /* Same as max msg seq number */
-
-/* Soft state */
-struct rl2_softc {
- struct device sc_dev;
- void *sc_ih; /* Interrupt handler */
- struct arpcom sc_arpcom; /* Ethernet common part */
- bus_space_tag_t sc_iot; /* Bus cookie */
- bus_space_handle_t sc_ioh; /* Bus i/o handle */
-
- u_int8_t sc_width; /* Bus transfer width */
- u_int8_t sc_irq; /* IRQ for card */
-
- u_int16_t sc_cardtype; /* Set from config flags */
-#define RL2_CTYPE_OEM 0x01
-#define RL2_CTYPE_UISA 0x02
-#define RL2_CTYPE_ONE_PIECE 0x04
-
- u_int8_t sc_intsel; /* Copy of INTSEL */
- u_int8_t sc_status; /* Copy of STATUS */
- u_int8_t sc_control; /* Copy of CONTROL */
-#ifdef RL2DEBUG_REG
- u_int8_t dbg_oreg[8]; /* Last reg value written */
-#endif
-
- u_int8_t sc_pktseq; /* Card message seq no */
- u_int8_t sc_txseq; /* Tx packet seq no */
-
- u_int16_t sc_state; /* Soft state. */
-#define RL2_STATE_SYNC 0x0001 /* Card is synchronised */
-#define RL2_STATE_NEEDINIT 0x0002 /* Card needs reset+init */
-#define RL2_STATE_PROMISC 0x0004 /* Receive all packets */
-
- struct rl2_mbox sc_mbox[0x80]; /* Per-message mailboxes */
- struct rl2_param sc_param; /* User controlled parameters */
-};
-
-#define rl2_need_reset(sc) \
- (sc)->sc_state |= RL2_STATE_NEEDINIT
-
-/* Structure used to hold partial read state for rl2_rx_pdata() */
-struct rl2_pdata {
- u_int8_t p_data; /* extra data read but not consumed */
- int p_nremain; /* size of unconsumed data */
-};
-#define RL2_PDATA_INIT {0,0}
-
-/* Structure used to hold partial transmit state for rl2_msg_tx_*() */
-struct rl2_msg_tx_state {
- int ien; /* saved interrupt state */
- u_int8_t w; /* saved wakup state */
- struct rl2_pdata pd; /* saved partial write state */
-};
-
-struct rl2_mm_cmd; /* fwd decl */
-
-#define RL2_WAKEUP_SET 0xff
-#define RL2_WAKEUP_NOCHANGE (0x80|0x10)
-
-void rl2config __P((struct rl2_softc *));
-int rl2intr __P((void *));
-void rl2read __P((struct rl2_softc *, struct rl2_mm_cmd *, int));
-int rl2_enable __P((struct rl2_softc *, int));
-int rl2_reset __P((struct rl2_softc *));
-u_int8_t rl2_wakeup __P((struct rl2_softc *, u_int8_t));
-int rl2_rx_request __P((struct rl2_softc *, int));
-int rl2_rx_data __P((struct rl2_softc *, void *, int));
-void rl2_rx_pdata __P((struct rl2_softc *, void *, int,
- struct rl2_pdata *));
-void rl2_rx_end __P((struct rl2_softc *));
-void rl2_clear_nak __P((struct rl2_softc *));
-u_int8_t rl2_newseq __P((struct rl2_softc *));
-
-void rl2_msg_tx_data __P((struct rl2_softc *, void *, u_int16_t,
- struct rl2_msg_tx_state *));
-int rl2_msg_tx_start __P((struct rl2_softc *, void *, int,
- struct rl2_msg_tx_state *));
-int rl2_msg_tx_end __P((struct rl2_softc *,
- struct rl2_msg_tx_state *));
-int rl2_msg_txrx __P((struct rl2_softc *, void *, int,
- void *, int));
-
-int rl2_mbox_create __P((struct rl2_softc *, u_int8_t, void *,
- size_t));
-int rl2_mbox_wait __P((struct rl2_softc *, u_int8_t, int));
-int rl2_mbox_lock __P((struct rl2_softc *, u_int8_t, void **,
- size_t*));
-void rl2_mbox_unlock __P((struct rl2_softc *, u_int8_t, size_t));
-
-/* debug all card operations */
-#ifdef RL2DEBUG
-#define dprintf(fmt, args...) printf(fmt , ## args)
- /* log(LOG_DEBUG, fmt , ## args) */
-#define dprinthex(buf, len) do { \
- unsigned char *_b = (unsigned char*)(buf); \
- int _i, _l=(len); \
- printf("{"); \
- for(_i = 0; _i < _l; _i++) { \
- printf("%02x", _b[_i]); \
- if (_i % 4 == 3 && _i != _l - 1) \
- printf(","); \
- } \
- printf("}"); \
-} while (0)
-#else
-#define dprintf(fmt, args...) /* nothing */
-#define dprinthex(buf, len) /* nothing */
-#endif
-
-/* debug messages to/from card. prints 4-octet groups separated by commas */
-#define RL2DUMP
-#define RL2DUMPHEX(buf, buflen) do { \
- int _i; \
- for (_i = 0; _i < (buflen); _i++) { \
- printf("%02x", ((unsigned char *)(buf))[_i]); \
- if (_i != (buflen) - 1 && _i % 4 == 3) \
- printf(","); \
- } \
-} while (0)
diff --git a/sys/dev/ic/rl2.c b/sys/dev/ic/rln.c
index f8fbaafcc95..1c2b2e5ffbb 100644
--- a/sys/dev/ic/rl2.c
+++ b/sys/dev/ic/rln.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rl2.c,v 1.3 1999/07/14 03:51:08 d Exp $ */
+/* $OpenBSD: rln.c,v 1.1 1999/07/30 13:43:36 d Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public Domain.
*
@@ -38,51 +38,51 @@
#include <machine/bus.h>
#include <machine/intr.h>
-#include <dev/ic/rl2.h>
-#include <dev/ic/rl2var.h>
-#include <dev/ic/rl2reg.h>
-#include <dev/ic/rl2cmd.h>
+#include <dev/ic/rln.h>
+#include <dev/ic/rlnvar.h>
+#include <dev/ic/rlnreg.h>
+#include <dev/ic/rlncmd.h>
/* Autoconfig definition of driver back-end. */
struct cfdriver rln_cd = {
NULL, "rln", DV_IFNET
};
-static void rl2init __P((struct rl2_softc *));
-static void rl2start __P((struct ifnet*));
-static void rl2watchdog __P((struct ifnet*));
-static int rl2ioctl __P((struct ifnet *, u_long, caddr_t));
-static int rl2_probe __P((struct rl2_softc *));
-static void rl2stop __P((struct rl2_softc *));
+static void rlninit __P((struct rln_softc *));
+static void rlnstart __P((struct ifnet*));
+static void rlnwatchdog __P((struct ifnet*));
+static int rlnioctl __P((struct ifnet *, u_long, caddr_t));
+static int rln_probe __P((struct rln_softc *));
+static void rlnstop __P((struct rln_softc *));
/* Interrupt handler. */
-static void rl2softintr __P((void *));
+static void rlnsoftintr __P((void *));
/* Packet I/O. */
-static int rl2_transmit __P((struct rl2_softc *, struct mbuf *,
+static int rln_transmit __P((struct rln_softc *, struct mbuf *,
int, int));
-static struct mbuf * rl2get __P((struct rl2_softc *, struct rl2_mm_cmd *,
+static struct mbuf * rlnget __P((struct rln_softc *, struct rln_mm_cmd *,
int));
/* Card protocol-level functions. */
-static int rl2_getenaddr __P((struct rl2_softc *, u_int8_t *));
-static int rl2_getpromvers __P((struct rl2_softc *, char *, int));
-static int rl2_sendinit __P((struct rl2_softc *));
+static int rln_getenaddr __P((struct rln_softc *, u_int8_t *));
+static int rln_getpromvers __P((struct rln_softc *, char *, int));
+static int rln_sendinit __P((struct rln_softc *));
#if notyet
-static int rl2_roamconfig __P((struct rl2_softc *));
-static int rl2_roam __P((struct rl2_softc *));
-static int rl2_multicast __P((struct rl2_softc *, int));
-static int rl2_searchsync __P((struct rl2_softc *));
-static int rl2_iosetparam __P((struct rl2_softc *, struct rl2_param *));
-static int rl2_lockprom __P((struct rl2_softc *));
-static int rl2_ito __P((struct rl2_softc *));
-static int rl2_standby __P((struct rl2_softc *));
+static int rln_roamconfig __P((struct rln_softc *));
+static int rln_roam __P((struct rln_softc *));
+static int rln_multicast __P((struct rln_softc *, int));
+static int rln_searchsync __P((struct rln_softc *));
+static int rln_iosetparam __P((struct rln_softc *, struct rln_param *));
+static int rln_lockprom __P((struct rln_softc *));
+static int rln_ito __P((struct rln_softc *));
+static int rln_standby __P((struct rln_softc *));
#endif
/* Back-end attach and configure. */
void
-rl2config(sc)
- struct rl2_softc * sc;
+rlnconfig(sc)
+ struct rln_softc * sc;
{
struct ifnet * ifp = &sc->sc_arpcom.ac_if;
char promvers[7];
@@ -94,13 +94,13 @@ rl2config(sc)
sc->sc_cardtype |= sc->sc_dev.dv_cfdata->cf_flags;
/* Initialise values in the soft state. */
- sc->sc_pktseq = 0; /* rl2_newseq() */
+ sc->sc_pktseq = 0; /* rln_newseq() */
sc->sc_txseq = 0;
/* Initialise user-configurable params. */
- sc->sc_param.rp_roam_config = RL2_ROAM_NORMAL;
- sc->sc_param.rp_security = RL2_SECURITY_DEFAULT;
- sc->sc_param.rp_station_type = RL2_STATIONTYPE_ALTMASTER;
+ sc->sc_param.rp_roam_config = RLN_ROAM_NORMAL;
+ sc->sc_param.rp_security = RLN_SECURITY_DEFAULT;
+ sc->sc_param.rp_station_type = RLN_STATIONTYPE_ALTMASTER;
sc->sc_param.rp_domain = 0;
sc->sc_param.rp_channel = 1;
sc->sc_param.rp_subchannel = 1;
@@ -108,30 +108,30 @@ rl2config(sc)
bzero(sc->sc_param.rp_master, sizeof sc->sc_param.rp_master);
/* Initialise the message mailboxes. */
- for (i = 0; i < RL2_NMBOX; i++)
- sc->sc_mbox[i].mb_state = RL2MBOX_VOID;
+ for (i = 0; i < RLN_NMBOX; i++)
+ sc->sc_mbox[i].mb_state = RLNMBOX_VOID;
/* Keep the sys admin informed. */
printf(", %s-piece",
- (sc->sc_cardtype & RL2_CTYPE_ONE_PIECE) ? "one" : "two");
- if (sc->sc_cardtype & RL2_CTYPE_OEM)
+ (sc->sc_cardtype & RLN_CTYPE_ONE_PIECE) ? "one" : "two");
+ if (sc->sc_cardtype & RLN_CTYPE_OEM)
printf(" oem");
- if (sc->sc_cardtype & RL2_CTYPE_UISA)
+ if (sc->sc_cardtype & RLN_CTYPE_UISA)
printf(" micro-isa");
/* Probe/reset the card. */
- if (rl2_probe(sc))
+ if (rln_probe(sc))
return;
/* Read the card's PROM revision. */
- if (rl2_getpromvers(sc, promvers, sizeof promvers)) {
+ if (rln_getpromvers(sc, promvers, sizeof promvers)) {
printf(": could not read PROM version\n");
return;
}
printf(", fw %.7s", promvers);
/* Fetch the card's MAC address. */
- if (rl2_getenaddr(sc, sc->sc_arpcom.ac_enaddr)) {
+ if (rln_getenaddr(sc, sc->sc_arpcom.ac_enaddr)) {
printf(": could not read MAC address\n");
return;
}
@@ -140,9 +140,9 @@ rl2config(sc)
/* Attach as a network interface. */
bcopy(sc->sc_dev.dv_xname, ifp->if_xname, IFNAMSIZ);
ifp->if_softc = sc;
- ifp->if_start = rl2start;
- ifp->if_ioctl = rl2ioctl;
- ifp->if_watchdog = rl2watchdog;
+ ifp->if_start = rlnstart;
+ ifp->if_ioctl = rlnioctl;
+ ifp->if_watchdog = rlnwatchdog;
ifp->if_flags = IFF_BROADCAST | IFF_SIMPLEX | IFF_NOTRAILERS;
if_attach(ifp);
ether_ifattach(ifp);
@@ -153,8 +153,8 @@ rl2config(sc)
/* Bring device up. */
static void
-rl2init(sc)
- struct rl2_softc * sc;
+rlninit(sc)
+ struct rln_softc * sc;
{
/* LLDInit() */
struct ifnet * ifp = &sc->sc_arpcom.ac_if;
@@ -170,11 +170,11 @@ rl2init(sc)
ifp->if_flags &= ~IFF_OACTIVE;
/* Do a hard reset. */
- if (rl2_reset(sc)) {
+ if (rln_reset(sc)) {
printf("%s: could not reset card\n", sc->sc_dev.dv_xname);
goto fail;
}
- sc->sc_state = 0; /* Also clears RL2_STATE_NEEDINIT. */
+ sc->sc_state = 0; /* Also clears RLN_STATE_NEEDINIT. */
/* Use this host's name as a master name. */
if (!cold && sc->sc_param.rp_master[0] == '\0') {
@@ -182,29 +182,29 @@ rl2init(sc)
min(hostnamelen, sizeof sc->sc_param.rp_master));
}
- rl2_enable(sc, 1);
+ rln_enable(sc, 1);
/* Initialise operational params. */
- if (rl2_sendinit(sc)) {
+ if (rln_sendinit(sc)) {
printf("%s: could not set card parameters\n",
sc->sc_dev.dv_xname);
goto fail;
}
#if 0
- rl2_roamconfig(sc);
- /* rl2_lockprom(sc); */ /* XXX error? */
+ rln_roamconfig(sc);
+ /* rln_lockprom(sc); */ /* XXX error? */
/* SendSetITO() */
- rl2_multicast(sc, 1);
- rl2_roam(sc);
+ rln_multicast(sc, 1);
+ rln_roam(sc);
/* Synchronise with something. */
- rl2_searchsync(sc);
+ rln_searchsync(sc);
#endif
s = splnet();
ifp->if_flags |= IFF_RUNNING;
- rl2start(ifp);
+ rlnstart(ifp);
splx(s);
return;
@@ -216,17 +216,17 @@ rl2init(sc)
/* Start outputting on interface. This is always called at splnet(). */
static void
-rl2start(ifp)
+rlnstart(ifp)
struct ifnet * ifp;
{
- struct rl2_softc * sc = (struct rl2_softc *)ifp->if_softc;
+ struct rln_softc * sc = (struct rln_softc *)ifp->if_softc;
struct mbuf * m0;
int len, pad, ret;
dprintf(" start[");
- if (sc->sc_state & RL2_STATE_NEEDINIT)
- rl2init(sc);
+ if (sc->sc_state & RLN_STATE_NEEDINIT)
+ rlninit(sc);
/* Don't transmit if interface is busy or not running. */
if ((ifp->if_flags & (IFF_RUNNING | IFF_OACTIVE)) != IFF_RUNNING) {
@@ -236,7 +236,7 @@ rl2start(ifp)
}
/* Don't transmit if we are not synchronised. */
- if ((sc->sc_state & RL2_STATE_SYNC) == 0) {
+ if ((sc->sc_state & RLN_STATE_SYNC) == 0) {
dprintf(" nosync]");
return;
}
@@ -280,7 +280,7 @@ rl2start(ifp)
goto startagain;
}
- ret = rl2_transmit(sc, m0, len, pad);
+ ret = rln_transmit(sc, m0, len, pad);
if (ret)
goto oerror;
@@ -293,14 +293,14 @@ rl2start(ifp)
oerror:
++ifp->if_oerrors;
m_freem(m0);
- rl2_need_reset(sc);
+ rln_need_reset(sc);
return;
}
/* Transmit one packet. */
static int
-rl2_transmit(sc, m0, len, pad)
- struct rl2_softc * sc;
+rln_transmit(sc, m0, len, pad)
+ struct rln_softc * sc;
struct mbuf * m0;
int len;
int pad;
@@ -309,17 +309,17 @@ rl2_transmit(sc, m0, len, pad)
int zfirst;
int actlen;
int tlen = len + pad;
- struct rl2_msg_tx_state state;
+ struct rln_msg_tx_state state;
static u_int8_t zeroes[60];
- struct rl2_mm_sendpacket cmd = { RL2_MM_SENDPACKET };
+ struct rln_mm_sendpacket cmd = { RLN_MM_SENDPACKET };
/* Does the packet start with a zero bit? */
zfirst = ((*mtod(m0, u_int8_t *) & 1) == 0);
cmd.mode =
- RL2_MM_SENDPACKET_MODE_BIT7 |
- (zfirst ? RL2_MM_SENDPACKET_MODE_ZFIRST : 0) |
- (0 ? RL2_MM_SENDPACKET_MODE_QFSK : 0), /* sc->qfsk? */
+ RLN_MM_SENDPACKET_MODE_BIT7 |
+ (zfirst ? RLN_MM_SENDPACKET_MODE_ZFIRST : 0) |
+ (0 ? RLN_MM_SENDPACKET_MODE_QFSK : 0), /* sc->qfsk? */
cmd.power = 0x70; /* 0x70 or 0xf0 */
cmd.length_lo = htons(4 + tlen) & 0xff;
cmd.length_hi = (htons(4 + tlen) >> 8) & 0xff;
@@ -330,52 +330,52 @@ rl2_transmit(sc, m0, len, pad)
/* A unique packet-level sequence number. XXX related to sc_seq? */
cmd.sequence = sc->sc_txseq;
sc->sc_txseq++;
- if (sc->sc_txseq > RL2_MAXSEQ)
+ if (sc->sc_txseq > RLN_MAXSEQ)
sc->sc_txseq = 0;
dprintf(" T[%d+%d", len, pad);
- if (rl2_msg_tx_start(sc, &cmd, sizeof cmd + tlen, &state))
+ if (rln_msg_tx_start(sc, &cmd, sizeof cmd + tlen, &state))
goto error;
- cmd.mm_cmd.cmd_seq = rl2_newseq(sc);
+ cmd.mm_cmd.cmd_seq = rln_newseq(sc);
-#ifdef RL2DUMP
+#ifdef RLNDUMP
printf("%s: send %c%d seq %d data ", sc->sc_dev.dv_xname,
cmd.mm_cmd.cmd_letter, cmd.mm_cmd.cmd_fn, cmd.mm_cmd.cmd_seq);
- RL2DUMPHEX(&cmd, sizeof cmd);
+ RLNDUMPHEX(&cmd, sizeof cmd);
printf(":");
#endif
- rl2_msg_tx_data(sc, &cmd, sizeof cmd, &state);
+ rln_msg_tx_data(sc, &cmd, sizeof cmd, &state);
actlen = 0;
for (m = m0; m; m = m->m_next) {
if (m->m_len) {
-#ifdef RL2DUMP
- RL2DUMPHEX(mtod(m, void *), m->m_len);
+#ifdef RLNDUMP
+ RLNDUMPHEX(mtod(m, void *), m->m_len);
printf("|");
#endif
- rl2_msg_tx_data(sc, mtod(m, void *), m->m_len, &state);
+ rln_msg_tx_data(sc, mtod(m, void *), m->m_len, &state);
}
actlen += m->m_len;
}
#ifdef DIAGNOSTIC
if (actlen != len)
- panic("rl2_transmit: len %d != %d", actlen, len);
+ panic("rln_transmit: len %d != %d", actlen, len);
if (pad > sizeof zeroes)
- panic("rl2_transmit: pad %d > %d", pad, sizeof zeroes);
+ panic("rln_transmit: pad %d > %d", pad, sizeof zeroes);
#endif
if (pad) {
-#ifdef RL2DUMP
- RL2DUMPHEX(zeroes, pad);
+#ifdef RLNDUMP
+ RLNDUMPHEX(zeroes, pad);
#endif
- rl2_msg_tx_data(sc, zeroes, pad, &state);
+ rln_msg_tx_data(sc, zeroes, pad, &state);
}
-#ifdef RL2DUMP
+#ifdef RLNDUMP
printf("\n");
#endif
- if (rl2_msg_tx_end(sc, &state))
+ if (rln_msg_tx_end(sc, &state))
goto error;
return (0);
@@ -386,99 +386,107 @@ rl2_transmit(sc, m0, len, pad)
/* (Supposedly) called when interrupts are suspiciously absent. */
static void
-rl2watchdog(ifp)
+rlnwatchdog(ifp)
struct ifnet * ifp;
{
- struct rl2_softc * sc = (struct rl2_softc *)ifp->if_softc;
+ struct rln_softc * sc = (struct rln_softc *)ifp->if_softc;
log(LOG_ERR, "%s: device timeout\n", sc->sc_dev.dv_xname);
++sc->sc_arpcom.ac_if.if_oerrors;
- rl2init(sc);
- rl2_enable(sc, 1);
+ rlninit(sc);
+ rln_enable(sc, 1);
}
/* Handle single card interrupt. */
int
-rl2intr(arg)
+rlnintr(arg)
void * arg;
{
- struct rl2_softc * sc = (struct rl2_softc *)arg;
+ struct rln_softc * sc = (struct rln_softc *)arg;
extern int cold;
dprintf("!");
/* Tell card not to interrupt any more. */
- rl2_enable(sc, 0);
+ rln_enable(sc, 0);
if (cold)
/* During autoconfig - must handle interrupts now. */
- rl2softintr(sc);
+ rlnsoftintr(sc);
else
/* Handle later. */
- timeout(rl2softintr, sc, 1);
+ timeout(rlnsoftintr, sc, 1);
return (1);
}
/* Process earlier card interrupt at splnetintr. */
static void
-rl2softintr(arg)
+rlnsoftintr(arg)
void * arg;
{
- struct rl2_softc *sc = (struct rl2_softc *)arg;
+ struct rln_softc *sc = (struct rln_softc *)arg;
struct ifnet *ifp = &sc->sc_arpcom.ac_if;
int len;
u_int8_t w;
- struct rl2_mm_cmd hdr;
+ struct rln_mm_cmd hdr;
dprintf(" si(");
again:
/* Save wakeup state. */
- w = rl2_wakeup(sc, RL2_WAKEUP_SET);
+ w = rln_wakeup(sc, RLN_WAKEUP_SET);
- if ((len = rl2_rx_request(sc, 300)) < 0) {
+ if ((len = rln_rx_request(sc, 300)) < 0) {
/* Error in transfer. */
- rl2_need_reset(sc);
- rl2_rx_end(sc);
+ rln_need_reset(sc);
+ rln_rx_end(sc);
} else if (len < sizeof hdr) {
/* Short message. */
- rl2_rx_end(sc);
+ rln_rx_end(sc);
printf("%s: short msg (%d)\n", sc->sc_dev.dv_xname, len);
ifp->if_ierrors++;
} else {
/* Valid message: read header and process. */
- rl2_rx_data(sc, &hdr, sizeof hdr);
- rl2read(sc, &hdr, len);
+ rln_rx_data(sc, &hdr, sizeof hdr);
+ rlnread(sc, &hdr, len);
}
/* Ensure that wakeup state is unchanged if transmitting. */
if (ifp->if_flags & IFF_OACTIVE)
- w |= RL2_WAKEUP_NOCHANGE;
- rl2_wakeup(sc, w);
+ w |= RLN_WAKEUP_NOCHANGE;
+ rln_wakeup(sc, w);
/* Check for more interrupts. */
- if (rl2_status_rx_ready(sc)) {
+ if (rln_status_rx_ready(sc)) {
+ if (rln_status_rx_read(sc) == RLN_STATUS_RX_ERROR) {
#ifdef DIAGNOSTIC
- printf("%s: intr piggyback\n", sc->sc_dev.dv_xname);
+ printf("%s: protocol error\n", sc->sc_dev.dv_xname);
#endif
- goto again;
+ DELAY(100 * 1000); /* XXX */
+ rln_clear_nak(sc);
+ } else {
+#ifdef DIAGNOSTIC
+ printf("%s: intr piggyback\n", sc->sc_dev.dv_xname);
+#endif
+ goto again;
+ }
}
/* Some cards need this? */
- rl2_eoi(sc);
+ rln_eoi(sc);
/* Re-enable card. */
- rl2_enable(sc, 1);
+ rln_enable(sc, 1);
dprintf(")");
}
/* Read and process a message from the card. */
void
-rl2read(sc, hdr, len)
- struct rl2_softc *sc;
- struct rl2_mm_cmd *hdr;
+rlnread(sc, hdr, len)
+ struct rln_softc *sc;
+ struct rln_mm_cmd *hdr;
int len;
{
struct ifnet *ifp = &sc->sc_arpcom.ac_if;
@@ -487,17 +495,17 @@ rl2read(sc, hdr, len)
u_int8_t data[1538];
u_int8_t *buf;
size_t buflen;
- struct rl2_pdata pd = RL2_PDATA_INIT;
- struct rl2_mm_synchronised * syncp = (struct rl2_mm_synchronised *)data;
+ struct rln_pdata pd = RLN_PDATA_INIT;
+ struct rln_mm_synchronised * syncp = (struct rln_mm_synchronised *)data;
int s;
dprintf(" [read]");
/* Were we waiting for this message? */
- if (rl2_mbox_lock(sc, hdr->cmd_seq, (void **)&buf, &buflen) == 0) {
+ if (rln_mbox_lock(sc, hdr->cmd_seq, (void **)&buf, &buflen) == 0) {
#ifdef DIAGNOSTIC
if (buflen < sizeof *hdr)
- panic("rl2read buflen");
+ panic("rlnread buflen");
#endif
bcopy(hdr, buf, sizeof *hdr);
buf += sizeof *hdr;
@@ -505,7 +513,7 @@ rl2read(sc, hdr, len)
buflen -= sizeof *hdr;
if (len) {
if (len == buflen) /* Expected size */
- rl2_rx_pdata(sc, buf, len, &pd);
+ rln_rx_pdata(sc, buf, len, &pd);
else if (len < buflen) { /* Underfill */
#ifdef DIAGNOSTIC
printf("%s: underfill %d<%d, cmd %c%d\n",
@@ -513,7 +521,7 @@ rl2read(sc, hdr, len)
len, buflen,
hdr->cmd_letter, hdr->cmd_fn);
#endif
- rl2_rx_pdata(sc, buf, len, &pd);
+ rln_rx_pdata(sc, buf, len, &pd);
} else { /* Overflow */
#ifdef DIAGNOSTIC
printf("%s: overflow %d>%d, cmd %c%d\n",
@@ -521,15 +529,15 @@ rl2read(sc, hdr, len)
len, buflen,
hdr->cmd_letter, hdr->cmd_fn);
#endif
- rl2_rx_pdata(sc, buf, buflen, &pd);
+ rln_rx_pdata(sc, buf, buflen, &pd);
/* Drain the rest somewhere. */
- rl2_rx_pdata(sc, data, len - buflen, &pd);
+ rln_rx_pdata(sc, data, len - buflen, &pd);
}
}
- rl2_rx_end(sc);
+ rln_rx_end(sc);
/* This message can now be handled by the waiter. */
- rl2_mbox_unlock(sc, hdr->cmd_seq, len + sizeof *hdr);
+ rln_mbox_unlock(sc, hdr->cmd_seq, len + sizeof *hdr);
return;
}
@@ -539,8 +547,8 @@ rl2read(sc, hdr, len)
if (len > sizeof data) {
printf("%s: msg too big (%d)\n", sc->sc_dev.dv_xname, len);
ifp->if_ierrors++;
- rl2_rx_end(sc);
- /* rl2_need_reset(sc); */
+ rln_rx_end(sc);
+ /* rln_need_reset(sc); */
return;
}
@@ -552,8 +560,8 @@ rl2read(sc, hdr, len)
hdr->cmd_letter, hdr->cmd_fn,
len);
ifp->if_ierrors++;
- rl2_rx_end(sc);
- rl2_need_reset(sc);
+ rln_rx_end(sc);
+ rln_need_reset(sc);
return;
}
@@ -563,8 +571,8 @@ rl2read(sc, hdr, len)
* mbuf to avoid a memory-memory copy.
*/
if (hdr->cmd_letter == 'b' && hdr->cmd_fn == 1) {
- m = rl2get(sc, hdr, len);
- rl2_rx_end(sc);
+ m = rlnget(sc, hdr, len);
+ rln_rx_end(sc);
if (m == NULL)
return;
ifp->if_ipackets++;
@@ -589,20 +597,20 @@ rl2read(sc, hdr, len)
/* Otherwise we read the packet into a buffer on the stack. */
bcopy(hdr, data, sizeof *hdr);
if (len > sizeof *hdr)
- rl2_rx_pdata(sc, data + sizeof *hdr, len - sizeof *hdr, &pd);
- rl2_rx_end(sc);
+ rln_rx_pdata(sc, data + sizeof *hdr, len - sizeof *hdr, &pd);
+ rln_rx_end(sc);
-#ifdef RL2DUMP
+#ifdef RLNDUMP
printf("%s: recv %c%d seq %d data ", sc->sc_dev.dv_xname,
hdr->cmd_letter, hdr->cmd_fn, hdr->cmd_seq);
- RL2DUMPHEX(hdr, sizeof hdr);
+ RLNDUMPHEX(hdr, sizeof hdr);
printf(":");
- RL2DUMPHEX(data + sizeof hdr, len - sizeof hdr);
+ RLNDUMPHEX(data + sizeof hdr, len - sizeof hdr);
printf("\n");
#endif
- switch (RL2_MM_CMD(hdr->cmd_letter, hdr->cmd_fn)) {
- case RL2_MM_CMD('b', 0): /* b0: Transmit done. */
+ switch (RLN_MM_CMD(hdr->cmd_letter, hdr->cmd_fn)) {
+ case RLN_MM_CMD('b', 0): /* b0: Transmit done. */
#ifdef DIAGNOSTIC
if (len != 7)
printf("%s: 'b0' len %d != 7\n",
@@ -611,21 +619,21 @@ rl2read(sc, hdr, len)
ifp->if_flags &= ~IFF_OACTIVE;
ifp->if_opackets++;
s = splnet();
- rl2start(ifp);
+ rlnstart(ifp);
splx(s);
break;
- case RL2_MM_CMD('a', 20): /* a20: Card fault. */
+ case RLN_MM_CMD('a', 20): /* a20: Card fault. */
printf("%s: hardware fault\n", sc->sc_dev.dv_xname);
break;
- case RL2_MM_CMD('a', 4): /* a4: Sync'd. */
+ case RLN_MM_CMD('a', 4): /* a4: Sync'd. */
if (bcmp(syncp->enaddr, sc->sc_arpcom.ac_enaddr,
ETHER_ADDR_LEN) == 0) {
/* Sync'd to own enaddr. */
/*
* From http://www.proxim.com/support/faq/7400.shtml
- * 3. RL2SETUP reports that I'm synchronized to my own MAC address. What
+ * 3. RLNSETUP reports that I'm synchronized to my own MAC address. What
* does that mean?
* You are the acting Master for this network. Either you are
* configured as the Master or as an Alternate Master. If you are an
@@ -647,20 +655,20 @@ rl2read(sc, hdr, len)
/* Record the new circumstances. */
sc->sc_param.rp_channel = syncp->channel;
sc->sc_param.rp_subchannel = syncp->subchannel;
- sc->sc_state |= RL2_STATE_SYNC;
+ sc->sc_state |= RLN_STATE_SYNC;
/* Resume sending. */
s = splnet();
- rl2start(ifp);
+ rlnstart(ifp);
splx(s);
break;
- case RL2_MM_CMD('a', 5): /* a4: Lost sync. */
+ case RLN_MM_CMD('a', 5): /* a4: Lost sync. */
printf("%s: lost sync\n", sc->sc_dev.dv_xname);
- sc->sc_state &= ~RL2_STATE_SYNC;
+ sc->sc_state &= ~RLN_STATE_SYNC;
break;
- case RL2_MM_CMD('a', 18): /* a18: Roaming. */
+ case RLN_MM_CMD('a', 18): /* a18: Roaming. */
printf("%s: roaming\n", sc->sc_dev.dv_xname);
break;
default:
@@ -668,9 +676,9 @@ rl2read(sc, hdr, len)
printf("%s: msg `%c%d' seq %d data {",
sc->sc_dev.dv_xname,
hdr->cmd_letter, hdr->cmd_fn, hdr->cmd_seq);
- RL2DUMPHEX(hdr, sizeof hdr);
+ RLNDUMPHEX(hdr, sizeof hdr);
printf(":");
- RL2DUMPHEX(data, len);
+ RLNDUMPHEX(data, len);
printf("}\n");
#endif
break;
@@ -680,23 +688,23 @@ rl2read(sc, hdr, len)
/* Extract a received network packet from the card. */
static struct mbuf *
-rl2get(sc, hdr, totlen)
- struct rl2_softc *sc;
- struct rl2_mm_cmd *hdr;
+rlnget(sc, hdr, totlen)
+ struct rln_softc *sc;
+ struct rln_mm_cmd *hdr;
int totlen;
{
struct ifnet *ifp = &sc->sc_arpcom.ac_if;
int len;
struct mbuf *m, **mp, *top;
- struct rl2_pdata pd = RL2_PDATA_INIT;
+ struct rln_pdata pd = RLN_PDATA_INIT;
u_int8_t hwhdr[20];
dprintf(" [get]");
-#ifdef RL2DUMP
+#ifdef RLNDUMP
printf("%s: recv %c%d seq %d data ", sc->sc_dev.dv_xname,
hdr->cmd_letter, hdr->cmd_fn, hdr->cmd_seq);
- RL2DUMPHEX(hdr, sizeof hdr);
+ RLNDUMPHEX(hdr, sizeof hdr);
printf(":");
#endif
@@ -710,9 +718,9 @@ rl2get(sc, hdr, totlen)
totlen -= sizeof hwhdr;
/* Skip the hardware header. */
- rl2_rx_pdata(sc, hwhdr, sizeof hwhdr, &pd);
-#ifdef RL2DUMP
- RL2DUMPHEX(hwhdr, sizeof hwhdr);
+ rln_rx_pdata(sc, hwhdr, sizeof hwhdr, &pd);
+#ifdef RLNDUMP
+ RLNDUMPHEX(hwhdr, sizeof hwhdr);
printf("/");
#endif
/* (Most of the following code fleeced from elink3.c.) */
@@ -741,9 +749,9 @@ rl2get(sc, hdr, totlen)
len = MCLBYTES;
}
len = min(totlen, len);
- rl2_rx_pdata(sc, mtod(m, u_int8_t *), len, &pd);
-#ifdef RL2DUMP
- RL2DUMPHEX(mtod(m, u_int8_t *), len);
+ rln_rx_pdata(sc, mtod(m, u_int8_t *), len, &pd);
+#ifdef RLNDUMP
+ RLNDUMPHEX(mtod(m, u_int8_t *), len);
if (totlen != len)
printf("|");
#endif
@@ -752,13 +760,13 @@ rl2get(sc, hdr, totlen)
*mp = m;
mp = &m->m_next;
}
-#ifdef RL2DUMP
+#ifdef RLNDUMP
printf("\n");
#endif
return m;
drop:
-#ifdef RL2DUMP
+#ifdef RLNDUMP
printf(": drop\n");
#endif
ifp->if_iqdrops++;
@@ -767,12 +775,12 @@ drop:
/* Interface control. */
static int
-rl2ioctl(ifp, cmd, data)
+rlnioctl(ifp, cmd, data)
struct ifnet *ifp;
u_long cmd;
caddr_t data;
{
- struct rl2_softc *sc = ifp->if_softc;
+ struct rln_softc *sc = ifp->if_softc;
struct ifaddr *ifa = (struct ifaddr *)data;
int s, error;
int need_init;
@@ -791,12 +799,12 @@ rl2ioctl(ifp, cmd, data)
switch (ifa->ifa_addr->sa_family) {
#ifdef INET
case AF_INET:
- rl2init(sc);
+ rlninit(sc);
arp_ifinit(&sc->sc_arpcom, ifa);
break;
#endif
default:
- rl2init(sc);
+ rlninit(sc);
break;
}
break;
@@ -807,7 +815,7 @@ rl2ioctl(ifp, cmd, data)
if ((ifp->if_flags & IFF_UP) == 0 &&
(ifp->if_flags & IFF_RUNNING) != 0) {
/* Was running, want down: stop. */
- rl2stop(sc);
+ rlnstop(sc);
} else if ((ifp->if_flags & IFF_UP) != 0 &&
(ifp->if_flags & IFF_RUNNING) == 0) {
/* Was not running, want up: start. */
@@ -816,13 +824,13 @@ rl2ioctl(ifp, cmd, data)
if (ifp->if_flags & IFF_RUNNING) {
if ((ifp->if_flags & IFF_PROMISC) &&
- (sc->sc_state & RL2_STATE_PROMISC) == 0) {
- sc->sc_state |= RL2_STATE_PROMISC;
+ (sc->sc_state & RLN_STATE_PROMISC) == 0) {
+ sc->sc_state |= RLN_STATE_PROMISC;
need_init = 1;
}
else if ((ifp->if_flags & IFF_PROMISC) == 0 &&
- (sc->sc_state & RL2_STATE_PROMISC)) {
- sc->sc_state &= ~RL2_STATE_PROMISC;
+ (sc->sc_state & RLN_STATE_PROMISC)) {
+ sc->sc_state &= ~RLN_STATE_PROMISC;
need_init = 1;
}
}
@@ -830,7 +838,7 @@ rl2ioctl(ifp, cmd, data)
/* XXX Deal with other flag changes? */
if (need_init)
- rl2init(sc);
+ rlninit(sc);
break;
@@ -840,12 +848,12 @@ rl2ioctl(ifp, cmd, data)
break;
#if notyet
- case RL2IOSPARAM:
- error = rl2_iosetparam(sc, (struct rl2_param *)&data);
+ case RLNIOSPARAM:
+ error = rln_iosetparam(sc, (struct rln_param *)&data);
break;
- case RL2IOGPARAM:
- bcopy(&sc->sc_param, (struct rl2_param *)&data,
+ case RLNIOGPARAM:
+ bcopy(&sc->sc_param, (struct rln_param *)&data,
sizeof sc->sc_param);
break;
#endif
@@ -861,38 +869,38 @@ rl2ioctl(ifp, cmd, data)
/* Stop output from the card. */
static void
-rl2stop(sc)
- struct rl2_softc *sc;
+rlnstop(sc)
+ struct rln_softc *sc;
{
struct ifnet *ifp = &sc->sc_arpcom.ac_if;
dprintf(" [stop]");
/* XXX Should kill interrupts? */
- /* rl2_enable(sc, 0); */
+ /* rln_enable(sc, 0); */
ifp->if_flags &= ~IFF_RUNNING;
}
/* Test for existence of card. */
static int
-rl2_probe(sc)
- struct rl2_softc *sc;
+rln_probe(sc)
+ struct rln_softc *sc;
{
dprintf(" [probe]");
/* If we can reset it, it's there. */
- return (rl2_reset(sc));
+ return (rln_reset(sc));
}
/* Get MAC address from card. */
static int
-rl2_getenaddr(sc, enaddr)
- struct rl2_softc *sc;
+rln_getenaddr(sc, enaddr)
+ struct rln_softc *sc;
u_int8_t * enaddr;
{
- struct rl2_mm_cmd query = RL2_MM_GETENADDR;
- struct rl2_mm_gotenaddr response = { RL2_MM_GETENADDR };
+ struct rln_mm_cmd query = RLN_MM_GETENADDR;
+ struct rln_mm_gotenaddr response = { RLN_MM_GETENADDR };
- if (rl2_msg_txrx(sc, &query, sizeof query,
+ if (rln_msg_txrx(sc, &query, sizeof query,
&response, sizeof response))
return (-1);
bcopy(response.enaddr, enaddr, sizeof response.enaddr);
@@ -901,21 +909,21 @@ rl2_getenaddr(sc, enaddr)
/* Get firmware version string from card. */
static int
-rl2_getpromvers(sc, ver, verlen)
- struct rl2_softc *sc;
+rln_getpromvers(sc, ver, verlen)
+ struct rln_softc *sc;
char *ver;
int verlen;
{
- struct rl2_mm_cmd query = RL2_MM_GETPROMVERSION;
- struct rl2_mm_gotpromversion response = { RL2_MM_GOTPROMVERSION };
+ struct rln_mm_cmd query = RLN_MM_GETPROMVERSION;
+ struct rln_mm_gotpromversion response = { RLN_MM_GOTPROMVERSION };
int i;
#ifdef DIAGNOSTIC
if (verlen != sizeof response.version)
- panic("rl2_getpromvers");
+ panic("rln_getpromvers");
#endif
- if (rl2_msg_txrx(sc, &query, sizeof query,
+ if (rln_msg_txrx(sc, &query, sizeof query,
&response, sizeof response))
return (-1);
bcopy(response.version, ver, verlen);
@@ -927,23 +935,23 @@ rl2_getpromvers(sc, ver, verlen)
/* Set default operational parameters on card. */
static int
-rl2_sendinit(sc)
- struct rl2_softc *sc;
+rln_sendinit(sc)
+ struct rln_softc *sc;
{
- struct rl2_mm_init init = { RL2_MM_INIT };
- struct rl2_mm_initted iresponse;
+ struct rln_mm_init init = { RLN_MM_INIT };
+ struct rln_mm_initted iresponse;
#if 0
- struct rl2_mm_setmagic magic = { RL2_MM_SETMAGIC };
- struct rl2_mm_disablehopping hop = { RL2_MM_DISABLEHOPPING };
- struct rl2_mm_cmd response;
+ struct rln_mm_setmagic magic = { RLN_MM_SETMAGIC };
+ struct rln_mm_disablehopping hop = { RLN_MM_DISABLEHOPPING };
+ struct rln_mm_cmd response;
#endif
bzero((char*)&init + sizeof init.mm_cmd,
sizeof init - sizeof init.mm_cmd);
dprintf(" [setting parameters]");
- init.opmode = (sc->sc_state & RL2_STATE_PROMISC ?
- RL2_MM_INIT_OPMODE_PROMISC : RL2_MM_INIT_OPMODE_NORMAL);
+ init.opmode = (sc->sc_state & RLN_STATE_PROMISC ?
+ RLN_MM_INIT_OPMODE_PROMISC : RLN_MM_INIT_OPMODE_NORMAL);
init.stationtype = sc->sc_param.rp_station_type;
/* Spread-spectrum frequency hopping. */
@@ -967,7 +975,7 @@ rl2_sendinit(sc)
init.sync_to = 1;
bzero(init.syncname, sizeof init.syncname);
- if (rl2_msg_txrx(sc, &init, sizeof init,
+ if (rln_msg_txrx(sc, &init, sizeof init,
&iresponse, sizeof iresponse))
return (-1);
#if 0
@@ -982,13 +990,13 @@ rl2_sendinit(sc)
magic.xxx2 = 0xff;
magic.xxx3 = 0xff;
magic.xxx4 = 0x00;
- if (rl2_msg_txrx(sc, &magic, sizeof magic,
+ if (rln_msg_txrx(sc, &magic, sizeof magic,
&response, sizeof response))
return (-1);
dprintf(" [disabling freq hopping]");
- hop.hopflag = RL2_MM_DISABLEHOPPING_HOPFLAG_DISABLE;
- if (rl2_msg_txrx(sc, &hop, sizeof hop,
+ hop.hopflag = RLN_MM_DISABLEHOPPING_HOPFLAG_DISABLE;
+ if (rln_msg_txrx(sc, &hop, sizeof hop,
&response, sizeof response))
return (-1);
@@ -999,11 +1007,11 @@ rl2_sendinit(sc)
#if notyet
/* Configure the way the card leaves a basestation. */
static int
-rl2_roamconfig(sc)
- struct rl2_softc *sc;
+rln_roamconfig(sc)
+ struct rln_softc *sc;
{
- struct rl2_mm_setroaming roam = { RL2_MM_SETROAMING };
- struct rl2_mm_cmd response;
+ struct rln_mm_setroaming roam = { RLN_MM_SETROAMING };
+ struct rln_mm_cmd response;
static int retry[3] = { 6, 6, 4 };
static int rssi[3] = { 5, 15, 5 };
@@ -1019,7 +1027,7 @@ rl2_roamconfig(sc)
roam.sync_rssi_threshold = 0;
roam.xxx2 = 0x5a;
roam.missed_sync = 0x4;
- if (rl2_msg_txrx(sc, &roam, sizeof roam,
+ if (rln_msg_txrx(sc, &roam, sizeof roam,
&response, sizeof response))
return (-1);
@@ -1028,30 +1036,30 @@ rl2_roamconfig(sc)
/* Enable roaming. */
static int
-rl2_roam(sc)
- struct rl2_softc *sc;
+rln_roam(sc)
+ struct rln_softc *sc;
{
- struct rl2_mm_cmd roam = RL2_MM_ROAM;
- struct rl2_mm_cmd response;
+ struct rln_mm_cmd roam = RLN_MM_ROAM;
+ struct rln_mm_cmd response;
- return (rl2_msg_txrx(sc, &roam, sizeof roam,
+ return (rln_msg_txrx(sc, &roam, sizeof roam,
&response, sizeof response));
}
/* Enable multicast capability. */
static int
-rl2_multicast(sc, enable)
- struct rl2_softc *sc;
+rln_multicast(sc, enable)
+ struct rln_softc *sc;
int enable;
{
struct ifnet *ifp = &sc->sc_arpcom.ac_if;
- struct rl2_mm_multicast mcast = { RL2_MM_MULTICAST };
- struct rl2_mm_cmd response;
+ struct rln_mm_multicast mcast = { RLN_MM_MULTICAST };
+ struct rln_mm_cmd response;
int ret;
mcast.enable = enable;
- ret = rl2_msg_txrx(sc, &mcast, sizeof mcast,
+ ret = rln_msg_txrx(sc, &mcast, sizeof mcast,
&response, sizeof response);
if (ret == 0) {
if (enable)
@@ -1064,11 +1072,11 @@ rl2_multicast(sc, enable)
/* Search for and sync with any master. */
static int
-rl2_searchsync(sc)
- struct rl2_softc *sc;
+rln_searchsync(sc)
+ struct rln_softc *sc;
{
- struct rl2_mm_search search = { RL2_MM_SEARCH };
- struct rl2_mm_searching response;
+ struct rln_mm_search search = { RLN_MM_SEARCH };
+ struct rln_mm_searching response;
bzero(search.xxx1, sizeof search.xxx1);
search.domain = sc->sc_param.rp_domain;
@@ -1078,15 +1086,15 @@ rl2_searchsync(sc)
search.xxx5 = 0;
bzero(search.xxx6, sizeof search.xxx6);
- return (rl2_msg_txrx(sc, &search, sizeof search,
+ return (rln_msg_txrx(sc, &search, sizeof search,
&response, sizeof response));
}
/* Set values from an external parameter block. */
static int
-rl2_iosetparam(sc, param)
- struct rl2_softc *sc;
- struct rl2_param *param;
+rln_iosetparam(sc, param)
+ struct rln_softc *sc;
+ struct rln_param *param;
{
int error = 0;
@@ -1103,7 +1111,7 @@ rl2_iosetparam(sc, param)
if (error == 0) {
/* Apply immediately. */
bcopy(param, &sc->sc_param, sizeof *param);
- if (rl2_sendinit(sc))
+ if (rln_sendinit(sc))
error = EIO;
}
return (error);
@@ -1111,24 +1119,24 @@ rl2_iosetparam(sc, param)
/* Protect the eeprom from storing a security ID(?) */
static int
-rl2_lockprom(sc)
- struct rl2_softc *sc;
+rln_lockprom(sc)
+ struct rln_softc *sc;
{
- struct rl2_mm_cmd lock = RL2_MM_EEPROM_PROTECT;
- struct rl2_mm_cmd response;
+ struct rln_mm_cmd lock = RLN_MM_EEPROM_PROTECT;
+ struct rln_mm_cmd response;
/* XXX Always yields an error? */
- return (rl2_msg_txrx(sc, &lock, sizeof lock,
+ return (rln_msg_txrx(sc, &lock, sizeof lock,
&response, sizeof response));
}
/* Set the h/w Inactivity Time Out timer on the card. */
static int
-rl2_ito(sc)
- struct rl2_softc * sc;
+rln_ito(sc)
+ struct rln_softc * sc;
{
- struct rl2_mm_setito ito = { RL2_MM_MULTICAST };
- struct rl2_mm_cmd response;
+ struct rln_mm_setito ito = { RLN_MM_MULTICAST };
+ struct rln_mm_cmd response;
ito.xxx = 3;
ito.timeout = LLDInactivityTimeOut /* enabler, 0 or 1 */;
@@ -1136,20 +1144,20 @@ rl2_ito(sc)
ito.pm_sync = LLDPMSync /* 0 */;
ito.sniff_time = ito.timeout ? LLDSniffTime /* 0 */ : 0;
- if (rl2_msg_txrx(sc, &ito, sizeof ito,
+ if (rln_msg_txrx(sc, &ito, sizeof ito,
&response, sizeof response))
return (-1);
}
/* Put the card into standby mode. */
static int
-rl2_standby(sc)
- struct rl2_softc * sc;
+rln_standby(sc)
+ struct rln_softc * sc;
{
- struct rl2_mm_standby standby = { RL2_MM_STANDBY };
+ struct rln_mm_standby standby = { RLN_MM_STANDBY };
standby.xxx = 0;
- if (rl2_msg_txrx(sc, &ito, sizeof ito, NULL, 0))
+ if (rln_msg_txrx(sc, &ito, sizeof ito, NULL, 0))
return (-1);
}
#endif
diff --git a/sys/dev/ic/rl2.h b/sys/dev/ic/rln.h
index 850dda9331c..fa4b7b2e799 100644
--- a/sys/dev/ic/rl2.h
+++ b/sys/dev/ic/rln.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: rl2.h,v 1.2 1999/07/14 03:51:50 d Exp $ */
+/* $OpenBSD: rln.h,v 1.1 1999/07/30 13:43:36 d Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public domain.
*
@@ -11,29 +11,29 @@
*/
/* User-configurable station parameters. */
-struct rl2_param {
+struct rln_param {
u_int32_t rp_security; /* Security ID */
-#define RL2_SECURITY_DEFAULT 0x0010203
+#define RLN_SECURITY_DEFAULT 0x0010203
u_int8_t rp_station_type; /* Station type */
-#define RL2_STATIONTYPE_SLAVE 0
-#define RL2_STATIONTYPE_ALTMASTER 1
-#define RL2_STATIONTYPE_MASTER 2
+#define RLN_STATIONTYPE_SLAVE 0
+#define RLN_STATIONTYPE_ALTMASTER 1
+#define RLN_STATIONTYPE_MASTER 2
u_int8_t rp_domain; /* Network domain */
u_int8_t rp_channel; /* Phys channel when master */
u_int8_t rp_subchannel; /* Logical master subchannel */
char rp_master[11]; /* Name when master */
u_int8_t rp_mac_optimize;
-#define RL2_MAC_OPTIM_LIGHT 0
-#define RL2_MAC_OPTIM_NORMAL 1
+#define RLN_MAC_OPTIM_LIGHT 0
+#define RLN_MAC_OPTIM_NORMAL 1
u_int8_t rp_roam_config; /* Roaming speed */
-#define RL2_ROAM_SLOW 0
-#define RL2_ROAM_NORMAL 1
-#define RL2_ROAM_FAST 2
+#define RLN_ROAM_SLOW 0
+#define RLN_ROAM_NORMAL 1
+#define RLN_ROAM_FAST 2
u_int8_t rp_peer_to_peer; /* Ability to talk to peers */
};
#ifdef notyet
-#define RL2IOSPARAM _IOW('2', 1, struct rl2_param) /* set params */
-#define RL2IOGPARAM _IOR('2', 2, struct rl2_param) /* get params */
+#define RLNIOSPARAM _IOW('2', 1, struct rln_param) /* set params */
+#define RLNIOGPARAM _IOR('2', 2, struct rln_param) /* get params */
#endif
diff --git a/sys/dev/ic/rl2cmd.h b/sys/dev/ic/rlncmd.h
index 0fe4f8365e4..efaed3dcde1 100644
--- a/sys/dev/ic/rl2cmd.h
+++ b/sys/dev/ic/rlncmd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: rl2cmd.h,v 1.2 1999/07/14 03:52:27 d Exp $ */
+/* $OpenBSD: rlncmd.h,v 1.1 1999/07/30 13:43:36 d Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public Domain.
*
@@ -6,28 +6,28 @@
*/
/* Micro-message command header. */
-struct rl2_mm_cmd {
+struct rln_mm_cmd {
u_int8_t cmd_letter; /* Command letter */
u_int8_t cmd_seq; /* Incremented on each command */
-#define RL2_MAXSEQ 0x7c
+#define RLN_MAXSEQ 0x7c
u_int8_t cmd_fn; /* Function number */
u_int8_t cmd_error; /* Reserved */
};
-#define RL2_MM_CMD(l,n) ((((unsigned int)l)<<8) | ((unsigned int)n))
-#define RL2_MM_CMD_LETTER(cmd) ((unsigned char)(((cmd) & 0xff00)>>8))
-#define RL2_MM_CMD_FUNCTION(cmd) ((unsigned char)((cmd) & 0xff))
-#define RL2_CMDCODE(letter, num) ((((letter) & 0xff) << 8) | ((num) & 0xff))
+#define RLN_MM_CMD(l,n) ((((unsigned int)l)<<8) | ((unsigned int)n))
+#define RLN_MM_CMD_LETTER(cmd) ((unsigned char)(((cmd) & 0xff00)>>8))
+#define RLN_MM_CMD_FUNCTION(cmd) ((unsigned char)((cmd) & 0xff))
+#define RLN_CMDCODE(letter, num) ((((letter) & 0xff) << 8) | ((num) & 0xff))
/* Initialise card, and set operational parameters. */
-struct rl2_mm_init {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_INIT { 'A', 0, 0, 0 }
+struct rln_mm_init {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_INIT { 'A', 0, 0, 0 }
u_int8_t enaddr[6];
u_int8_t opmode;
-#define RL2_MM_INIT_OPMODE_NORMAL 0
-#define RL2_MM_INIT_OPMODE_PROMISC 1
-#define RL2_MM_INIT_OPMODE_PROTOCOL 2
- u_int8_t stationtype; /* RL2_STATIONTYPE_... */
+#define RLN_MM_INIT_OPMODE_NORMAL 0
+#define RLN_MM_INIT_OPMODE_PROMISC 1
+#define RLN_MM_INIT_OPMODE_PROTOCOL 2
+ u_int8_t stationtype; /* RLN_STATIONTYPE_... */
u_int8_t hop_period;
u_int8_t bfreq;
u_int8_t sfreq;
@@ -44,16 +44,16 @@ struct rl2_mm_init {
};
/* Result of initialisation. */
-struct rl2_mm_initted {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_INITTED { 'a', 0, 0, 0 }
+struct rln_mm_initted {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_INITTED { 'a', 0, 0, 0 }
u_int8_t xxx;
};
/* Start searching for other masters. */
-struct rl2_mm_search {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_SEARCH { 'A', 0, 1, 0 }
+struct rln_mm_search {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_SEARCH { 'A', 0, 1, 0 }
u_int8_t xxx1[23];
u_char xxx2 : 4;
u_char domain : 4;
@@ -65,19 +65,19 @@ struct rl2_mm_search {
};
/* Notification that searching has started. */
-struct rl2_mm_searching {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_SEARCHING { 'a', 0, 1, 0 }
+struct rln_mm_searching {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_SEARCHING { 'a', 0, 1, 0 }
u_int8_t xxx;
};
/* Terminate search. */
-#define RL2_MM_ABORTSEARCH { 'A', 0, 3, 0 }
+#define RLN_MM_ABORTSEARCH { 'A', 0, 3, 0 }
/* Station synchronised to a master. */
-struct rl2_mm_synchronised {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_SYNCHRONISED { 'a', 0, 4, 0 }
+struct rln_mm_synchronised {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_SYNCHRONISED { 'a', 0, 4, 0 }
u_char channel : 4; /* lower bits */
u_char subchannel : 4; /* upper bits */
char mastername[11];
@@ -85,19 +85,19 @@ struct rl2_mm_synchronised {
};
/* Station lost synchronisation with a master. */
-#define RL2_MM_UNSYNCHRONISED { 'a', 0, 5, 0 }
+#define RLN_MM_UNSYNCHRONISED { 'a', 0, 5, 0 }
-/* Send card to sleep. (See rl2_wakeup().) */
-struct rl2_mm_standby {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_STANDBY { 'A', 0, 6, 0 }
+/* Send card to sleep. (See rln_wakeup().) */
+struct rln_mm_standby {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_STANDBY { 'A', 0, 6, 0 }
u_int8_t xxx; /* default 0 */
};
/* Set ITO (inactivity timeout timer). */
-struct rl2_mm_setito {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_SETITO { 'A', 0, 7, 0 }
+struct rln_mm_setito {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_SETITO { 'A', 0, 7, 0 }
u_int8_t xxx; /* default 3 */
u_int8_t timeout;
u_char bd_wakeup : 1;
@@ -106,65 +106,65 @@ struct rl2_mm_setito {
};
/* ITO acknowledgment */
-#define RL2_MM_GOTITO { 'a', 0, 7, 0 }
+#define RLN_MM_GOTITO { 'a', 0, 7, 0 }
/* Send keepalive protocol message (?). */
-#define RL2_MM_SENDKEEPALIVE { 'A', 0, 8, 0 }
+#define RLN_MM_SENDKEEPALIVE { 'A', 0, 8, 0 }
/* Set multicast mode. */
-struct rl2_mm_multicast {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_MULTICAST { 'A', 0, 9, 0 }
+struct rln_mm_multicast {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_MULTICAST { 'A', 0, 9, 0 }
u_int8_t enable;
};
/* Ack multicast mode change. */
-#define RL2_MM_MULTICASTING { 'a', 0, 9, 0 }
+#define RLN_MM_MULTICASTING { 'a', 0, 9, 0 }
/* Request statistics. */
-#define RL2_MM_GETSTATS { 'A', 0, 11, 0 }
+#define RLN_MM_GETSTATS { 'A', 0, 11, 0 }
/* Statistics results. */
-#define RL2_MM_GOTSTATS { 'a', 0, 11, 0 }
+#define RLN_MM_GOTSTATS { 'a', 0, 11, 0 }
/* Set security ID used in channel. */
-struct rl2_mm_setsecurity {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_SETSECURITY { 'A', 0, 12, 0 }
+struct rln_mm_setsecurity {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_SETSECURITY { 'A', 0, 12, 0 }
u_int8_t sec1;
u_int8_t sec2;
u_int8_t sec3;
};
/* Ack set security ID. */
-#define RL2_MM_GOTSECURITY { 'a', 0, 12, 0 }
+#define RLN_MM_GOTSECURITY { 'a', 0, 12, 0 }
/* Request firmware version. */
-#define RL2_MM_GETPROMVERSION { 'A', 0, 13, 0 }
+#define RLN_MM_GETPROMVERSION { 'A', 0, 13, 0 }
/* Reply with firmware version. */
-struct rl2_mm_gotpromversion {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_GOTPROMVERSION { 'a', 0, 13, 0 }
+struct rln_mm_gotpromversion {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_GOTPROMVERSION { 'a', 0, 13, 0 }
u_int8_t xxx; /* sizeof version? */
char version[7];
};
/* Request station's MAC address (same as ethernet). */
-#define RL2_MM_GETENADDR { 'A', 0, 14, 0 }
+#define RLN_MM_GETENADDR { 'A', 0, 14, 0 }
/* Reply with station's MAC address. */
-struct rl2_mm_gotenaddr {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_GOTENADDR { 'a', 0, 14, 0 }
+struct rln_mm_gotenaddr {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_GOTENADDR { 'a', 0, 14, 0 }
u_int8_t xxx;
u_int8_t enaddr[6];
};
/* Tune various channel parameters. */
-struct rl2_mm_setmagic {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_SETMAGIC { 'A', 0, 16, 0 }
+struct rln_mm_setmagic {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_SETMAGIC { 'A', 0, 16, 0 }
u_char fairness_slot : 3;
u_char deferral_slot : 5;
u_int8_t regular_mac_retry; /* default 0x07 */
@@ -178,12 +178,12 @@ struct rl2_mm_setmagic {
};
/* Ack channel tuning. */
-#define RL2_MM_GOTMAGIC { 'a', 0, 16, 0 }
+#define RLN_MM_GOTMAGIC { 'a', 0, 16, 0 }
/* Set roaming parameters - used when multiple masters available. */
-struct rl2_mm_setroaming {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_SETROAMING { 'A', 0, 17, 0 }
+struct rln_mm_setroaming {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_SETROAMING { 'A', 0, 17, 0 }
u_int8_t sync_alarm;
u_int8_t retry_thresh;
u_int8_t rssi_threshold;
@@ -194,30 +194,30 @@ struct rl2_mm_setroaming {
};
/* Ack roaming parameter change. */
-#define RL2_MM_GOTROAMING { 'a', 0, 17, 0 }
+#define RLN_MM_GOTROAMING { 'a', 0, 17, 0 }
-#define RL2_MM_ROAMING { 'a', 0, 18, 0 }
-#define RL2_MM_ROAM { 'A', 0, 19, 0 }
+#define RLN_MM_ROAMING { 'a', 0, 18, 0 }
+#define RLN_MM_ROAM { 'A', 0, 19, 0 }
/* Hardware fault notification. (Usually the antenna.) */
-#define RL2_MM_FAULT { 'a', 0, 20, 0 }
+#define RLN_MM_FAULT { 'a', 0, 20, 0 }
-#define RL2_MM_EEPROM_PROTECT { 'A', 0, 23, 0 }
-#define RL2_MM_EEPROM_PROTECTED { 'a', 0, 23, 0 }
-#define RL2_MM_EEPROM_UNPROTECT { 'A', 0, 24, 0 }
-#define RL2_MM_EEPROM_UNPROTECTED { 'a', 0, 24, 0 }
+#define RLN_MM_EEPROM_PROTECT { 'A', 0, 23, 0 }
+#define RLN_MM_EEPROM_PROTECTED { 'a', 0, 23, 0 }
+#define RLN_MM_EEPROM_UNPROTECT { 'A', 0, 24, 0 }
+#define RLN_MM_EEPROM_UNPROTECTED { 'a', 0, 24, 0 }
/* Receive hop statistics. */
-#define RL2_MM_HOP_STATISTICS { 'a', 0, 35, 0 }
+#define RLN_MM_HOP_STATISTICS { 'a', 0, 35, 0 }
/* Transmit a frame on the channel. */
-struct rl2_mm_sendpacket {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_SENDPACKET { 'B', 0, 0, 0 }
+struct rln_mm_sendpacket {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_SENDPACKET { 'B', 0, 0, 0 }
u_int8_t mode;
-#define RL2_MM_SENDPACKET_MODE_BIT7 0x80
-#define RL2_MM_SENDPACKET_MODE_ZFIRST 0x20
-#define RL2_MM_SENDPACKET_MODE_QFSK 0x03
+#define RLN_MM_SENDPACKET_MODE_BIT7 0x80
+#define RLN_MM_SENDPACKET_MODE_ZFIRST 0x20
+#define RLN_MM_SENDPACKET_MODE_QFSK 0x03
u_int8_t power; /* default 0x70 */
u_int8_t length_lo;
u_int8_t length_hi;
@@ -228,20 +228,20 @@ struct rl2_mm_sendpacket {
};
/* Ack packet transmission. */
-#define RL2_MM_SENTPACKET { 'b', 0, 0, 0 }
+#define RLN_MM_SENTPACKET { 'b', 0, 0, 0 }
/* Notification of frame received from channel. */
-struct rl2_mm_recvpacket {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_RECVPACKET { 'b', 0, 1, 0 }
+struct rln_mm_recvpacket {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_RECVPACKET { 'b', 0, 1, 0 }
u_int8_t xxx[8];
};
/* Disable hopping. (?) */
-struct rl2_mm_disablehopping {
- struct rl2_mm_cmd mm_cmd;
-#define RL2_MM_DISABLEHOPPING { 'C', 0, 9, 0 }
+struct rln_mm_disablehopping {
+ struct rln_mm_cmd mm_cmd;
+#define RLN_MM_DISABLEHOPPING { 'C', 0, 9, 0 }
u_int8_t hopflag;
-#define RL2_MM_DISABLEHOPPING_HOPFLAG_DISABLE 0x52
+#define RLN_MM_DISABLEHOPPING_HOPFLAG_DISABLE 0x52
};
diff --git a/sys/dev/ic/rlnreg.h b/sys/dev/ic/rlnreg.h
new file mode 100644
index 00000000000..0677837aa8c
--- /dev/null
+++ b/sys/dev/ic/rlnreg.h
@@ -0,0 +1,250 @@
+/* $OpenBSD: rlnreg.h,v 1.1 1999/07/30 13:43:36 d Exp $ */
+/*
+ * David Leonard <d@openbsd.org>, 1999. Public Domain.
+ *
+ * RangeLAN2 registers
+ */
+
+/*
+ * The RangeLAN2 cards provide four control registers for transferring
+ * messaged between the host and the card using programmed i/o.
+ *
+ * A transfer protocol is followed when sending asynchronous messages to,
+ * and receiving messages from, the card.
+ *
+ * DATA
+ * 7 6 5 4 3 2 1 0
+ * +-------+-------+-------+-------+-------+-------+-------+-------+
+ * | data |
+ * +-------+-------+-------+-------+-------+-------+-------+-------+
+ *
+ * STATUS
+ * 7 6 5 4 3 2 1 0
+ * +-------+-------+-------+-------+-------+-------+-------+-------+
+ * |WAKEUP | tx message state |CLRNAK | rx message state |
+ * +-------+-------+-------+-------+-------+-------+-------+-------+
+ *
+ * CONTROL
+ * 7 6 5 4 3 2 1 0
+ * +-------+-------+-------+-------+-------+-------+-------+-------+
+ * | | | 16BIT | RESET | | | TXINT | RXINT |
+ * +-------+-------+-------+-------+-------+-------+-------+-------+
+ *
+ * INTSEL
+ * 7 6 5 4 3 2 1 0
+ * +-------+-------+-------+-------+-------+-------+-------+-------+
+ * | | | |ENABLE | interrupt line |
+ * +-------+-------+-------+-------+-------+-------+-------+-------+
+ */
+
+/* Register offsets. */
+#define RLN_REG_DATA 0
+#define RLN_REG_STATUS 2
+#define RLN_REG_CONTROL 4
+#define RLN_REG_EOI 5
+#define RLN_REG_INTSEL 6
+#define RLN_NPORTS 8
+
+/*
+ * A short delay is needed (16ms?) after register writes on some cards.
+ * XXX This is done by performing an innocent and harmless bus read. (i386)
+ * This is what Proxim's driver does, anyway.
+ */
+#define _rln_regacc_delay() \
+ bus_space_read_1(I386_BUS_SPACE_IO, 0, 0x61)
+
+static void _rln_register_write_1 __P((struct rln_softc *, u_int8_t,
+ u_int8_t));
+static u_int8_t _rln_register_read_1 __P((struct rln_softc *, u_int8_t));
+static int rln_status_rx_ready __P((struct rln_softc *));
+
+/* Write to a register. */
+static inline void
+_rln_register_write_1(sc, regoff, value)
+ struct rln_softc *sc;
+ u_int8_t regoff;
+ u_int8_t value;
+{
+
+#ifdef RLNDEBUG_REG
+ printf(" %c<%02x", "DDS3CEI7"[regoff], value);
+#endif
+ bus_space_write_1((sc)->sc_iot, (sc)->sc_ioh, (regoff), (value));
+ _rln_regacc_delay();
+}
+
+/* Read from a register. */
+static inline u_int8_t
+_rln_register_read_1(sc, regoff)
+ struct rln_softc *sc;
+ u_int8_t regoff;
+{
+ u_int8_t ret;
+
+ ret = bus_space_read_1((sc)->sc_iot, (sc)->sc_ioh, (regoff));
+#ifdef RLNDEBUG_REG
+ if (ret != (sc)->dbg_oreg[regoff]) {
+ /* avoid spewing out too much debug info */
+ printf(" %c>%02x", "DDS3CEI7"[regoff], ret);
+ (sc)->dbg_oreg[regoff] = ret;
+ }
+#endif
+ return (ret);
+}
+
+/* 8-bit data register access. */
+#define rln_data_write_1(sc, value) \
+ _rln_register_write_1(sc, RLN_REG_DATA, (value))
+#define rln_data_read_1(sc) \
+ _rln_register_read_1(sc, RLN_REG_DATA)
+#define rln_data_write_multi_1(sc, buf, len) \
+ bus_space_write_multi_1((sc)->sc_iot, (sc)->sc_ioh, \
+ RLN_REG_DATA, (buf), (len))
+#define rln_data_read_multi_1(sc, buf, len) \
+ bus_space_read_multi_1((sc)->sc_iot, (sc)->sc_ioh, \
+ RLN_REG_DATA, (buf), (len))
+
+/* 16-bit data register access. */
+#define rln_data_write_2(sc, value) \
+ bus_space_write_2((sc)->sc_iot, (sc)->sc_ioh, \
+ RLN_REG_DATA, (value))
+#define rln_data_read_2(sc) \
+ bus_space_read_2((sc)->sc_iot, (sc)->sc_ioh, \
+ RLN_REG_DATA)
+#define rln_data_write_multi_2(sc, buf, len) \
+ bus_space_write_multi_2((sc)->sc_iot, (sc)->sc_ioh, \
+ RLN_REG_DATA, (buf), (len))
+#define rln_data_read_multi_2(sc, buf, len) \
+ bus_space_read_multi_2((sc)->sc_iot, (sc)->sc_ioh, \
+ RLN_REG_DATA, (buf), (len))
+
+/* Status register. */
+#define RLN_STATUS_CLRNAK 0x08
+#define RLN_STATUS_WAKEUP 0x80
+
+#define RLN_STATUS_TX_IDLE 0x00
+#define RLN_STATUS_TX_HILEN_AVAIL 0x01
+#define RLN_STATUS_TX_HILEN_ACCEPT 0x02
+#define RLN_STATUS_TX_XFR_COMPLETE 0x03
+#define RLN_STATUS_TX_XFR 0x04
+#define RLN_STATUS_TX_ERROR 0x05
+#define RLN_STATUS_TX_LOLEN_AVAIL 0x06
+#define RLN_STATUS_TX_LOLEN_ACCEPT 0x07
+#define RLN_STATUS_TX_MASK 0x0f
+
+#define RLN_STATUS_RX_IDLE 0x00
+#define RLN_STATUS_RX_HILEN_AVAIL 0x10
+#define RLN_STATUS_RX_HILEN_ACCEPT 0x20
+#define RLN_STATUS_RX_XFR_COMPLETE 0x30
+#define RLN_STATUS_RX_XFR 0x40
+#define RLN_STATUS_RX_ERROR 0x50
+#define RLN_STATUS_RX_LOLEN_AVAIL 0x60
+#define RLN_STATUS_RX_LOLEN_ACCEPT 0x70
+#define RLN_STATUS_RX_MASK 0x70
+
+#define rln_status_write(sc, value) \
+ _rln_register_write_1(sc, RLN_REG_STATUS, (value))
+#define rln_status_set(sc, bits) \
+ rln_status_write(sc, (sc)->sc_status |= (bits))
+#define rln_status_clear(sc, bits) \
+ rln_status_write(sc, (sc)->sc_status &= ~(bits))
+#define _rln_status_setmask(sc, mask, bits) \
+do { \
+ int _s; \
+ \
+ _s = splhigh(); \
+ (sc)->sc_status = ((sc)->sc_status & (mask)) | (bits); \
+ rln_status_write(sc, (sc)->sc_status); \
+ splx(_s); \
+} while (0);
+#define rln_status_rx_write(sc, state) \
+ _rln_status_setmask((sc), ~RLN_STATUS_RX_MASK, state)
+#define rln_status_tx_write(sc, state) \
+ _rln_status_setmask((sc), ~RLN_STATUS_TX_MASK, state)
+#define rln_status_read(sc) \
+ _rln_register_read_1(sc, RLN_REG_STATUS)
+#define rln_status_rx_read(sc) \
+ (rln_status_read(sc) & ~RLN_STATUS_TX_MASK)
+#define rln_status_tx_read(sc) \
+ (rln_status_read(sc) & ~RLN_STATUS_RX_MASK)
+
+static inline int
+rln_status_rx_ready(sc)
+ struct rln_softc *sc;
+{
+ u_int8_t status;
+
+ status = rln_status_rx_read(sc);
+ return (status == RLN_STATUS_RX_LOLEN_AVAIL ||
+ status == RLN_STATUS_RX_HILEN_AVAIL ||
+ status == RLN_STATUS_RX_ERROR);
+}
+
+#define rln_status_tx_int(sc) do { \
+ int _s = splhigh(); \
+ \
+ rln_control_clear(sc, RLN_CONTROL_TXINT); \
+ rln_control_set(sc, RLN_CONTROL_TXINT); \
+ splx(_s); \
+} while (0)
+#define rln_status_rx_int(sc) do { \
+ int _s = splhigh(); \
+ \
+ rln_control_clear(sc, RLN_CONTROL_RXINT); \
+ rln_control_set(sc, RLN_CONTROL_RXINT); \
+ splx(_s); \
+} while (0)
+
+/* Control register. */
+#define RLN_CONTROL_RXINT 0x01
+#define RLN_CONTROL_TXINT 0x02
+#define RLN_CONTROL_BIT2 0x04
+#define RLN_CONTROL_BIT3 0x08
+#define RLN_CONTROL_RESET 0x10
+#define RLN_CONTROL_16BIT 0x20
+#define RLN_CONTROL_MASK 0x3f
+
+#define rln_control_write(sc, value) \
+ _rln_register_write_1(sc, RLN_REG_CONTROL, \
+ (sc)->sc_control = (value))
+#define rln_control_read(sc) \
+ _rln_register_read_1(sc, RLN_REG_CONTROL)
+#define rln_control_set(sc, bits) \
+ rln_control_write(sc, (sc)->sc_control | (bits))
+#define rln_control_clear(sc, bits) \
+ rln_control_write(sc, (sc)->sc_control & ~(bits))
+#define rln_control_outofstandby(sc) do { \
+ rln_control_write(sc, (sc)->sc_control | RLN_CONTROL_RESET);\
+ DELAY(30000); \
+ rln_control_write(sc, (sc)->sc_control); \
+} while (0)
+
+/* Interrupt selection register. */
+#define RLN_INTSEL_IRQMASK 0x07
+#define RLN_INTSEL_ENABLE 0x10
+#define RLN_INTSEL_BIT7 0x80
+
+#define rln_intsel_disable(sc) do { \
+ int _s; \
+ \
+ _s = splhigh(); \
+ _rln_register_write_1(sc, RLN_REG_INTSEL, \
+ (sc)->sc_intsel &= ~RLN_INTSEL_ENABLE); \
+ splx(_s); \
+} while (0)
+#define rln_intsel_enable(sc) do { \
+ int _s; \
+ \
+ _s = splhigh(); \
+ _rln_register_write_1(sc, RLN_REG_INTSEL, \
+ (sc)->sc_intsel |= RLN_INTSEL_ENABLE); \
+ splx(_s); \
+} while (0)
+#define rln_intsel_write(sc, value) \
+ _rln_register_write_1(sc, RLN_REG_INTSEL, \
+ (sc)->sc_intsel |= (value))
+
+/* End of interrupt signal, used on some newer cards. */
+#define rln_eoi(sc) \
+ (void) _rln_register_read_1(sc, RLN_REG_EOI)
+
diff --git a/sys/dev/ic/rl2subr.c b/sys/dev/ic/rlnsubr.c
index 468c4ff7e66..db6dcae5b91 100644
--- a/sys/dev/ic/rl2subr.c
+++ b/sys/dev/ic/rlnsubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rl2subr.c,v 1.3 1999/07/14 03:53:23 d Exp $ */
+/* $OpenBSD: rlnsubr.c,v 1.1 1999/07/30 13:43:36 d Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public Domain.
*
@@ -33,34 +33,34 @@
#include <machine/bus.h>
#include <machine/intr.h>
-#include <dev/ic/rl2.h>
-#include <dev/ic/rl2var.h>
-#include <dev/ic/rl2reg.h>
-#include <dev/ic/rl2cmd.h>
+#include <dev/ic/rln.h>
+#include <dev/ic/rlnvar.h>
+#include <dev/ic/rlnreg.h>
+#include <dev/ic/rlncmd.h>
-static int rl2_tx_request __P((struct rl2_softc *, u_int16_t));
-static int rl2_tx_end __P((struct rl2_softc *));
+static int rln_tx_request __P((struct rln_softc *, u_int16_t));
+static int rln_tx_end __P((struct rln_softc *));
/*
* Disables or enables interrupts from the card. Returns the old
* interrupt-enable state.
*/
int
-rl2_enable(sc, enable)
- struct rl2_softc * sc;
+rln_enable(sc, enable)
+ struct rln_softc * sc;
int enable;
{
int s;
int was_enabled;
s = splhigh();
- was_enabled = (sc->sc_intsel & RL2_INTSEL_ENABLE) ? 1 : 0;
+ was_enabled = (sc->sc_intsel & RLN_INTSEL_ENABLE) ? 1 : 0;
if (enable != was_enabled) {
if (enable)
- sc->sc_intsel |= RL2_INTSEL_ENABLE;
+ sc->sc_intsel |= RLN_INTSEL_ENABLE;
else
- sc->sc_intsel &=~RL2_INTSEL_ENABLE;
- _rl2_register_write_1(sc, RL2_REG_INTSEL, sc->sc_intsel);
+ sc->sc_intsel &=~RLN_INTSEL_ENABLE;
+ _rln_register_write_1(sc, RLN_REG_INTSEL, sc->sc_intsel);
}
splx(s);
return (was_enabled);
@@ -75,8 +75,8 @@ rl2_enable(sc, enable)
* brought up.
*/
int
-rl2_reset(sc)
- struct rl2_softc * sc;
+rln_reset(sc)
+ struct rln_softc * sc;
{
int s;
int i;
@@ -85,36 +85,36 @@ rl2_reset(sc)
s = splhigh();
dprintf(" R[");
- if (sc->sc_cardtype & (RL2_CTYPE_UISA | RL2_CTYPE_ONE_PIECE))
+ if (sc->sc_cardtype & (RLN_CTYPE_UISA | RLN_CTYPE_ONE_PIECE))
op = 0x04;
- if (rl2_status_read(sc) & RL2_STATUS_WAKEUP) {
- rl2_control_write(sc, op);
- rl2_control_write(sc, op | RL2_CONTROL_RESET);
+ if (rln_status_read(sc) & RLN_STATUS_WAKEUP) {
+ rln_control_write(sc, op);
+ rln_control_write(sc, op | RLN_CONTROL_RESET);
dprintf(" 7ms");
DELAY(7000);
- rl2_control_write(sc, op);
+ rln_control_write(sc, op);
dprintf(" 7ms");
DELAY(7000);
}
- rl2_control_write(sc, op);
- rl2_control_write(sc, op);
- rl2_control_write(sc, op | RL2_CONTROL_BIT3);
+ rln_control_write(sc, op);
+ rln_control_write(sc, op);
+ rln_control_write(sc, op | RLN_CONTROL_BIT3);
dprintf(" 67ms");
DELAY(67000);
- rl2_status_write(sc, 0x00);
- if (sc->sc_cardtype & (RL2_CTYPE_UISA | RL2_CTYPE_ONE_PIECE))
- rl2_control_write(sc, 0x38);
- /* RL2_CONTROL_BIT3 | RL2_CONTROL_RESET | RL2_CONTROL_16BIT */
+ rln_status_write(sc, 0x00);
+ if (sc->sc_cardtype & (RLN_CTYPE_UISA | RLN_CTYPE_ONE_PIECE))
+ rln_control_write(sc, 0x38);
+ /* RLN_CONTROL_BIT3 | RLN_CONTROL_RESET | RLN_CONTROL_16BIT */
else
- rl2_control_write(sc, 0x2c);
- /* RL2_CONTROL_BIT3 | RL2_CONTROL_BIT2 | RL2_CONTROL_16BIT */
+ rln_control_write(sc, 0x2c);
+ /* RLN_CONTROL_BIT3 | RLN_CONTROL_BIT2 | RLN_CONTROL_16BIT */
dprintf(" 67ms");
DELAY(67000);
- rl2_data_write_2(sc, 0xaa55);
- rl2_status_write(sc, 0x5a);
+ rln_data_write_2(sc, 0xaa55);
+ rln_status_write(sc, 0x5a);
splx(s);
- for (i = 0; i < 2000; i++) { /* Proxim says 200 not 2000. */
- if ((status = rl2_status_read(sc)) == 0x5a)
+ for (i = 0; i < 200 *5; i++) { /* Proxim says 200. */
+ if ((status = rln_status_read(sc)) == 0x5a)
break;
DELAY(1000);
}
@@ -122,38 +122,41 @@ rl2_reset(sc)
s = splhigh();
if (status != 0x5a) {
splx(s);
- printf("%s: reset timeout\n", sc->sc_dev.dv_xname);
+ /* Only winge if bus width not yet probed */
+ if (sc->sc_width != 0)
+ printf("%s: reset timeout\n", sc->sc_dev.dv_xname);
dprintf("]=-1");
return (-1);
}
if (sc->sc_width == 8) {
- if (sc->sc_cardtype & (RL2_CTYPE_UISA | RL2_CTYPE_ONE_PIECE))
- rl2_control_write(sc, RL2_CONTROL_BIT3);
+ if (sc->sc_cardtype & (RLN_CTYPE_UISA | RLN_CTYPE_ONE_PIECE))
+ rln_control_write(sc, RLN_CONTROL_BIT3);
else
- rl2_control_write(sc, RL2_CONTROL_BIT3 |
- RL2_CONTROL_BIT2);
- rl2_data_write_1(sc, 0x20);
+ rln_control_write(sc, RLN_CONTROL_BIT3 |
+ RLN_CONTROL_BIT2);
+ rln_data_write_1(sc, 0x20);
} else if (sc->sc_width == 16) {
- rl2_data_write_2(sc, 0x0000);
+ rln_data_write_2(sc, 0x0000);
} else {
- if (rl2_data_read_2(sc) == 0x55aa) {
- rl2_data_write_2(sc, 0x0000);
+ if (rln_data_read_2(sc) == 0x55aa) {
+ rln_data_write_2(sc, 0x0000);
sc->sc_width = 16;
} else {
- if (sc->sc_cardtype & (RL2_CTYPE_UISA |
- RL2_CTYPE_ONE_PIECE))
- rl2_control_write(sc, RL2_CONTROL_BIT3);
+ if (sc->sc_cardtype & (RLN_CTYPE_UISA |
+ RLN_CTYPE_ONE_PIECE))
+ rln_control_write(sc, RLN_CONTROL_BIT3);
else
- rl2_control_write(sc, RL2_CONTROL_BIT3 |
- RL2_CONTROL_BIT2);
- rl2_data_write_1(sc, 0x20);
+ rln_control_write(sc, RLN_CONTROL_BIT3 |
+ RLN_CONTROL_BIT2);
+ rln_data_write_1(sc, 0x20);
sc->sc_width = 8;
}
- printf("%s: %d bit bus\n", sc->sc_dev.dv_xname, sc->sc_width);
+ /* printf("%s: %d bit bus\n", sc->sc_dev.dv_xname,
+ sc->sc_width); */
}
- rl2_status_write(sc, 0x00);
+ rln_status_write(sc, 0x00);
sc->sc_intsel = 0;
- rl2_intsel_write(sc, sc->sc_irq);
+ rln_intsel_write(sc, sc->sc_irq);
splx(s);
dprintf("]");
return (0);
@@ -161,50 +164,50 @@ rl2_reset(sc)
/*
* Sets the new 'wakeup' state. Returns the old wakeup state.
- * The special state value RL2_WAKEUP_SET should be used to wake the
+ * The special state value RLN_WAKEUP_SET should be used to wake the
* card up. The card can be partially put to sleep (presumably to save
* power) by sending it the 'Standby' command.
*/
u_int8_t
-rl2_wakeup(sc, wnew)
- struct rl2_softc * sc;
+rln_wakeup(sc, wnew)
+ struct rln_softc * sc;
u_int8_t wnew;
{
u_int8_t wold, s;
int i;
/* Save what the last-written values were. */
- wold = (sc->sc_status & RL2_STATUS_WAKEUP) |
- (sc->sc_control & RL2_CONTROL_RESET);
+ wold = (sc->sc_status & RLN_STATUS_WAKEUP) |
+ (sc->sc_control & RLN_CONTROL_RESET);
- if (wnew == RL2_WAKEUP_SET) {
+ if (wnew == RLN_WAKEUP_SET) {
/* SetWakeupBit() */
dprintf(" Ws[");
- rl2_status_set(sc, RL2_STATUS_WAKEUP);
+ rln_status_set(sc, RLN_STATUS_WAKEUP);
if (0/*LLDInactivityTimeOut &&
- (sc->sc_cardtype & RL2_CTYPE_OEM)*/) {
+ (sc->sc_cardtype & RLN_CTYPE_OEM)*/) {
dprintf (" 167ms");
DELAY(167000);
} else {
dprintf (" .1ms");
DELAY(100);
}
- s = rl2_status_read(sc);
- rl2_control_set(sc, RL2_CONTROL_RESET);
- if ((s & RL2_STATUS_WAKEUP) != 0)
+ s = rln_status_read(sc);
+ rln_control_set(sc, RLN_CONTROL_RESET);
+ if ((s & RLN_STATUS_WAKEUP) != 0)
for (i = 0; i < 9; i++) {
dprintf(" 2ms");
DELAY(2000);
- rl2_status_set(sc, RL2_STATUS_WAKEUP);
+ rln_status_set(sc, RLN_STATUS_WAKEUP);
}
dprintf("]");
} else {
/* ClearWakeupBit() */
dprintf(" Wc[");
- if ((wnew & RL2_STATUS_WAKEUP) == 0)
- rl2_status_clear(sc, RL2_STATUS_WAKEUP);
- if ((wnew & RL2_CONTROL_RESET) == 0)
- rl2_control_clear(sc, RL2_CONTROL_RESET);
+ if ((wnew & RLN_STATUS_WAKEUP) == 0)
+ rln_status_clear(sc, RLN_STATUS_WAKEUP);
+ if ((wnew & RLN_CONTROL_RESET) == 0)
+ rln_control_clear(sc, RLN_CONTROL_RESET);
dprintf("]");
}
return (wold);
@@ -215,11 +218,11 @@ rl2_wakeup(sc, wnew)
* to the card. 'len' is the expected length of the message is needed.
* Returns: 0 on success
* 1 on timeout
- * 2 on NAK (card busy, and will need a rl2_clear_nak() after 100ms)
+ * 2 on NAK (card busy, and will need a rln_clear_nak() after 100ms)
*/
static int
-rl2_tx_request(sc, len)
- struct rl2_softc * sc;
+rln_tx_request(sc, len)
+ struct rln_softc * sc;
u_int16_t len;
{
/* TxRequest() */
@@ -228,57 +231,57 @@ rl2_tx_request(sc, len)
u_int8_t status;
/* u_int8_t w; */
- /* w = rl2_wakeup(sc, RL2_WAKEUP_SET); */
+ /* w = rln_wakeup(sc, RLN_WAKEUP_SET); */
dprintf(" Tr[");
if (sc->sc_width == 16) {
- rl2_status_tx_write(sc, RL2_STATUS_TX_HILEN_AVAIL);
- rl2_data_write_2(sc, len);
- rl2_status_tx_int(sc);
+ rln_status_tx_write(sc, RLN_STATUS_TX_HILEN_AVAIL);
+ rln_data_write_2(sc, len);
+ rln_status_tx_int(sc);
s = spl0();
for (i = 0; i < 600; i++) {
- status = rl2_status_tx_read(sc);
- if (status == RL2_STATUS_TX_HILEN_ACCEPT ||
- status == RL2_STATUS_TX_ERROR)
+ status = rln_status_tx_read(sc);
+ if (status == RLN_STATUS_TX_HILEN_ACCEPT ||
+ status == RLN_STATUS_TX_ERROR)
break;
DELAY(1000);
}
splx(s);
dprintf(" %dms", i);
- if (status == RL2_STATUS_TX_HILEN_ACCEPT)
+ if (status == RLN_STATUS_TX_HILEN_ACCEPT)
goto success;
- if (status == RL2_STATUS_TX_ERROR)
+ if (status == RLN_STATUS_TX_ERROR)
goto error;
} else if (sc->sc_width == 8) {
- rl2_status_tx_write(sc, RL2_STATUS_TX_LOLEN_AVAIL);
- rl2_data_write_1(sc, len & 0xff);
- rl2_status_tx_int(sc);
+ rln_status_tx_write(sc, RLN_STATUS_TX_LOLEN_AVAIL);
+ rln_data_write_1(sc, len & 0xff);
+ rln_status_tx_int(sc);
s = spl0();
for (i = 0; i < 6800; i++) {
- status = rl2_status_tx_read(sc);
- if (status == RL2_STATUS_TX_LOLEN_ACCEPT)
+ status = rln_status_tx_read(sc);
+ if (status == RLN_STATUS_TX_LOLEN_ACCEPT)
break;
DELAY(1000);
}
splx(s);
dprintf(" %dms", i);
- if (status == RL2_STATUS_TX_LOLEN_ACCEPT) {
- rl2_data_write_1(sc, (len >> 8) & 0xff);
- rl2_status_tx_write(sc, RL2_STATUS_TX_HILEN_AVAIL);
+ if (status == RLN_STATUS_TX_LOLEN_ACCEPT) {
+ rln_data_write_1(sc, (len >> 8) & 0xff);
+ rln_status_tx_write(sc, RLN_STATUS_TX_HILEN_AVAIL);
s = spl0();
for (i = 0; i < 600; i++) {
- status = rl2_status_tx_read(sc);
- if (status == RL2_STATUS_TX_HILEN_ACCEPT ||
- status == RL2_STATUS_TX_ERROR)
+ status = rln_status_tx_read(sc);
+ if (status == RLN_STATUS_TX_HILEN_ACCEPT ||
+ status == RLN_STATUS_TX_ERROR)
break;
DELAY(1000);
}
splx(s);
dprintf(" %dms", i);
- if (status == RL2_STATUS_TX_HILEN_ACCEPT)
+ if (status == RLN_STATUS_TX_HILEN_ACCEPT)
goto success;
- if (status == RL2_STATUS_TX_ERROR)
+ if (status == RLN_STATUS_TX_ERROR)
goto error;
}
}
@@ -301,7 +304,7 @@ error:
return (2);
success:
- /* rl2_wakeup(sc, w); */
+ /* rln_wakeup(sc, w); */
dprintf("]=0");
return (0);
}
@@ -313,8 +316,8 @@ success:
* non-zero on failure (card will need reset)
*/
static int
-rl2_tx_end(sc)
- struct rl2_softc * sc;
+rln_tx_end(sc)
+ struct rln_softc * sc;
{
/* EndOfTx() */
int i;
@@ -324,20 +327,20 @@ rl2_tx_end(sc)
dprintf(" Te[");
s = spl0();
for (i = 0; i < 600; i++) {
- status = rl2_status_tx_read(sc);
- if (status == RL2_STATUS_TX_XFR_COMPLETE)
+ status = rln_status_tx_read(sc);
+ if (status == RLN_STATUS_TX_XFR_COMPLETE)
break;
DELAY(1000);
}
splx(s);
- if (status == RL2_STATUS_TX_XFR_COMPLETE) {
- rl2_status_tx_write(sc, RL2_STATUS_TX_IDLE);
+ if (status == RLN_STATUS_TX_XFR_COMPLETE) {
+ rln_status_tx_write(sc, RLN_STATUS_TX_IDLE);
dprintf("]=0");
return (0);
} else {
printf("%s: tx cmd failed (%02x)\n", sc->sc_dev.dv_xname,
status);
- rl2_need_reset(sc);
+ rln_need_reset(sc);
dprintf("]=-1");
return (-1);
}
@@ -350,8 +353,8 @@ rl2_tx_end(sc)
*/
int
-rl2_rx_request(sc, timeo)
- struct rl2_softc * sc;
+rln_rx_request(sc, timeo)
+ struct rln_softc * sc;
int timeo; /* milliseconds */
{
/* RxRequest */
@@ -362,50 +365,50 @@ rl2_rx_request(sc, timeo)
u_int8_t hi, lo;
dprintf(" Rr[");
- status = rl2_status_rx_read(sc);
+ status = rln_status_rx_read(sc);
/* Short wait for states 1|5|6. */
s = spl0();
for (i = 0; i < timeo; i++) {
- if (status == RL2_STATUS_RX_LOLEN_AVAIL ||
- status == RL2_STATUS_RX_HILEN_AVAIL ||
- status == RL2_STATUS_RX_ERROR)
+ if (status == RLN_STATUS_RX_LOLEN_AVAIL ||
+ status == RLN_STATUS_RX_HILEN_AVAIL ||
+ status == RLN_STATUS_RX_ERROR)
break;
DELAY(1000);
- status = rl2_status_rx_read(sc);
+ status = rln_status_rx_read(sc);
}
splx(s);
dprintf(" (%dms)",i);
if (sc->sc_width == 16) {
- if (status != RL2_STATUS_RX_HILEN_AVAIL)
+ if (status != RLN_STATUS_RX_HILEN_AVAIL)
goto badstatus_quiet;
/* Read 2 octets. */
- len = rl2_data_read_2(sc);
+ len = rln_data_read_2(sc);
} else if (sc->sc_width == 8) {
- if (status != RL2_STATUS_RX_LOLEN_AVAIL)
+ if (status != RLN_STATUS_RX_LOLEN_AVAIL)
goto badstatus_quiet;
/* Read low octet. */
- lo = rl2_data_read_1(sc);
- rl2_status_rx_write(sc, RL2_STATUS_RX_LOLEN_ACCEPT);
- rl2_status_rx_int(sc);
+ lo = rln_data_read_1(sc);
+ rln_status_rx_write(sc, RLN_STATUS_RX_LOLEN_ACCEPT);
+ rln_status_rx_int(sc);
s = spl0();
for (i = 0; i < 600; i++) {
- status = rl2_status_rx_read(sc);
- if (status == RL2_STATUS_RX_HILEN_AVAIL)
+ status = rln_status_rx_read(sc);
+ if (status == RLN_STATUS_RX_HILEN_AVAIL)
break;
DELAY(1000);
}
splx(s);
- if (status != RL2_STATUS_RX_HILEN_AVAIL)
+ if (status != RLN_STATUS_RX_HILEN_AVAIL)
goto badstatus;
/* Read high octet. */
- hi = rl2_data_read_1(sc);
+ hi = rln_data_read_1(sc);
len = lo | (hi << 8);
}
#ifdef DIAGNOSTIC
else
- panic("rl2: bus width %d", sc->sc_width);
+ panic("rln: bus width %d", sc->sc_width);
#endif
dprintf(" len=%d]", len);
@@ -415,7 +418,7 @@ badstatus:
printf("%s: rx_request timed out, status %02x\n",
sc->sc_dev.dv_xname, status);
badstatus_quiet:
- if (status == RL2_STATUS_RX_ERROR)
+ if (status == RLN_STATUS_RX_ERROR)
printf("%s: rx protocol error (nak)\n", sc->sc_dev.dv_xname);
dprintf("]");
return (-1);
@@ -423,11 +426,11 @@ badstatus_quiet:
/* Performs part of the second (transfer) stage of receiving a data message. */
void
-rl2_rx_pdata(sc, buf, len, pd)
- struct rl2_softc * sc;
+rln_rx_pdata(sc, buf, len, pd)
+ struct rln_softc * sc;
void * buf;
int len;
- struct rl2_pdata * pd;
+ struct rln_pdata * pd;
{
char * data = (char *)buf;
@@ -441,8 +444,8 @@ rl2_rx_pdata(sc, buf, len, pd)
if (sc->sc_width == 16) {
/* Round down to the closest even multiple. */
- rl2_data_read_multi_2(sc, data, len / 2);
-#ifdef RL2DEBUG_REG
+ rln_data_read_multi_2(sc, data, len / 2);
+#ifdef RLNDEBUG_REG
dprintf(" D>");
dprinthex(data, len);
#endif
@@ -453,25 +456,25 @@ rl2_rx_pdata(sc, buf, len, pd)
u_int8_t b[2];
} u;
- u.w = rl2_data_read_2(sc);
+ u.w = rln_data_read_2(sc);
data[len - 1] = u.b[0];
pd->p_data = u.b[1];
pd->p_nremain = 1;
-#ifdef RL2DEBUG_REG
+#ifdef RLNDEBUG_REG
dprintf(" D>{%02x%02x}", u.b[0], u.b[1]);
#endif
}
} else if (sc->sc_width == 8) {
- rl2_data_read_multi_1(sc, data, len);
-#ifdef RL2DEBUG_REG
+ rln_data_read_multi_1(sc, data, len);
+#ifdef RLNDEBUG_REG
dprintf(" D>");
dprinthex(data, len);
#endif
if (len & 1) {
/* Must read multiples of two. */
- pd->p_data = rl2_data_read_1(sc);
+ pd->p_data = rln_data_read_1(sc);
pd->p_nremain = 1;
-#ifdef RL2DEBUG_REG
+#ifdef RLNDEBUG_REG
dprintf(" D>{%02x}", pd->p_data);
#endif
}
@@ -480,38 +483,38 @@ rl2_rx_pdata(sc, buf, len, pd)
}
int
-rl2_rx_data(sc, buf, len)
- struct rl2_softc * sc;
+rln_rx_data(sc, buf, len)
+ struct rln_softc * sc;
void * buf;
int len;
{
/* RxData() */
- struct rl2_pdata pd = { 0, 0 };
+ struct rln_pdata pd = { 0, 0 };
int s;
int i;
u_int8_t status;
dprintf(" Rd[");
- rl2_status_rx_write(sc, RL2_STATUS_RX_HILEN_ACCEPT);
- rl2_status_rx_int(sc);
+ rln_status_rx_write(sc, RLN_STATUS_RX_HILEN_ACCEPT);
+ rln_status_rx_int(sc);
s = spl0();
for (i = 0; i < 600; i++) {
- status = rl2_status_rx_read(sc);
- if (status == RL2_STATUS_RX_XFR)
+ status = rln_status_rx_read(sc);
+ if (status == RLN_STATUS_RX_XFR)
break;
DELAY(1000);
}
splx(s);
- if (status != RL2_STATUS_RX_XFR) {
+ if (status != RLN_STATUS_RX_XFR) {
dprintf("]=-1");
return (-1);
}
- rl2_rx_pdata(sc, buf, len, &pd);
+ rln_rx_pdata(sc, buf, len, &pd);
#ifdef DIAGNOSTIC
/* We should have nothing left over. */
if (pd.p_nremain || len & 1)
- panic("rl2_rx_data: leftover");
+ panic("rln_rx_data: leftover");
#endif
dprintf("]=0");
@@ -519,27 +522,27 @@ rl2_rx_data(sc, buf, len)
}
void
-rl2_rx_end(sc)
- struct rl2_softc * sc;
+rln_rx_end(sc)
+ struct rln_softc * sc;
{
/* EndOfRx() */
dprintf(" Re[");
- rl2_status_rx_write(sc, RL2_STATUS_RX_XFR_COMPLETE);
- rl2_status_rx_int(sc);
- /* rl2_wakeup(sc, 0); */
+ rln_status_rx_write(sc, RLN_STATUS_RX_XFR_COMPLETE);
+ rln_status_rx_int(sc);
+ /* rln_wakeup(sc, 0); */
dprintf("]");
}
/* Clear a transmission NAK from the card. */
void
-rl2_clear_nak(sc)
- struct rl2_softc * sc;
+rln_clear_nak(sc)
+ struct rln_softc * sc;
{
/* ClearNAK() */
- rl2_status_tx_write(sc, RL2_STATUS_CLRNAK);
- rl2_status_tx_int(sc);
+ rln_status_tx_write(sc, RLN_STATUS_CLRNAK);
+ rln_status_tx_int(sc);
}
/*
@@ -549,44 +552,44 @@ rl2_clear_nak(sc)
* 0: success
*/
int
-rl2_msg_tx_start(sc, buf, pktlen, state)
- struct rl2_softc * sc;
+rln_msg_tx_start(sc, buf, pktlen, state)
+ struct rln_softc * sc;
void * buf;
int pktlen;
- struct rl2_msg_tx_state * state;
+ struct rln_msg_tx_state * state;
{
- struct rl2_mm_cmd * cmd = (struct rl2_mm_cmd *)buf;
+ struct rln_mm_cmd * cmd = (struct rln_mm_cmd *)buf;
int ret;
- state->ien = rl2_enable(sc, 0);
+ state->ien = rln_enable(sc, 0);
state->pd.p_nremain = 0;
if (!(cmd->cmd_letter == 'A' && cmd->cmd_fn == 6)) /* Standby. */
- state->w = rl2_wakeup(sc, RL2_WAKEUP_SET);
+ state->w = rln_wakeup(sc, RLN_WAKEUP_SET);
else
- state->w = RL2_WAKEUP_NOCHANGE;
+ state->w = RLN_WAKEUP_NOCHANGE;
- ret = rl2_tx_request(sc, pktlen);
+ ret = rln_tx_request(sc, pktlen);
if (ret == 2) {
- rl2_clear_nak(sc);
- if (sc->sc_cardtype & RL2_CTYPE_OEM)
- rl2_need_reset(sc);
+ rln_clear_nak(sc);
+ if (sc->sc_cardtype & RLN_CTYPE_OEM)
+ rln_need_reset(sc);
ret = 2;
}
else if (ret == 1) {
/* Timeout. */
- rl2_status_tx_write(sc, RL2_STATUS_TX_XFR);
+ rln_status_tx_write(sc, RLN_STATUS_TX_XFR);
ret = -1;
}
return (ret);
}
void
-rl2_msg_tx_data(sc, buf, len, state)
- struct rl2_softc * sc;
+rln_msg_tx_data(sc, buf, len, state)
+ struct rln_softc * sc;
void * buf;
u_int16_t len;
- struct rl2_msg_tx_state * state;
+ struct rln_msg_tx_state * state;
{
char * data = (char *)buf;
@@ -603,28 +606,28 @@ rl2_msg_tx_data(sc, buf, len, state)
len--;
} else
u.b[1] = '\0';
-#ifdef RL2DEBUG_REG
+#ifdef RLNDEBUG_REG
dprintf(" D<%02x%02x", u.b[0], u.b[1]);
#endif
- rl2_data_write_2(sc, u.w);
+ rln_data_write_2(sc, u.w);
state->pd.p_nremain = 0;
}
if (len) {
if (sc->sc_width == 16) {
if (len >= 2)
- rl2_data_write_multi_2(sc, buf, len / 2);
+ rln_data_write_multi_2(sc, buf, len / 2);
if (len & 1) {
state->pd.p_nremain = 1;
state->pd.p_data = data[len - 1];
}
} else if (sc->sc_width == 8)
- rl2_data_write_multi_1(sc, buf, len);
+ rln_data_write_multi_1(sc, buf, len);
#ifdef DIAGNOSTIC
else
- panic("rl2_msg_tx_data width %d", sc->sc_width);
+ panic("rln_msg_tx_data width %d", sc->sc_width);
#endif
-#ifdef RL2DEBUG_REG
+#ifdef RLNDEBUG_REG
dprintf(" D<");
dprinthex(data, len);
#endif
@@ -633,39 +636,39 @@ rl2_msg_tx_data(sc, buf, len, state)
int
-rl2_msg_tx_end(sc, state)
- struct rl2_softc * sc;
- struct rl2_msg_tx_state * state;
+rln_msg_tx_end(sc, state)
+ struct rln_softc * sc;
+ struct rln_msg_tx_state * state;
{
int ret;
/* Flush the tx buffer. */
if (state->pd.p_nremain)
- rl2_msg_tx_data(sc, NULL, 0, state);
+ rln_msg_tx_data(sc, NULL, 0, state);
#ifdef DIAGNOSTIC
if (state->pd.p_nremain)
- panic("rl2_msg_tx_end remain %d", state->pd.p_nremain);
+ panic("rln_msg_tx_end remain %d", state->pd.p_nremain);
#endif
- ret = rl2_tx_end(sc);
+ ret = rln_tx_end(sc);
if (sc->sc_arpcom.ac_if.if_flags & IFF_OACTIVE)
- state->w = RL2_WAKEUP_NOCHANGE;
- rl2_wakeup(sc, state->w);
- rl2_enable(sc, state->ien);
+ state->w = RLN_WAKEUP_NOCHANGE;
+ rln_wakeup(sc, state->w);
+ rln_enable(sc, state->ien);
return (ret);
}
/* Return the next unique sequence number to use for a transmitted command */
u_int8_t
-rl2_newseq(sc)
- struct rl2_softc * sc;
+rln_newseq(sc)
+ struct rln_softc * sc;
{
int s;
u_int8_t seq;
s = splhigh();
seq = sc->sc_pktseq++;
- if (sc->sc_pktseq > RL2_MAXSEQ)
+ if (sc->sc_pktseq > RLN_MAXSEQ)
sc->sc_pktseq = 0;
splx(s);
return (seq);
@@ -676,60 +679,60 @@ rl2_newseq(sc)
* message from the card. Each transmitted message has a sequence
* number, and corresponding reply messages have the same sequence
* number. We use the sequence numbers to index the mailboxes so
- * that rl2softintr() can signal this routine when it has serviced
+ * that rlnsoftintr() can signal this routine when it has serviced
* and correctly received a response.
*/
int
-rl2_msg_txrx(sc, tx, txlen, rx, rxlen)
- struct rl2_softc * sc;
+rln_msg_txrx(sc, tx, txlen, rx, rxlen)
+ struct rln_softc * sc;
void * tx;
int txlen;
void * rx;
int rxlen;
{
- struct rl2_mm_cmd * txc = (struct rl2_mm_cmd *)tx;
- struct rl2_mm_cmd * rxc = (struct rl2_mm_cmd *)rx;
- struct rl2_msg_tx_state state;
+ struct rln_mm_cmd * txc = (struct rln_mm_cmd *)tx;
+ struct rln_mm_cmd * rxc = (struct rln_mm_cmd *)rx;
+ struct rln_msg_tx_state state;
int ien;
int ret;
#ifdef DIAGNOSTIC
if (rx != NULL && rxlen < sizeof *rxc)
- panic("rl2_msg_txrx");
+ panic("rln_msg_txrx");
#endif
- txc->cmd_seq = rl2_newseq(sc);
+ txc->cmd_seq = rln_newseq(sc);
-#ifdef RL2DUMP
+#ifdef RLNDUMP
printf("%s: send %c%d seq %d data ", sc->sc_dev.dv_xname,
txc->cmd_letter, txc->cmd_fn, txc->cmd_seq);
- RL2DUMPHEX(txc, sizeof *txc);
+ RLNDUMPHEX(txc, sizeof *txc);
printf(":");
- RL2DUMPHEX((char *)tx + sizeof *txc, txlen - sizeof *txc);
+ RLNDUMPHEX((char *)tx + sizeof *txc, txlen - sizeof *txc);
printf("\n");
#endif
if (rx != NULL)
- if (rl2_mbox_create(sc, txc->cmd_seq, rx, rxlen) < 0)
+ if (rln_mbox_create(sc, txc->cmd_seq, rx, rxlen) < 0)
/* Mailbox collision. */
return (-1);
/* Start the transfer. */
- if ((ret = rl2_msg_tx_start(sc, tx, txlen, &state))) {
+ if ((ret = rln_msg_tx_start(sc, tx, txlen, &state))) {
if (rx != NULL)
- rl2_mbox_wait(sc, txc->cmd_seq, -1);
+ rln_mbox_wait(sc, txc->cmd_seq, -1);
return (ret);
}
/* Always send an even number of octets. */
- rl2_msg_tx_data(sc, tx, (txlen + 1) & ~1, &state);
+ rln_msg_tx_data(sc, tx, (txlen + 1) & ~1, &state);
/* End the transmission. */
- if ((ret = rl2_msg_tx_end(sc, &state))) {
+ if ((ret = rln_msg_tx_end(sc, &state))) {
/* Destroy mailbox. */
if (rx != NULL)
- rl2_mbox_wait(sc, txc->cmd_seq, -1);
+ rln_mbox_wait(sc, txc->cmd_seq, -1);
return (ret);
}
@@ -738,23 +741,23 @@ rl2_msg_txrx(sc, tx, txlen, rx, rxlen)
return (0);
/* Enable interrupts if not already. */
- ien = rl2_enable(sc, 1);
+ ien = rln_enable(sc, 1);
/* Wait for the reply message. */
- if (rl2_mbox_wait(sc, txc->cmd_seq, 2000) <= 0) {
+ if (rln_mbox_wait(sc, txc->cmd_seq, 2000) <= 0) {
printf("%s: lost message %c%d seq %d\n", sc->sc_dev.dv_xname,
txc->cmd_letter, txc->cmd_fn, txc->cmd_seq);
- rl2_enable(sc, ien);
+ rln_enable(sc, ien);
return (-1);
}
- rl2_enable(sc, ien);
+ rln_enable(sc, ien);
-#ifdef RL2DUMP
+#ifdef RLNDUMP
printf("%s: recv %c%d seq %d data ", sc->sc_dev.dv_xname,
rxc->cmd_letter, rxc->cmd_fn, rxc->cmd_seq);
- RL2DUMPHEX(rxc, sizeof *rxc);
+ RLNDUMPHEX(rxc, sizeof *rxc);
printf(":");
- RL2DUMPHEX(((char *)rx) + sizeof *rxc, rxlen - sizeof *rxc);
+ RLNDUMPHEX(((char *)rx) + sizeof *rxc, rxlen - sizeof *rxc);
printf("\n");
#endif
@@ -781,24 +784,24 @@ rl2_msg_txrx(sc, tx, txlen, rx, rxlen)
/* Create a mailbox for filling. */
int
-rl2_mbox_create(sc, seq, buf, len)
- struct rl2_softc * sc;
+rln_mbox_create(sc, seq, buf, len)
+ struct rln_softc * sc;
u_int8_t seq;
void * buf;
size_t len;
{
int s;
- struct rl2_mbox * mb = &sc->sc_mbox[seq];
+ struct rln_mbox * mb = &sc->sc_mbox[seq];
dprintf(" <create %d", seq);
#ifdef DIAGNOSTIC
- if (seq > RL2_NMBOX)
+ if (seq > RLN_NMBOX)
panic("mbox create");
#endif
s = splhigh();
- if (mb->mb_state != RL2MBOX_VOID) {
+ if (mb->mb_state != RLNMBOX_VOID) {
#ifdef DIAGNOSTIC
printf("mbox collision");
#endif
@@ -808,7 +811,7 @@ rl2_mbox_create(sc, seq, buf, len)
mb->mb_buf = buf;
mb->mb_len = len;
mb->mb_actlen = 0;
- mb->mb_state = RL2MBOX_EMPTY;
+ mb->mb_state = RLNMBOX_EMPTY;
dprintf(" empty>");
splx(s);
return (0);
@@ -817,42 +820,42 @@ rl2_mbox_create(sc, seq, buf, len)
/* Wait for a mailbox to be filled. */
int
-rl2_mbox_wait(sc, seq, timeo)
- struct rl2_softc * sc;
+rln_mbox_wait(sc, seq, timeo)
+ struct rln_softc * sc;
u_int8_t seq;
int timeo;
{
int i;
int s;
int ret;
- volatile struct rl2_mbox * mb = &sc->sc_mbox[seq];
+ volatile struct rln_mbox * mb = &sc->sc_mbox[seq];
extern int cold;
dprintf(" <wait %d", seq);
#ifdef DIAGNOSTIC
- if (seq > RL2_NMBOX)
+ if (seq > RLN_NMBOX)
panic("mbox wait");
#endif
if (cold) {
/* Autoconfiguration - spin at spl0. */
s = spl0();
i = 0;
- while (mb->mb_state == RL2MBOX_EMPTY && i < timeo) {
+ while (mb->mb_state == RLNMBOX_EMPTY && i < timeo) {
DELAY(1000);
i++;
}
if (i)
dprintf(" %dms", i);
- while (mb->mb_state == RL2MBOX_FILLING)
+ while (mb->mb_state == RLNMBOX_FILLING)
;
splx(s);
} else {
- tsleep((void *)mb, PRIBIO, "rl2mbox", hz * timeo / 1000);
- if (mb->mb_state == RL2MBOX_FILLING) {
+ tsleep((void *)mb, PRIBIO, "rlnmbox", hz * timeo / 1000);
+ if (mb->mb_state == RLNMBOX_FILLING) {
/* Must wait until filled. */
s = spl0();
- while (mb->mb_state == RL2MBOX_FILLING)
+ while (mb->mb_state == RLNMBOX_FILLING)
;
splx(s);
}
@@ -860,11 +863,11 @@ rl2_mbox_wait(sc, seq, timeo)
s = splhigh();
#ifdef DIAGNOSTIC
- if (mb->mb_state != RL2MBOX_EMPTY && mb->mb_state != RL2MBOX_FILLED)
+ if (mb->mb_state != RLNMBOX_EMPTY && mb->mb_state != RLNMBOX_FILLED)
panic("mbox wait %d", mb->mb_state);
#endif
ret = mb->mb_actlen;
- mb->mb_state = RL2MBOX_VOID;
+ mb->mb_state = RLNMBOX_VOID;
dprintf(" void>=%d", ret);
splx(s);
return (ret);
@@ -872,29 +875,29 @@ rl2_mbox_wait(sc, seq, timeo)
/* Lock a mailbox for filling. */
int
-rl2_mbox_lock(sc, seq, bufp, lenp)
- struct rl2_softc * sc;
+rln_mbox_lock(sc, seq, bufp, lenp)
+ struct rln_softc * sc;
u_int8_t seq;
void ** bufp;
size_t * lenp;
{
int s;
- struct rl2_mbox * mb = &sc->sc_mbox[seq];
+ struct rln_mbox * mb = &sc->sc_mbox[seq];
dprintf(" <lock %d", seq);
s = splhigh();
#ifdef DIAGNOSTIC
- if (seq > RL2_NMBOX)
+ if (seq > RLN_NMBOX)
panic("mbox lock");
#endif
- if (mb->mb_state != RL2MBOX_EMPTY) {
+ if (mb->mb_state != RLNMBOX_EMPTY) {
splx(s);
dprintf(" ?>");
return (-1);
}
- mb->mb_state = RL2MBOX_FILLING;
+ mb->mb_state = RLNMBOX_FILLING;
dprintf(" filling>");
*bufp = mb->mb_buf;
*lenp = mb->mb_len;
@@ -905,24 +908,24 @@ rl2_mbox_lock(sc, seq, bufp, lenp)
/* Unlock a mailbox and inform the waiter of the actual number of octets. */
void
-rl2_mbox_unlock(sc, seq, actlen)
- struct rl2_softc * sc;
+rln_mbox_unlock(sc, seq, actlen)
+ struct rln_softc * sc;
u_int8_t seq;
size_t actlen;
{
int s;
- struct rl2_mbox * mb = &sc->sc_mbox[seq];
+ struct rln_mbox * mb = &sc->sc_mbox[seq];
dprintf(" <unlock %d", seq);
s = splhigh();
#ifdef DIAGNOSTIC
- if (seq > RL2_NMBOX)
+ if (seq > RLN_NMBOX)
panic("mbox unlock seq");
- if (mb->mb_state != RL2MBOX_FILLING)
+ if (mb->mb_state != RLNMBOX_FILLING)
panic("mbox unlock");
#endif
- mb->mb_state = RL2MBOX_FILLED;
+ mb->mb_state = RLNMBOX_FILLED;
dprintf(" filled>");
mb->mb_actlen = actlen;
wakeup(mb);
diff --git a/sys/dev/ic/rlnvar.h b/sys/dev/ic/rlnvar.h
new file mode 100644
index 00000000000..2e9dae49329
--- /dev/null
+++ b/sys/dev/ic/rlnvar.h
@@ -0,0 +1,141 @@
+/* $OpenBSD: rlnvar.h,v 1.1 1999/07/30 13:43:36 d Exp $ */
+/*
+ * David Leonard <d@openbsd.org>, 1999. Public domain.
+ *
+ * Proxim RangeLAN2 soft state copy.
+ */
+
+/*
+ * Mailboxes are used to communicate card-initiated messages
+ * from the interrupt handler to other kernel threads.
+ */
+struct rln_mbox {
+ void * mb_buf; /* Message buffer */
+ size_t mb_len; /* Message buffer size */
+ size_t mb_actlen; /* Actual message size */
+ u_int8_t mb_state; /* Mailbox state */
+#define RLNMBOX_VOID 0
+#define RLNMBOX_EMPTY 1
+#define RLNMBOX_FILLING 2
+#define RLNMBOX_FILLED 3
+};
+
+#define RLN_NMBOX 0x7c /* Same as max msg seq number */
+
+/* Soft state */
+struct rln_softc {
+ struct device sc_dev;
+ void *sc_ih; /* Interrupt handler */
+ struct arpcom sc_arpcom; /* Ethernet common part */
+ bus_space_tag_t sc_iot; /* Bus cookie */
+ bus_space_handle_t sc_ioh; /* Bus i/o handle */
+
+ u_int8_t sc_width; /* Bus transfer width */
+ u_int8_t sc_irq; /* IRQ for card */
+
+ u_int16_t sc_cardtype; /* Set from config flags */
+#define RLN_CTYPE_OEM 0x01
+#define RLN_CTYPE_UISA 0x02
+#define RLN_CTYPE_ONE_PIECE 0x04
+
+ u_int8_t sc_intsel; /* Copy of INTSEL */
+ u_int8_t sc_status; /* Copy of STATUS */
+ u_int8_t sc_control; /* Copy of CONTROL */
+#ifdef RLNDEBUG_REG
+ u_int8_t dbg_oreg[8]; /* Last reg value written */
+#endif
+
+ u_int8_t sc_pktseq; /* Card message seq no */
+ u_int8_t sc_txseq; /* Tx packet seq no */
+
+ u_int16_t sc_state; /* Soft state. */
+#define RLN_STATE_SYNC 0x0001 /* Card is synchronised */
+#define RLN_STATE_NEEDINIT 0x0002 /* Card needs reset+init */
+#define RLN_STATE_PROMISC 0x0004 /* Receive all packets */
+
+ struct rln_mbox sc_mbox[0x80]; /* Per-message mailboxes */
+ struct rln_param sc_param; /* User controlled parameters */
+};
+
+#define rln_need_reset(sc) \
+ (sc)->sc_state |= RLN_STATE_NEEDINIT
+
+/* Structure used to hold partial read state for rln_rx_pdata() */
+struct rln_pdata {
+ u_int8_t p_data; /* extra data read but not consumed */
+ int p_nremain; /* size of unconsumed data */
+};
+#define RLN_PDATA_INIT {0,0}
+
+/* Structure used to hold partial transmit state for rln_msg_tx_*() */
+struct rln_msg_tx_state {
+ int ien; /* saved interrupt state */
+ u_int8_t w; /* saved wakup state */
+ struct rln_pdata pd; /* saved partial write state */
+};
+
+struct rln_mm_cmd; /* fwd decl */
+
+#define RLN_WAKEUP_SET 0xff
+#define RLN_WAKEUP_NOCHANGE (0x80|0x10)
+
+void rlnconfig __P((struct rln_softc *));
+int rlnintr __P((void *));
+void rlnread __P((struct rln_softc *, struct rln_mm_cmd *, int));
+int rln_enable __P((struct rln_softc *, int));
+int rln_reset __P((struct rln_softc *));
+u_int8_t rln_wakeup __P((struct rln_softc *, u_int8_t));
+int rln_rx_request __P((struct rln_softc *, int));
+int rln_rx_data __P((struct rln_softc *, void *, int));
+void rln_rx_pdata __P((struct rln_softc *, void *, int,
+ struct rln_pdata *));
+void rln_rx_end __P((struct rln_softc *));
+void rln_clear_nak __P((struct rln_softc *));
+u_int8_t rln_newseq __P((struct rln_softc *));
+
+void rln_msg_tx_data __P((struct rln_softc *, void *, u_int16_t,
+ struct rln_msg_tx_state *));
+int rln_msg_tx_start __P((struct rln_softc *, void *, int,
+ struct rln_msg_tx_state *));
+int rln_msg_tx_end __P((struct rln_softc *,
+ struct rln_msg_tx_state *));
+int rln_msg_txrx __P((struct rln_softc *, void *, int,
+ void *, int));
+
+int rln_mbox_create __P((struct rln_softc *, u_int8_t, void *,
+ size_t));
+int rln_mbox_wait __P((struct rln_softc *, u_int8_t, int));
+int rln_mbox_lock __P((struct rln_softc *, u_int8_t, void **,
+ size_t*));
+void rln_mbox_unlock __P((struct rln_softc *, u_int8_t, size_t));
+
+/* debug all card operations */
+#ifdef RLNDEBUG
+#define dprintf(fmt, args...) printf(fmt , ## args)
+ /* log(LOG_DEBUG, fmt , ## args) */
+#define dprinthex(buf, len) do { \
+ unsigned char *_b = (unsigned char*)(buf); \
+ int _i, _l=(len); \
+ printf("{"); \
+ for(_i = 0; _i < _l; _i++) { \
+ printf("%02x", _b[_i]); \
+ if (_i % 4 == 3 && _i != _l - 1) \
+ printf(","); \
+ } \
+ printf("}"); \
+} while (0)
+#else
+#define dprintf(fmt, args...) /* nothing */
+#define dprinthex(buf, len) /* nothing */
+#endif
+
+/* debug messages to/from card. prints 4-octet groups separated by commas */
+#define RLNDUMP
+#define RLNDUMPHEX(buf, buflen) do { \
+ int _i; \
+ for (_i = 0; _i < (buflen); _i++) { \
+ printf("%02x", ((unsigned char *)(buf))[_i]); \
+ if (_i != (buflen) - 1 && _i % 4 == 3) \
+ printf(","); \
+ } \
+} while (0)