diff options
author | Can Erkin Acar <canacar@cvs.openbsd.org> | 2004-08-18 18:37:54 +0000 |
---|---|---|
committer | Can Erkin Acar <canacar@cvs.openbsd.org> | 2004-08-18 18:37:54 +0000 |
commit | 0f110bcb2ab1876b57c9052cf1be0de616ee188d (patch) | |
tree | bb9180a0b5a1e2335791e201821adcfc989cacb2 /sys/net/if_gre.c | |
parent | 3e489e435dbd89ab4ad15408804ca550bfa0bcf1 (diff) |
fix bad packets passed to bpf from the gre(4) interface.
reported by Robert Stone ( robert at arbor net ) via PR 3852
This is a different fix since gre(4) may carry non-ip packets.
tested by Robert Stone and markus@ ok markus@ deraadt@
Diffstat (limited to 'sys/net/if_gre.c')
-rw-r--r-- | sys/net/if_gre.c | 24 |
1 files changed, 20 insertions, 4 deletions
diff --git a/sys/net/if_gre.c b/sys/net/if_gre.c index 51eeabeee2c..fc20588a14c 100644 --- a/sys/net/if_gre.c +++ b/sys/net/if_gre.c @@ -1,4 +1,4 @@ -/* $OpenBSD: if_gre.c,v 1.31 2003/12/16 20:33:25 markus Exp $ */ +/* $OpenBSD: if_gre.c,v 1.32 2004/08/18 18:37:53 canacar Exp $ */ /* $NetBSD: if_gre.c,v 1.9 1999/10/25 19:18:11 drochner Exp $ */ /* @@ -161,7 +161,7 @@ gre_clone_create(struct if_clone *ifc, int unit) if_alloc_sadl(&sc->sc_if); #if NBPFILTER > 0 - bpfattach(&sc->sc_if.if_bpf, &sc->sc_if, DLT_RAW, + bpfattach(&sc->sc_if.if_bpf, &sc->sc_if, DLT_NULL, sizeof(u_int32_t)); #endif s = splnet(); @@ -236,8 +236,24 @@ gre_output(struct ifnet *ifp, struct mbuf *m, struct sockaddr *dst, m_tag_prepend(m, mtag); #if NBPFILTER >0 - if (ifp->if_bpf) - bpf_mtap(ifp->if_bpf, m); + if (ifp->if_bpf) { + /* + * We need to prepend the address family as a four + * byte field. Cons up a fake header to pacify bpf. + * This is safe because bpf will only read from the + * mbuf (i.e., it won't try to free it or keep a + * pointer a to it). + */ + struct mbuf m0; + u_int32_t af = dst->sa_family; + + m0.m_flags = 0; + m0.m_next = m; + m0.m_len = 4; + m0.m_data = (char *) ⁡ + + bpf_mtap(ifp->if_bpf, &m0); + } #endif if (sc->g_proto == IPPROTO_MOBILE) { |