Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/sys/net vlan: drop tagged outgoing packets
details: https://anonhg.NetBSD.org/src/rev/5531d9f3b3e6
branches: trunk
changeset: 984647:5531d9f3b3e6
user: yamaguchi <yamaguchi%NetBSD.org@localhost>
date: Thu Jul 15 04:05:47 2021 +0000
description:
vlan: drop tagged outgoing packets
vlan(4) doesn't support Q-in-Q yet.
diffstat:
sys/net/if_vlan.c | 36 ++++++++++++++++++++++++++++++++++--
1 files changed, 34 insertions(+), 2 deletions(-)
diffs (75 lines):
diff -r c40ab005d742 -r 5531d9f3b3e6 sys/net/if_vlan.c
--- a/sys/net/if_vlan.c Thu Jul 15 03:25:50 2021 +0000
+++ b/sys/net/if_vlan.c Thu Jul 15 04:05:47 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: if_vlan.c,v 1.159 2021/07/14 06:50:22 yamaguchi Exp $ */
+/* $NetBSD: if_vlan.c,v 1.160 2021/07/15 04:05:47 yamaguchi Exp $ */
/*
* Copyright (c) 2000, 2001 The NetBSD Foundation, Inc.
@@ -78,7 +78,7 @@
*/
#include <sys/cdefs.h>
-__KERNEL_RCSID(0, "$NetBSD: if_vlan.c,v 1.159 2021/07/14 06:50:22 yamaguchi Exp $");
+__KERNEL_RCSID(0, "$NetBSD: if_vlan.c,v 1.160 2021/07/15 04:05:47 yamaguchi Exp $");
#ifdef _KERNEL_OPT
#include "opt_inet.h"
@@ -1321,6 +1321,7 @@
struct mbuf *m;
struct ifvlan_linkmib *mib;
struct psref psref;
+ struct ether_header *eh;
int error;
mib = vlan_getref_linkmib(ifv, &psref);
@@ -1342,6 +1343,21 @@
if (m == NULL)
break;
+ if (m->m_len < sizeof(*eh)) {
+ m = m_pullup(m, sizeof(*eh));
+ if (m == NULL) {
+ if_statinc(ifp, if_oerrors);
+ continue;
+ }
+ }
+
+ eh = mtod(m, struct ether_header *);
+ if (ntohs(eh->ether_type) == ETHERTYPE_VLAN) {
+ m_freem(m);
+ if_statinc(ifp, if_noproto);
+ continue;
+ }
+
#ifdef ALTQ
/*
* KERNEL_LOCK is required for ALTQ even if NET_MPSAFE is
@@ -1465,10 +1481,26 @@
struct ethercom *ec;
struct ifvlan_linkmib *mib;
struct psref psref;
+ struct ether_header *eh;
int error;
size_t pktlen = m->m_pkthdr.len;
bool mcast = (m->m_flags & M_MCAST) != 0;
+ if (m->m_len < sizeof(*eh)) {
+ m = m_pullup(m, sizeof(*eh));
+ if (m == NULL) {
+ if_statinc(ifp, if_oerrors);
+ return ENOBUFS;
+ }
+ }
+
+ eh = mtod(m, struct ether_header *);
+ if (ntohs(eh->ether_type) == ETHERTYPE_VLAN) {
+ m_freem(m);
+ if_statinc(ifp, if_noproto);
+ return EPROTONOSUPPORT;
+ }
+
mib = vlan_getref_linkmib(ifv, &psref);
if (mib == NULL) {
m_freem(m);
Home |
Main Index |
Thread Index |
Old Index