summaryrefslogtreecommitdiff
path: root/sys/dev/usb
diff options
context:
space:
mode:
authorDavid Gwynne <dlg@cvs.openbsd.org>2004-12-30 07:43:10 +0000
committerDavid Gwynne <dlg@cvs.openbsd.org>2004-12-30 07:43:10 +0000
commit27292ea9e4da231ff24012ab51396d0af6602dc0 (patch)
treeea116f297e0a8afa046649b34866ac9f9cc7c13f /sys/dev/usb
parent49ef34998975a0d0268165cffc87628e34e48b75 (diff)
fix for some archs that don't like unaligned accesses, eg sparc64 and alpha
ok jsg@
Diffstat (limited to 'sys/dev/usb')
-rw-r--r--sys/dev/usb/if_udav.c28
-rw-r--r--sys/dev/usb/if_udavreg.h9
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)
+