Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys if_arp: Ensure that arphdr is aligned
details: https://anonhg.NetBSD.org/src/rev/45ca8129d139
branches: trunk
changeset: 1018668:45ca8129d139
user: roy <roy%NetBSD.org@localhost>
date: Sat Feb 13 07:57:09 2021 +0000
description:
if_arp: Ensure that arphdr is aligned
diffstat:
sys/net/if_arp.h | 7 ++++++-
sys/netinet/if_arp.c | 20 +++++++++++++++-----
2 files changed, 21 insertions(+), 6 deletions(-)
diffs (62 lines):
diff -r 5e6889657105 -r 45ca8129d139 sys/net/if_arp.h
--- a/sys/net/if_arp.h Sat Feb 13 07:32:19 2021 +0000
+++ b/sys/net/if_arp.h Sat Feb 13 07:57:09 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_arp.h,v 1.37 2021/02/03 18:13:13 roy Exp $ */
+/* $NetBSD: if_arp.h,v 1.38 2021/02/13 07:57:09 roy Exp $ */
/*
* Copyright (c) 1986, 1993
@@ -72,6 +72,11 @@
uint8_t ar_tpa[]; /* target protocol address */
#endif
};
+#ifdef __NO_STRICT_ALIGNMENT
+#define ARP_HDR_ALIGNED_P(ah) 1
+#else
+#define ARP_HDR_ALIGNED_P(ah) ((((vaddr_t) (ah)) & 3) == 0)
+#endif
#ifdef __CTASSERT
__CTASSERT(sizeof(struct arphdr) == 8);
#endif
diff -r 5e6889657105 -r 45ca8129d139 sys/netinet/if_arp.c
--- a/sys/netinet/if_arp.c Sat Feb 13 07:32:19 2021 +0000
+++ b/sys/netinet/if_arp.c Sat Feb 13 07:57:09 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_arp.c,v 1.298 2021/02/02 10:48:33 yamt Exp $ */
+/* $NetBSD: if_arp.c,v 1.299 2021/02/13 07:57:09 roy Exp $ */
/*
* Copyright (c) 1998, 2000, 2008 The NetBSD Foundation, Inc.
@@ -68,7 +68,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_arp.c,v 1.298 2021/02/02 10:48:33 yamt Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_arp.c,v 1.299 2021/02/13 07:57:09 roy Exp $");
#ifdef _KERNEL_OPT
#include "opt_ddb.h"
@@ -700,9 +700,19 @@
MCLAIM(m, &arpdomain.dom_mowner);
ARP_STATINC(ARP_STAT_RCVTOTAL);
- arplen = sizeof(struct arphdr);
- if (m->m_len < arplen && (m = m_pullup(m, arplen)) == NULL)
- goto badlen;
+ /* If the ARP header is not aligned, slurp it up into a new
+ * mbuf with space for link headers, in the event we forward
+ * it. Otherwise, if it is aligned, make sure the entire
+ * base ARP header is in the first mbuf of the chain.
+ */
+ if (ARP_HDR_ALIGNED_P(mtod(m, void *)) == 0) {
+ if ((m = m_copyup(m, sizeof(*ar),
+ (max_linkhdr + 3) & ~3)) == NULL)
+ goto badlen;
+ } else if (__predict_false(m->m_len < sizeof(*ar))) {
+ if ((m = m_pullup(m, sizeof(*ar))) == NULL)
+ goto badlen;
+ }
ar = mtod(m, struct arphdr *);
rcvif = m_get_rcvif(m, &s);
Home |
Main Index |
Thread Index |
Old Index