diff options
author | wpaul <wpaul@FreeBSD.org> | 2000-12-07 23:30:51 +0000 |
---|---|---|
committer | wpaul <wpaul@FreeBSD.org> | 2000-12-07 23:30:51 +0000 |
commit | 0089b9348da391c38613a02eea888edfa0271143 (patch) | |
tree | 57c3d84554416a0d4e45f5079ad0c82d67adac7d /sys | |
parent | fdb2cce5696766295ebce2800600b98619ca693c (diff) | |
download | FreeBSD-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')
-rw-r--r-- | sys/dev/vx/if_vx.c | 17 |
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 *); |