summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--sys/dev/ic/dc21040reg.h17
-rw-r--r--sys/dev/pci/if_de.c169
-rw-r--r--sys/dev/pci/if_devar.h5
3 files changed, 132 insertions, 59 deletions
diff --git a/sys/dev/ic/dc21040reg.h b/sys/dev/ic/dc21040reg.h
index d43277ca5b9..665b0b3e37d 100644
--- a/sys/dev/ic/dc21040reg.h
+++ b/sys/dev/ic/dc21040reg.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: dc21040reg.h,v 1.8 1998/07/30 14:09:57 pefo Exp $ */
+/* $OpenBSD: dc21040reg.h,v 1.9 1998/08/28 06:31:19 rahnds Exp $ */
/* $NetBSD: dc21040reg.h,v 1.11 1997/06/08 18:44:02 thorpej Exp $ */
/*-
@@ -44,11 +44,20 @@
#define TULIP_BITFIELD4(a, b, c, d) a, b, c, d
#endif
+typedef union {
+ struct {
+ u_int32_t TULIP_BITFIELD3(bd_length1 : 11,
+ bd_length2 : 11,
+ bd_flag : 10);
+ }s;
+ u_int32_t f;
+} tulip_desc_bitfield_t;
+#define bd_length1 s.bd_length1
+#define bd_length2 s.bd_length2
+#define bd_flag s.bd_flag
typedef struct {
u_int32_t d_status;
- u_int32_t TULIP_BITFIELD3(d_length1 : 11,
- d_length2 : 11,
- d_flag : 10);
+ tulip_desc_bitfield_t u;
u_int32_t d_addr1;
u_int32_t d_addr2;
#ifdef PPC_MPC106_BUG
diff --git a/sys/dev/pci/if_de.c b/sys/dev/pci/if_de.c
index f024447b447..7b569672f7e 100644
--- a/sys/dev/pci/if_de.c
+++ b/sys/dev/pci/if_de.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_de.c,v 1.32 1998/08/07 16:48:16 pefo Exp $ */
+/* $OpenBSD: if_de.c,v 1.33 1998/08/28 06:31:23 rahnds Exp $ */
/* $NetBSD: if_de.c,v 1.45 1997/06/09 00:34:18 thorpej Exp $ */
/*-
@@ -3194,7 +3194,10 @@ tulip_reset(
(4 << 2) /* Descriptor skip length */
|TULIP_BUSMODE_CACHE_ALIGN8
|TULIP_BUSMODE_READMULTIPLE
- |(BYTE_ORDER != LITTLE_ENDIAN ? (TULIP_BUSMODE_DESC_BIGENDIAN) : 0));
+ /*
+ |(BYTE_ORDER != LITTLE_ENDIAN ? (TULIP_BUSMODE_DESC_BIGENDIAN) : 0)
+ */
+ );
#else
TULIP_CSR_WRITE(sc, csr_busmode,
(1 << (TULIP_BURSTSIZE(sc->tulip_unit) + 8))
@@ -3220,7 +3223,7 @@ tulip_reset(
ri->ri_nextin = ri->ri_nextout = ri->ri_first;
ri->ri_free = ri->ri_max;
for (di = ri->ri_first; di < ri->ri_last; di++)
- di->d_status = 0;
+ di->d_status = 0; /* no swabbing necessary -dsr */
/*
* We need to collect all the mbufs were on the
@@ -3232,9 +3235,17 @@ tulip_reset(
ri->ri_nextin = ri->ri_nextout = ri->ri_first;
ri->ri_free = ri->ri_max;
for (di = ri->ri_first; di < ri->ri_last; di++) {
- di->d_status = 0;
- di->d_length1 = 0; di->d_addr1 = 0;
- di->d_length2 = 0; di->d_addr2 = 0;
+ di->d_status = 0; /* no swabbing necessary -dsr */
+ {
+ tulip_desc_bitfield_t u;
+
+ u.f = DESC_BO(di->u.f); /* copy the bitfields */
+ u.bd_length1 = 0;
+ u.bd_length2 = 0;
+ di->u.f = DESC_BO(u.f);
+ }
+ di->d_addr1 = 0; /* no swabbing necessary -dsr */
+ di->d_addr2 = 0; /* no swabbing necessary -dsr */
}
for (;;) {
struct mbuf *m;
@@ -3352,14 +3363,14 @@ tulip_rx_intr(
* 90% of the packets will fit in one descriptor. So we optimize
* for that case.
*/
- if ((((volatile tulip_desc_t *) eop)->d_status & (TULIP_DSTS_OWNER|TULIP_DSTS_RxFIRSTDESC|TULIP_DSTS_RxLASTDESC)) == (TULIP_DSTS_RxFIRSTDESC|TULIP_DSTS_RxLASTDESC)) {
+ if ((DESC_BO(((volatile tulip_desc_t *) eop)->d_status) & (TULIP_DSTS_OWNER|TULIP_DSTS_RxFIRSTDESC|TULIP_DSTS_RxLASTDESC)) == (TULIP_DSTS_RxFIRSTDESC|TULIP_DSTS_RxLASTDESC)) {
IF_DEQUEUE(&sc->tulip_rxq, ms);
me = ms;
} else {
/*
* If still owned by the TULIP, don't touch it.
*/
- if (((volatile tulip_desc_t *) eop)->d_status & TULIP_DSTS_OWNER)
+ if (DESC_BO(((volatile tulip_desc_t *) eop)->d_status) & TULIP_DSTS_OWNER)
break;
/*
@@ -3367,10 +3378,10 @@ tulip_rx_intr(
* is enabled or MCLBYTES < 1518) for a received packet to cross
* more than one receive descriptor.
*/
- while ((((volatile tulip_desc_t *) eop)->d_status & TULIP_DSTS_RxLASTDESC) == 0) {
+ while ((DESC_BO(((volatile tulip_desc_t *) eop)->d_status) & TULIP_DSTS_RxLASTDESC) == 0) {
if (++eop == ri->ri_last)
eop = ri->ri_first;
- if (eop == ri->ri_nextout || ((((volatile tulip_desc_t *) eop)->d_status & TULIP_DSTS_OWNER))) {
+ if (eop == ri->ri_nextout || (DESC_BO(((volatile tulip_desc_t *) eop)->d_status) & TULIP_DSTS_OWNER)) {
#if defined(TULIP_DEBUG)
sc->tulip_dbg.dbg_rxintrs++;
sc->tulip_dbg.dbg_rxpktsperintr[cnt]++;
@@ -3402,12 +3413,12 @@ tulip_rx_intr(
/*
* Now get the size of received packet (minus the CRC).
*/
- total_len = ((eop->d_status >> 16) & 0x7FFF) - 4;
+ total_len = ((DESC_BO(eop->d_status) >> 16) & 0x7FFF) - 4;
if ((sc->tulip_flags & TULIP_RXIGNORE) == 0
- && ((eop->d_status & TULIP_DSTS_ERRSUM) == 0
+ && ((DESC_BO(eop->d_status) & TULIP_DSTS_ERRSUM) == 0
#ifdef BIG_PACKET
|| (total_len <= sc->tulip_if.if_mtu + sizeof(struct ether_header) &&
- (eop->d_status & (TULIP_DSTS_RxBADLENGTH|TULIP_DSTS_RxRUNT|
+ (DESC_BO(eop->d_status) & (TULIP_DSTS_RxBADLENGTH|TULIP_DSTS_RxRUNT|
TULIP_DSTS_RxCOLLSEEN|TULIP_DSTS_RxBADCRC|
TULIP_DSTS_RxOVERFLOW)) == 0)
#endif
@@ -3431,16 +3442,16 @@ tulip_rx_intr(
total_len -= sizeof(struct ether_header);
} else {
ifp->if_ierrors++;
- if (eop->d_status & (TULIP_DSTS_RxBADLENGTH|TULIP_DSTS_RxOVERFLOW|TULIP_DSTS_RxWATCHDOG)) {
+ if (DESC_BO(eop->d_status) & (TULIP_DSTS_RxBADLENGTH|TULIP_DSTS_RxOVERFLOW|TULIP_DSTS_RxWATCHDOG)) {
sc->tulip_dot3stats.dot3StatsInternalMacReceiveErrors++;
} else {
const char *error = NULL;
- if (eop->d_status & TULIP_DSTS_RxTOOLONG) {
+ if (DESC_BO(eop->d_status) & TULIP_DSTS_RxTOOLONG) {
sc->tulip_dot3stats.dot3StatsFrameTooLongs++;
error = "frame too long";
}
- if (eop->d_status & TULIP_DSTS_RxBADCRC) {
- if (eop->d_status & TULIP_DSTS_RxDRBBLBIT) {
+ if (DESC_BO(eop->d_status) & TULIP_DSTS_RxBADCRC) {
+ if (DESC_BO(eop->d_status) & TULIP_DSTS_RxDRBBLBIT) {
sc->tulip_dot3stats.dot3StatsAlignmentErrors++;
error = "alignment error";
} else {
@@ -3543,9 +3554,14 @@ tulip_rx_intr(
* receive queue.
*/
do {
- ri->ri_nextout->d_length1 = TULIP_RX_BUFLEN;
- ri->ri_nextout->d_addr1 = TULIP_KVATOPHYS(sc, mtod(ms, caddr_t));
- ri->ri_nextout->d_status = TULIP_DSTS_OWNER;
+ tulip_desc_bitfield_t u;
+ u.f = DESC_BO ( ri->ri_nextout->u.f );
+ u.bd_length1 = TULIP_RX_BUFLEN;
+ ri->ri_nextout->u.f = DESC_BO ( u.f );
+
+ ri->ri_nextout->d_addr1 =
+ DESC_BO(TULIP_KVATOPHYS(sc, mtod(ms, caddr_t)));
+ ri->ri_nextout->d_status = DESC_BO(TULIP_DSTS_OWNER);
#if defined(__mips__)
pci_sync_cache(sc->tulip_pc, (vm_offset_t)mtod(ms, caddr_t),TULIP_RX_BUFLEN);
#endif
@@ -3578,10 +3594,15 @@ tulip_tx_intr(
while (ri->ri_free < ri->ri_max) {
u_int32_t d_flag;
- if (((volatile tulip_desc_t *) ri->ri_nextin)->d_status & TULIP_DSTS_OWNER)
+ if (DESC_BO(((volatile tulip_desc_t *) ri->ri_nextin)->d_status) & TULIP_DSTS_OWNER)
break;
- d_flag = ri->ri_nextin->d_flag;
+ {
+ tulip_desc_bitfield_t u;
+
+ u.f = DESC_BO(ri->ri_nextin->u.f); /* copy the bitfields */
+ d_flag = u.bd_flag;
+ }
if (d_flag & TULIP_DFLAG_TxLASTSEG) {
if (d_flag & TULIP_DFLAG_TxSETUPPKT) {
/*
@@ -3592,7 +3613,7 @@ tulip_tx_intr(
* an abormal interrupt indication.
*/
sc->tulip_flags &= ~(TULIP_DOINGSETUP|TULIP_HASHONLY);
- if (ri->ri_nextin->d_flag & TULIP_DFLAG_TxINVRSFILT)
+ if (d_flag & TULIP_DFLAG_TxINVRSFILT)
sc->tulip_flags |= TULIP_HASHONLY;
if ((sc->tulip_flags & (TULIP_WANTSETUP|TULIP_TXPROBE_ACTIVE)) == 0) {
tulip_rx_intr(sc);
@@ -3603,7 +3624,7 @@ tulip_tx_intr(
TULIP_CSR_WRITE(sc, csr_command, sc->tulip_cmdmode);
}
} else {
- const u_int32_t d_status = ri->ri_nextin->d_status;
+ const u_int32_t d_status = DESC_BO(ri->ri_nextin->d_status);
IF_DEQUEUE(&sc->tulip_txq, m);
if (m != NULL) {
#if NBPFILTER > 0
@@ -4123,21 +4144,32 @@ tulip_txput(
eop = nextout;
if (++nextout == ri->ri_last)
nextout = ri->ri_first;
- eop->d_flag &= TULIP_DFLAG_ENDRING|TULIP_DFLAG_CHAIN;
- eop->d_status = d_status;
- eop->d_addr1 = TULIP_KVATOPHYS(sc, addr);
- eop->d_length1 = slen;
+ {
+ tulip_desc_bitfield_t u;
+ u.f = DESC_BO(eop->u.f); /* copy the bitfields */
+ u.bd_flag &= TULIP_DFLAG_ENDRING|TULIP_DFLAG_CHAIN;
+ u.bd_length1 = slen;
+
+ eop->d_status = DESC_BO(d_status);
+ eop->d_addr1 = DESC_BO( TULIP_KVATOPHYS(sc, addr) );
+ eop->u.f = DESC_BO(u.f); /* copy the bitfields */
+ }
} else {
/*
* Fill in second half of descriptor
*/
- eop->d_addr2 = TULIP_KVATOPHYS(sc, addr);
- eop->d_length2 = slen;
+ eop->d_addr2 = DESC_BO(TULIP_KVATOPHYS(sc, addr));
+ {
+ tulip_desc_bitfield_t u;
+ u.f = DESC_BO(eop->u.f); /* copy the bitfields */
+ u.bd_length2 = slen;
+ eop->u.f = DESC_BO(u.f); /* copy the bitfields */
+ }
}
#if defined(__mips__)
pci_sync_cache(sc->tulip_pc, (vm_offset_t)addr, slen);
#endif
- d_status = TULIP_DSTS_OWNER;
+ d_status = DESC_BO(TULIP_DSTS_OWNER);
len -= slen;
addr += slen;
#ifdef BIG_PACKET
@@ -4161,30 +4193,45 @@ tulip_txput(
* by us since it may have been set up above if we ran out
* of room in the ring.
*/
- nextout->d_status = 0;
+ nextout->d_status = 0; /* doesn't need swab - dsr */
/*
* If we only used the first segment of the last descriptor,
* make sure the second segment will not be used.
*/
if (segcnt & 1) {
- eop->d_addr2 = 0;
- eop->d_length2 = 0;
+ tulip_desc_bitfield_t u;
+ u.f = DESC_BO(eop->u.f); /* copy the bitfields */
+ u.bd_length2 = 0;
+ eop->d_addr2 = 0; /* no swab necessary - dsr */
+ eop->u.f = DESC_BO(u.f);
}
/*
* Mark the last and first segments, indicate we want a transmit
* complete interrupt, and tell it to transmit!
*/
- eop->d_flag |= TULIP_DFLAG_TxLASTSEG|TULIP_DFLAG_TxWANTINTR;
+ {
+ tulip_desc_bitfield_t u;
+
+ u.f = DESC_BO(eop->u.f); /* copy the bitfields */
+ u.bd_flag |= TULIP_DFLAG_TxLASTSEG|TULIP_DFLAG_TxWANTINTR;
+ eop->u.f = DESC_BO(u.f);
+ }
/*
* Note that ri->ri_nextout is still the start of the packet
* and until we set the OWNER bit, we can still back out of
* everything we have done.
*/
- ri->ri_nextout->d_flag |= TULIP_DFLAG_TxFIRSTSEG;
- ri->ri_nextout->d_status = TULIP_DSTS_OWNER;
+ {
+ tulip_desc_bitfield_t u;
+
+ u.f = DESC_BO(ri->ri_nextout->u.f); /* copy the bitfields */
+ u.bd_flag |= TULIP_DFLAG_TxFIRSTSEG;
+ ri->ri_nextout->u.f = DESC_BO(u.f);
+ ri->ri_nextout->d_status = DESC_BO(TULIP_DSTS_OWNER);
+ }
TULIP_CSR_WRITE(sc, csr_txpoll, 1);
@@ -4279,18 +4326,30 @@ tulip_txput_setup(
pci_sync_cache(sc->tulip_pc, (vm_offset_t)sc->tulip_setupbuf, sizeof(sc->tulip_setupbuf));
#endif
nextout = ri->ri_nextout;
- nextout->d_flag &= TULIP_DFLAG_ENDRING|TULIP_DFLAG_CHAIN;
- nextout->d_flag |= TULIP_DFLAG_TxFIRSTSEG|TULIP_DFLAG_TxLASTSEG
- |TULIP_DFLAG_TxSETUPPKT|TULIP_DFLAG_TxWANTINTR;
- if (sc->tulip_flags & TULIP_WANTHASHPERFECT)
- nextout->d_flag |= TULIP_DFLAG_TxHASHFILT;
- else if (sc->tulip_flags & TULIP_WANTHASHONLY)
- nextout->d_flag |= TULIP_DFLAG_TxHASHFILT|TULIP_DFLAG_TxINVRSFILT;
-
- nextout->d_length1 = sizeof(sc->tulip_setupbuf);
- nextout->d_addr1 = TULIP_KVATOPHYS(sc, sc->tulip_setupbuf);
- nextout->d_length2 = 0;
- nextout->d_addr2 = 0;
+ {
+ u_int32_t d_flag;
+ tulip_desc_bitfield_t u;
+
+ u.f = DESC_BO(nextout->u.f); /* copy the bitfields */
+ d_flag = u.bd_flag;
+
+ d_flag &= TULIP_DFLAG_ENDRING|TULIP_DFLAG_CHAIN;
+ d_flag |= TULIP_DFLAG_TxFIRSTSEG|TULIP_DFLAG_TxLASTSEG
+ |TULIP_DFLAG_TxSETUPPKT|TULIP_DFLAG_TxWANTINTR;
+ if (sc->tulip_flags & TULIP_WANTHASHPERFECT)
+ d_flag |= TULIP_DFLAG_TxHASHFILT;
+ else if (sc->tulip_flags & TULIP_WANTHASHONLY)
+ d_flag |= TULIP_DFLAG_TxHASHFILT|TULIP_DFLAG_TxINVRSFILT;
+
+
+ u.bd_flag = d_flag;
+ u.bd_length1 = sizeof(sc->tulip_setupbuf);
+ u.bd_length2 = 0;
+
+ nextout->u.f = DESC_BO(u.f);
+ nextout->d_addr1 = DESC_BO(TULIP_KVATOPHYS(sc, sc->tulip_setupbuf));
+ nextout->d_addr2 = 0; /* no need to swab */
+ }
/*
* Advance the ring for the next transmit packet.
@@ -4303,8 +4362,8 @@ tulip_txput_setup(
* may have been set up above if we ran out of room in the
* ring.
*/
- ri->ri_nextout->d_status = 0;
- nextout->d_status = TULIP_DSTS_OWNER;
+ ri->ri_nextout->d_status = 0; /* doesn't need swab - dsr */
+ nextout->d_status = DESC_BO(TULIP_DSTS_OWNER);
TULIP_CSR_WRITE(sc, csr_txpoll, 1);
if ((sc->tulip_intrmask & TULIP_STS_TXINTR) == 0) {
sc->tulip_intrmask |= TULIP_STS_TXINTR;
@@ -4809,7 +4868,13 @@ tulip_initring(
ri->ri_first = descs;
ri->ri_last = ri->ri_first + ri->ri_max;
bzero((caddr_t) ri->ri_first, sizeof(ri->ri_first[0]) * ri->ri_max);
- ri->ri_last[-1].d_flag = TULIP_DFLAG_ENDRING;
+ {
+ tulip_desc_bitfield_t u;
+
+ u.f = DESC_BO( ri->ri_last[-1].u.f );
+ u.bd_flag = TULIP_DFLAG_ENDRING;
+ ri->ri_last[-1].u.f = DESC_BO(u.f);
+ }
}
/*
diff --git a/sys/dev/pci/if_devar.h b/sys/dev/pci/if_devar.h
index c3d07c62bfa..09a1eca3924 100644
--- a/sys/dev/pci/if_devar.h
+++ b/sys/dev/pci/if_devar.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_devar.h,v 1.6 1998/08/07 16:48:18 pefo Exp $ */
+/* $OpenBSD: if_devar.h,v 1.7 1998/08/28 06:31:25 rahnds Exp $ */
/* $NetBSD: if_devar.h,v 1.13 1997/06/08 18:46:36 thorpej Exp $ */
/*-
@@ -97,8 +97,7 @@ FILT_BO(x)
{
u_int32_t s;
- s = x;
- s = s << 16;
+ s = (x & 0xffff) << 16 | ((x & 0xff) << 8) | ((x & 0xff00) >> 8);
return s;
}