summaryrefslogtreecommitdiff
path: root/sys
diff options
context:
space:
mode:
Diffstat (limited to 'sys')
-rw-r--r--sys/net/if_bridge.c21
-rw-r--r--sys/net/if_bridge.h4
-rw-r--r--sys/net/if_ethersubr.c10
3 files changed, 23 insertions, 12 deletions
diff --git a/sys/net/if_bridge.c b/sys/net/if_bridge.c
index e102794dae4..9a776852e07 100644
--- a/sys/net/if_bridge.c
+++ b/sys/net/if_bridge.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_bridge.c,v 1.15 1999/08/20 04:53:17 jason Exp $ */
+/* $OpenBSD: if_bridge.c,v 1.16 1999/09/01 21:38:48 jason Exp $ */
/*
* Copyright (c) 1999 Jason L. Wright (jason@thought.net)
@@ -608,6 +608,16 @@ bridge_output(ifp, m, sa, rt)
s = splimp();
/*
+ * If bridge is down, but original output interface is up,
+ * go ahead and send out that interface. Otherwise the packet
+ * is dropped below.
+ */
+ if ((sc->sc_if.if_flags & IFF_RUNNING) == 0) {
+ dst_if = ifp;
+ goto sendunicast;
+ }
+
+ /*
* If the packet is a broadcast or we don't know a better way to
* get there, we must broadcast with header rewriting.
*/
@@ -665,6 +675,8 @@ bridge_output(ifp, m, sa, rt)
}
bcopy(ac->ac_enaddr, src, ETHER_ADDR_LEN);
+
+sendunicast:
if ((dst_if->if_flags & IFF_RUNNING) == 0) {
m_freem(m);
splx(s);
@@ -860,11 +872,10 @@ bridgeintr(void)
* bridge members.
*/
struct mbuf *
-bridge_input(ifp, eh, m, forme)
+bridge_input(ifp, eh, m)
struct ifnet *ifp;
struct ether_header *eh;
struct mbuf *m;
- int *forme;
{
struct bridge_softc *sc;
int s;
@@ -912,10 +923,8 @@ bridge_input(ifp, eh, m, forme)
while (ifl != NULL) {
ac = (struct arpcom *)ifl->ifp;
if (bcmp(ac->ac_enaddr, eh->ether_dhost,
- ETHER_ADDR_LEN) == 0) {
- *forme = 1;
+ ETHER_ADDR_LEN) == 0)
return (m);
- }
ifl = LIST_NEXT(ifl, next);
}
M_PREPEND(m, sizeof(*eh), M_DONTWAIT);
diff --git a/sys/net/if_bridge.h b/sys/net/if_bridge.h
index ee193e94dff..1392add2813 100644
--- a/sys/net/if_bridge.h
+++ b/sys/net/if_bridge.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_bridge.h,v 1.8 1999/08/08 02:42:58 niklas Exp $ */
+/* $OpenBSD: if_bridge.h,v 1.9 1999/09/01 21:38:48 jason Exp $ */
/*
* Copyright (c) 1999 Jason L. Wright (jason@thought.net)
@@ -103,7 +103,7 @@ struct ifbcachetoreq {
#ifdef _KERNEL
void bridge_ifdetach __P((struct ifnet *));
struct mbuf *bridge_input __P((struct ifnet *, struct ether_header *,
- struct mbuf *, int *));
+ struct mbuf *));
int bridge_output __P((struct ifnet *, struct mbuf *, struct sockaddr *,
struct rtentry *rt));
#endif /* _KERNEL */
diff --git a/sys/net/if_ethersubr.c b/sys/net/if_ethersubr.c
index 088923828a4..c22ba6d04ea 100644
--- a/sys/net/if_ethersubr.c
+++ b/sys/net/if_ethersubr.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: if_ethersubr.c,v 1.30 1999/08/08 02:42:58 niklas Exp $ */
+/* $OpenBSD: if_ethersubr.c,v 1.31 1999/09/01 21:38:48 jason Exp $ */
/* $NetBSD: if_ethersubr.c,v 1.19 1996/05/07 02:40:30 thorpej Exp $ */
/*
@@ -506,7 +506,7 @@ ether_input(ifp, eh, m)
{
register struct ifqueue *inq;
u_int16_t etype;
- int s, llcfound = 0, forme = 0;
+ int s, llcfound = 0;
register struct llc *l;
struct arpcom *ac = (struct arpcom *)ifp;
@@ -534,16 +534,18 @@ ether_input(ifp, eh, m)
* gets processed as normal.
*/
if (ifp->if_bridge) {
- m = bridge_input(ifp, eh, m, &forme);
+ m = bridge_input(ifp, eh, m);
if (m == NULL)
return;
+ /* The bridge has determined it's for us. */
+ goto decapsulate;
}
#endif
/*
* If packet is unicast and we're in promiscuous mode, make sure it
* is for us. Drop otherwise.
*/
- if (!forme && (m->m_flags & (M_BCAST|M_MCAST)) == 0 &&
+ if ((m->m_flags & (M_BCAST|M_MCAST)) == 0 &&
(ifp->if_flags & IFF_PROMISC)) {
if (bcmp(ac->ac_enaddr, (caddr_t)eh->ether_dhost,
ETHER_ADDR_LEN)) {