diff options
author | David Gwynne <dlg@cvs.openbsd.org> | 2004-12-30 07:43:10 +0000 |
---|---|---|
committer | David Gwynne <dlg@cvs.openbsd.org> | 2004-12-30 07:43:10 +0000 |
commit | 27292ea9e4da231ff24012ab51396d0af6602dc0 (patch) | |
tree | ea116f297e0a8afa046649b34866ac9f9cc7c13f /sys | |
parent | 49ef34998975a0d0268165cffc87628e34e48b75 (diff) |
fix for some archs that don't like unaligned accesses, eg sparc64 and alpha
ok jsg@
Diffstat (limited to 'sys')
-rw-r--r-- | sys/dev/usb/if_udav.c | 28 | ||||
-rw-r--r-- | sys/dev/usb/if_udavreg.h | 9 |
2 files changed, 20 insertions, 17 deletions
diff --git a/sys/dev/usb/if_udav.c b/sys/dev/usb/if_udav.c index aa9938518fe..b620217507a 100644 --- a/sys/dev/usb/if_udav.c +++ b/sys/dev/usb/if_udav.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_udav.c,v 1.7 2004/12/26 03:48:19 jsg Exp $ */ +/* $OpenBSD: if_udav.c,v 1.8 2004/12/30 07:43:09 dlg Exp $ */ /* $NetBSD: if_udav.c,v 1.3 2004/04/23 17:25:25 itojun Exp $ */ /* $nabe: if_udav.c,v 1.3 2003/08/21 16:57:19 nabe Exp $ */ /* @@ -1110,9 +1110,9 @@ udav_rxeof(usbd_xfer_handle xfer, usbd_private_handle priv, usbd_status status) struct udav_chain *c = priv; struct udav_softc *sc = c->udav_sc; struct ifnet *ifp = GET_IFP(sc); + struct udav_rx_hdr *h; struct mbuf *m; u_int32_t total_len; - u_int8_t *pktstat; int s; DPRINTF(("%s: %s: enter\n", USBDEVNAME(sc->sc_dev),__func__)); @@ -1141,31 +1141,27 @@ udav_rxeof(usbd_xfer_handle xfer, usbd_private_handle priv, usbd_status status) usbd_get_xfer_status(xfer, NULL, NULL, &total_len, NULL); - /* copy data to mbuf */ - m = c->udav_mbuf; - memcpy(mtod(m, char *), c->udav_buf, total_len); - - /* first byte in received data */ - pktstat = mtod(m, u_int8_t *); - m_adj(m, sizeof(u_int8_t)); - DPRINTF(("%s: RX Status: 0x%02x\n", *pktstat)); - - total_len = UGETW(mtod(m, u_int8_t *)); - m_adj(m, sizeof(u_int16_t)); + h = (struct udav_rx_hdr *)c->udav_buf; + total_len = UGETW(h->length) - ETHER_CRC_LEN; + + DPRINTF(("%s: RX Status: 0x%02x\n", h->pktstat)); - if (*pktstat & UDAV_RSR_LCS) { + if (h->pktstat & UDAV_RSR_LCS) { ifp->if_collisions++; goto done; } if (total_len < sizeof(struct ether_header) || - *pktstat & UDAV_RSR_ERR) { + h->pktstat & UDAV_RSR_ERR) { ifp->if_ierrors++; goto done; } + /* copy data to mbuf */ + m = c->udav_mbuf; + memcpy(mtod(m, char *), c->udav_buf + UDAV_RX_HDRLEN, total_len); + ifp->if_ipackets++; - total_len -= ETHER_CRC_LEN; m->m_pkthdr.len = m->m_len = total_len; m->m_pkthdr.rcvif = ifp; diff --git a/sys/dev/usb/if_udavreg.h b/sys/dev/usb/if_udavreg.h index 6dff5f17762..4179a6aed5a 100644 --- a/sys/dev/usb/if_udavreg.h +++ b/sys/dev/usb/if_udavreg.h @@ -1,4 +1,4 @@ -/* $OpenBSD: if_udavreg.h,v 1.1 2004/10/05 02:01:18 jsg Exp $ */ +/* $OpenBSD: if_udavreg.h,v 1.2 2004/12/30 07:43:09 dlg Exp $ */ /* $NetBSD: if_udavreg.h,v 1.2 2003/09/04 15:17:39 tsutsui Exp $ */ /* $nabe: if_udavreg.h,v 1.2 2003/08/21 16:26:40 nabe Exp $ */ /* @@ -212,3 +212,10 @@ struct udav_softc { u_int16_t sc_flags; }; + +struct udav_rx_hdr { + uByte pktstat; + uWord length; +} UPACKED; +#define UDAV_RX_HDRLEN sizeof(struct udav_rx_hdr) + |