summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorCamiel Dobbelaar <camield@cvs.openbsd.org>2005-06-07 07:09:43 +0000
committerCamiel Dobbelaar <camield@cvs.openbsd.org>2005-06-07 07:09:43 +0000
commit8e50e9947d0a355ca0701c231824311f3a884d0a (patch)
tree0dc57d67d836d2b4ae25d5b29596688dec187d61
parent5f0acf6733ad1ae34d35f4ab7a099498aa3d635d (diff)
Run vlan_input before bridge_input, and change vlan_input to not
consume vlan frames that no vlan interface wants, so they can still be bridged. This way, the bridge can bridge encapsulated frames _and_ bridge between vlan interfaces. ok henning markus
-rw-r--r--sys/net/if_ethersubr.c12
-rw-r--r--sys/net/if_vlan.c13
2 files changed, 18 insertions, 7 deletions
diff --git a/sys/net/if_ethersubr.c b/sys/net/if_ethersubr.c
index 87a6faf5f73..e4995d3ffb8 100644
--- a/sys/net/if_ethersubr.c
+++ b/sys/net/if_ethersubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ethersubr.c,v 1.94 2005/06/07 02:45:11 henning Exp $ */
+/* $OpenBSD: if_ethersubr.c,v 1.95 2005/06/07 07:09:42 camield Exp $ */
/* $NetBSD: if_ethersubr.c,v 1.19 1996/05/07 02:40:30 thorpej Exp $ */
/*
@@ -621,6 +621,11 @@ ether_input(ifp, eh, m)
etype = ntohs(eh->ether_type);
+#if NVLAN > 0
+ if (etype == ETHERTYPE_VLAN && (vlan_input(eh, m) == 0))
+ return;
+#endif
+
#if NBRIDGE > 0
/*
* Tap the packet off here for a bridge, if configured and
@@ -643,8 +648,9 @@ ether_input(ifp, eh, m)
#if NVLAN > 0
if (etype == ETHERTYPE_VLAN) {
- if (vlan_input(eh, m) < 0)
- ifp->if_noproto++;
+ /* The bridge did not want the vlan frame either, drop it. */
+ ifp->if_noproto++;
+ m_freem(m);
return;
}
#endif /* NVLAN > 0 */
diff --git a/sys/net/if_vlan.c b/sys/net/if_vlan.c
index 0e0938cdeb8..9fd46bf5064 100644
--- a/sys/net/if_vlan.c
+++ b/sys/net/if_vlan.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_vlan.c,v 1.55 2005/05/27 08:33:25 mpf Exp $ */
+/* $OpenBSD: if_vlan.c,v 1.56 2005/06/07 07:09:42 camield Exp $ */
/*
* Copyright 1998 Massachusetts Institute of Technology
@@ -328,6 +328,9 @@ vlan_input_tag(struct mbuf *m, u_int16_t t)
return 0;
}
+/*
+ * vlan_input() returns 0 if it has consumed the packet, 1 otherwise.
+ */
int
vlan_input(eh, m)
struct ether_header *eh;
@@ -349,11 +352,13 @@ vlan_input(eh, m)
if (m->m_pkthdr.rcvif == ifv->ifv_p && tag == ifv->ifv_tag)
break;
}
+ if (ifv == NULL)
+ return (1);
- if (ifv == NULL || (ifv->ifv_if.if_flags & (IFF_UP|IFF_RUNNING)) !=
+ if ((ifv->ifv_if.if_flags & (IFF_UP|IFF_RUNNING)) !=
(IFF_UP|IFF_RUNNING)) {
m_freem(m);
- return -1; /* so ether_input can take note */
+ return (0);
}
/*
@@ -389,7 +394,7 @@ vlan_input(eh, m)
ifv->ifv_if.if_ipackets++;
ether_input(&ifv->ifv_if, eh, m);
- return 0;
+ return (0);
}
int