summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/ic/rl2.c63
-rw-r--r--sys/dev/ic/rl2subr.c42
-rw-r--r--sys/dev/ic/rl2var.h32
-rw-r--r--sys/dev/pcmcia/if_rl2_pcmcia.c16
4 files changed, 82 insertions, 71 deletions
diff --git a/sys/dev/ic/rl2.c b/sys/dev/ic/rl2.c
index 3ec601655ff..3c6c78f9abe 100644
--- a/sys/dev/ic/rl2.c
+++ b/sys/dev/ic/rl2.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rl2.c,v 1.1 1999/06/21 23:21:46 d Exp $ */
+/* $OpenBSD: rl2.c,v 1.2 1999/06/23 04:48:48 d Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public Domain.
*
@@ -82,7 +82,6 @@ static int rl2_standby __P((struct rl2_softc *));
#endif
/* Back-end attach and configure. */
-
void
rl2config(sc)
struct rl2_softc * sc;
@@ -97,7 +96,7 @@ rl2config(sc)
sc->sc_cardtype |= sc->sc_dev.dv_cfdata->cf_flags;
/* Initialise values in the soft state. */
- sc->sc_pktseq = 0;
+ sc->sc_pktseq = 0; /* rl2_newseq() */
sc->sc_txseq = 0;
sc->sc_promisc = 0;
@@ -162,7 +161,6 @@ rl2config(sc)
}
/* Bring device up. */
-
static void
rl2init(sc)
struct rl2_softc * sc;
@@ -215,10 +213,7 @@ rl2init(sc)
return;
}
-/*
- * Start outputting on interface.
- * This is always called at splnet().
- */
+/* Start outputting on interface. This is always called at splnet(). */
static void
rl2start(ifp)
struct ifnet * ifp;
@@ -267,7 +262,7 @@ rl2start(ifp)
#define PACKETMIN (sizeof (struct ether_header) + ETHERMIN)
#define PACKETMAX (sizeof (struct ether_header) + ETHERMTU + 4)
- /* Packet size has to be an even number between 60 and 1518 bytes. */
+ /* Packet size has to be an even number between 60 and 1518 octets. */
pad = len & 1;
if (len + pad < PACKETMIN)
pad = PACKETMIN - len;
@@ -307,35 +302,40 @@ rl2_transmit(sc, m0, len, pad)
int pad;
{
struct mbuf * m;
- int zfirst = !(mtod(m0, u_int8_t*)[0]&1);
+ int zfirst;
int actlen;
int tlen = len + pad;
struct rl2_msg_tx_state state;
static u_int8_t zeroes[60];
- struct rl2_mm_sendpacket cmd = {
- RL2_MM_SENDPACKET,
+ struct rl2_mm_sendpacket cmd = { RL2_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) |
- (1 ? RL2_MM_SENDPACKET_MODE_QFSK : 0), /* sc->qfsk? */
- 0x70, /* txpower */
- htons(4 + tlen) & 0xff,
- (htons(4 + tlen) >> 8) & 0xff,
- 0,
- 0,
- sc->sc_txseq++,
- 0
- };
-
-#ifdef DIAGNOSTIC
- if (sizeof cmd != 12)
- panic("rl2_transmit");
-#endif
+ (0 ? RL2_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;
+ cmd.xxx1 = 0;
+ cmd.xxx2 = 0;
+ cmd.xxx3 = 0;
+
+ /* A unique packet-level sequence number. XXX related to sc_seq? */
+ cmd.sequence = sc->sc_txseq;
+ sc->sc_txseq++;
+ if (sc->sc_txseq > 0x7c)
+ sc->sc_txseq = 0;
dprintf(" T[%d+%d", len, pad);
if (rl2_msg_tx_start(sc, &cmd, sizeof cmd + tlen, &state))
goto error;
+ cmd.mm_cmd.cmd_seq = rl2_newseq(sc);
+
#ifdef RL2DUMP
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);
@@ -564,6 +564,7 @@ rl2read(sc, hdr, len)
sc->sc_dev.dv_xname);
}
#endif
+ /* XXX Jean's driver dealt with RFC893 trailers here */
eh = mtod(m, struct ether_header *);
#if NBPFILTER > 0
if (ifp->if_bpf)
@@ -593,8 +594,8 @@ rl2read(sc, hdr, len)
switch (RL2_MM_CMD(hdr->cmd_letter, hdr->cmd_fn)) {
case RL2_MM_CMD('b', 0): /* b0: Transmit done. */
#ifdef DIAGNOSTIC
- if (len != 4)
- printf("%s: 'b0' len %d != 4\n",
+ if (len != 7)
+ printf("%s: 'b0' len %d != 7\n",
sc->sc_dev.dv_xname, len);
#endif
ifp->if_flags &= ~IFF_OACTIVE;
@@ -668,7 +669,7 @@ rl2get(sc, hdr, totlen)
int len;
struct mbuf *m, **mp, *top;
struct rl2_pdata pd = RL2_PDATA_INIT;
- /* u_int8_t hwhdr[ETHER_ADDR_LEN * 2]; */
+ u_int8_t hwhdr[20];
dprintf(" [get]");
@@ -687,7 +688,6 @@ rl2get(sc, hdr, totlen)
}
#endif
-#if 0
totlen -= sizeof hwhdr;
/* Skip the hardware header. */
rl2_rx_pdata(sc, hwhdr, sizeof hwhdr, &pd);
@@ -695,7 +695,6 @@ rl2get(sc, hdr, totlen)
RL2DUMPHEX(hwhdr, sizeof hwhdr);
printf("/");
#endif
-#endif
/* (Most of the following code fleeced from elink3.c.) */
MGETHDR(m, M_DONTWAIT, MT_DATA);
@@ -980,7 +979,7 @@ rl2_roamconfig(sc)
if (rl2_msg_txrx(sc, &roam, sizeof roam,
&response, sizeof response))
return (-1);
-
+
return (0);
}
diff --git a/sys/dev/ic/rl2subr.c b/sys/dev/ic/rl2subr.c
index 1c13098cf4b..38c5c43f5ee 100644
--- a/sys/dev/ic/rl2subr.c
+++ b/sys/dev/ic/rl2subr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: rl2subr.c,v 1.1 1999/06/21 23:21:47 d Exp $ */
+/* $OpenBSD: rl2subr.c,v 1.2 1999/06/23 04:48:49 d Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public Domain.
*
@@ -375,12 +375,12 @@ rl2_rx_request(sc, timeo)
if (sc->sc_width == 16) {
if (status != 0x10)
goto badstatus_quiet;
- /* Read 2 bytes. */
+ /* Read 2 octets. */
len = rl2_data_read_2(sc);
} else if (sc->sc_width == 8) {
if (status != 0x60)
goto badstatus_quiet;
- /* Read low byte. */
+ /* Read low octet. */
lo = rl2_data_read_1(sc);
rl2_status_rx_write(sc, 0x70);
rl2_status_rx_int(sc);
@@ -394,7 +394,7 @@ rl2_rx_request(sc, timeo)
splx(s);
if (status != 0x10)
goto badstatus;
- /* Read high byte. */
+ /* Read high octet. */
hi = rl2_data_read_1(sc);
len = lo | (hi << 8);
}
@@ -405,9 +405,9 @@ rl2_rx_request(sc, timeo)
dprintf(" len=%d]", len);
return (len);
-
+
badstatus:
- printf("%s: rx_request tiemd out, status %02x\n",
+ printf("%s: rx_request timed out, status %02x\n",
sc->sc_dev.dv_xname, status);
badstatus_quiet:
if (status == 0x50)
@@ -442,7 +442,7 @@ rl2_rx_pdata(sc, buf, len, pd)
dprinthex(data, len);
#endif
if (len & 1) {
- /* Read the last byte plus a bit extra. */
+ /* Read the last octet plus a bit extra. */
union {
u_int16_t w;
u_int8_t b[2];
@@ -652,6 +652,22 @@ rl2_msg_tx_end(sc, state)
return (ret);
}
+/* Return the next unique sequence number to use for a transmitted command */
+u_int8_t
+rl2_newseq(sc)
+ struct rl2_softc * sc;
+{
+ int s;
+ u_int8_t seq;
+
+ s = splhigh();
+ seq = sc->sc_pktseq++;
+ if (sc->sc_pktseq > 0x7c)
+ sc->sc_pktseq = 0;
+ splx(s);
+ return (seq);
+}
+
/*
* Transmit a command message to, and (optionally) receive a response
* message from the card. Each transmitted message has a sequence
@@ -674,19 +690,13 @@ rl2_msg_txrx(sc, tx, txlen, rx, rxlen)
struct rl2_msg_tx_state state;
int ien;
int ret;
- int s;
#ifdef DIAGNOSTIC
if (rx != NULL && rxlen < sizeof *rxc)
panic("rl2_msg_txrx");
#endif
- /* Each message has a unique sequence number. */
- s = splhigh();
- txc->cmd_seq = sc->sc_pktseq++;
- if (sc->sc_pktseq > 0x7c)
- sc->sc_pktseq = 0;
- splx(s);
+ txc->cmd_seq = rl2_newseq(sc);
#ifdef RL2DUMP
printf("%s: send %c%d seq %d data ", sc->sc_dev.dv_xname,
@@ -709,7 +719,7 @@ rl2_msg_txrx(sc, tx, txlen, rx, rxlen)
return (ret);
}
- /* Always send an even number of bytes. */
+ /* Always send an even number of octets. */
rl2_msg_tx_data(sc, tx, (txlen + 1) & ~1, &state);
/* End the transmission. */
@@ -884,7 +894,7 @@ rl2_mbox_lock(sc, seq, bufp, lenp)
return (0);
}
-/* Unlock a mailbox and inform the waiter of the actual number of bytes. */
+/* Unlock a mailbox and inform the waiter of the actual number of octets. */
void
rl2_mbox_unlock(sc, seq, actlen)
struct rl2_softc * sc;
diff --git a/sys/dev/ic/rl2var.h b/sys/dev/ic/rl2var.h
index 92143c1af9c..6dd3cfd4d47 100644
--- a/sys/dev/ic/rl2var.h
+++ b/sys/dev/ic/rl2var.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: rl2var.h,v 1.1 1999/06/21 23:21:47 d Exp $ */
+/* $OpenBSD: rl2var.h,v 1.2 1999/06/23 04:48:49 d Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public domain.
*
@@ -58,8 +58,8 @@ struct rl2_softc {
/* Structure used to hold partial read state for rl2_rx_pdata() */
struct rl2_pdata {
- u_int8_t p_data; /* extra bytes read but not consumed */
- int p_nremain; /* number of bytes not consumed */
+ u_int8_t p_data; /* extra data read but not consumed */
+ int p_nremain; /* size of unconsumed data */
};
#define RL2_PDATA_INIT {0,0}
@@ -78,22 +78,24 @@ struct rl2_mm_cmd; /* fwd decl */
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,
+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 *));
+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,
+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 *,
+int rl2_msg_tx_end __P((struct rl2_softc *,
struct rl2_msg_tx_state *));
-int rl2_msg_txrx __P((struct rl2_softc *, void *, int,
+int rl2_msg_txrx __P((struct rl2_softc *, void *, int,
void *, int));
int rl2_mbox_create __P((struct rl2_softc *, u_int8_t, void *,
@@ -123,7 +125,7 @@ void rl2_mbox_unlock __P((struct rl2_softc *, u_int8_t, size_t));
#define dprinthex(buf, len) /* nothing */
#endif
-/* debug messages to/from card. prints 4-byte groups separated by commas */
+/* debug messages to/from card. prints 4-octet groups separated by commas */
#define RL2DUMP
#define RL2DUMPHEX(buf, buflen) do { \
int _i; \
diff --git a/sys/dev/pcmcia/if_rl2_pcmcia.c b/sys/dev/pcmcia/if_rl2_pcmcia.c
index 0950e304cea..16143a80028 100644
--- a/sys/dev/pcmcia/if_rl2_pcmcia.c
+++ b/sys/dev/pcmcia/if_rl2_pcmcia.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_rl2_pcmcia.c,v 1.1 1999/06/21 23:21:45 d Exp $ */
+/* $OpenBSD: if_rl2_pcmcia.c,v 1.2 1999/06/23 04:48:49 d Exp $ */
/*
* David Leonard <d@openbsd.org>, 1999. Public domain.
*
@@ -83,7 +83,7 @@ rl2_pcmcia_product_lookup(pa)
{
struct rl2_pcmcia_product *rpp;
- for (rpp = rl2_pcmcia_products; rpp->manufacturer && rpp->product;
+ for (rpp = rl2_pcmcia_products; rpp->manufacturer && rpp->product;
rpp++)
if (pa->manufacturer == rpp->manufacturer &&
pa->product == rpp->product)
@@ -102,7 +102,7 @@ rl2_pcmcia_match(parent, match, aux)
int i;
for (i = 0; i < 4; i++)
- if (cis1_info[i] &&
+ if (cis1_info[i] &&
strcmp(cis1_info[i], pa->card->cis1_info[i]) != 0)
return (0);
@@ -126,7 +126,7 @@ rl2_pcmcia_attach(parent, self, aux)
int i;
static bus_addr_t iobases[] = {
0x270, /* useful in user-space debugging */
- 0x100, 0x120, 0x140, 0x218, 0x270, 0x280, 0x290, 0x298,
+ 0x100, 0x120, 0x140, 0x218, 0x270, 0x280, 0x290, 0x298,
0x2a0, 0x2a8, 0x2e0, 0x300, 0x310, 0x358, 0x360, 0x368,
0
};
@@ -164,12 +164,12 @@ rl2_pcmcia_attach(parent, self, aux)
#ifdef RL2DEBUG
/* Try only those ports from the manual */
for (i=0; iobases[i] != 0; i++)
- if (pcmcia_io_alloc(psc->sc_pf, iobases[i], RL2_NPORTS,
+ if (pcmcia_io_alloc(psc->sc_pf, iobases[i], RL2_NPORTS,
RL2_NPORTS, &psc->sc_pcioh) == 0)
break;
if (iobases[i] == 0) {
#else
- if (pcmcia_io_alloc(psc->sc_pf, 0, RL2_NPORTS,
+ if (pcmcia_io_alloc(psc->sc_pf, 0, RL2_NPORTS,
RL2_NPORTS, &psc->sc_pcioh)) {
#endif
printf(": can't alloc i/o space\n");
@@ -265,7 +265,7 @@ rl2_pcmcia_enable(sc)
struct pcmcia_function *pf = psc->sc_pf;
/* Establish the interrupt */
- sc->sc_ih = pcmcia_intr_establish(psc->sc_pf, IPL_NET,
+ sc->sc_ih = pcmcia_intr_establish(psc->sc_pf, IPL_NET,
rl2intr_pcmcia, sc);
if (sc->sc_ih == NULL) {
printf("%s: couldn't establish interrupt\n",
@@ -281,7 +281,7 @@ rl2_pcmcia_disable(sc)
struct rl2_softc *sc;
{
struct rl2_pcmcia_softc *psc = (struct rl2_pcmcia_softc *) sc;
-
+
pcmcia_function_disable(psc->sc_pf);
pcmcia_intr_disestablish(psc->sc_pf, sc->sc_ih);
}