summaryrefslogtreecommitdiffstats
path: root/sys/dev/vx
diff options
context:
space:
mode:
authorwpaul <wpaul@FreeBSD.org>2000-12-07 23:30:51 +0000
committerwpaul <wpaul@FreeBSD.org>2000-12-07 23:30:51 +0000
commit0089b9348da391c38613a02eea888edfa0271143 (patch)
tree57c3d84554416a0d4e45f5079ad0c82d67adac7d /sys/dev/vx
parentfdb2cce5696766295ebce2800600b98619ca693c (diff)
downloadFreeBSD-src-0089b9348da391c38613a02eea888edfa0271143.zip
FreeBSD-src-0089b9348da391c38613a02eea888edfa0271143.tar.gz
When I converted this driver, I neglected to deal with packet alignment.
We must force payload alignment to a longword boundary to make the alpha happy. This should stop the driver from trapping on the alpha when the interface is ifconfig'ed (actually, when the first frame is received).
Diffstat (limited to 'sys/dev/vx')
-rw-r--r--sys/dev/vx/if_vx.c17
1 files changed, 17 insertions, 0 deletions
diff --git a/sys/dev/vx/if_vx.c b/sys/dev/vx/if_vx.c
index 30ce7cc..e1fa760 100644
--- a/sys/dev/vx/if_vx.c
+++ b/sys/dev/vx/if_vx.c
@@ -77,6 +77,7 @@
#define ETHER_MAX_LEN 1518
#define ETHER_ADDR_LEN 6
+#define ETHER_ALIGN 2
static struct connector_entry {
int bit;
@@ -687,6 +688,22 @@ again:
++ifp->if_ipackets;
+ {
+ struct mbuf *m0;
+
+ m0 = m_devget(mtod(m, char *) - ETHER_ALIGN,
+ m->m_pkthdr.len + ETHER_ALIGN, 0, ifp, NULL);
+
+ if (m0 == NULL) {
+ ifp->if_ierrors++;
+ goto abort;
+ }
+
+ m_adj(m0, ETHER_ALIGN);
+ m_freem(m);
+ m = m0;
+ }
+
/* We assume the header fit entirely in one mbuf. */
eh = mtod(m, struct ether_header *);
OpenPOWER on IntegriCloud