How to inject fullsize 802.1q-tagged frame through BPF?
Christian S.J. Peron
csjp at FreeBSD.org
Mon May 19 23:40:33 UTC 2008
Eugene,
Thanks for the report. I will look into this. Although this patch technically
works, I think the right solution to this problem is to introduce a new DLT_
for VLAN encapsulated frames. I will look into this problem in a bit more
detail.
On Mon, May 19, 2008 at 04:07:22PM +0300, Eugene Perevyazko wrote:
> On Thu, May 15, 2008 at 12:21:23PM -0400, Sam Leffler wrote:
> > Eugene Perevyazko wrote:
> > > Is there a way to inject full-mtu vlan-tagged frame through BPF on parent
> > >device?
> > > I'd like not to open several tenths of BPFs for each vlanN if it's
> > > possible.
> >
> > bpf write code in the kernel calculates header size when packets are
> > injected. This is likely based on the frames being stock 802.3 so would
> > require mods to the bpf code to handle the additional space for the tag.
>
> I've made a simple patch that works for me on FreeBSD 6.2-RELEASE #1.
> Not sure if this is the way to do it, but it "just works". May be someone
> else will need such feature too.
>
> Eugene Perevyazko
>
>
> --- bpf.c.old Mon May 19 10:47:55 2008
> +++ bpf.c Mon May 19 10:57:44 2008
> @@ -64,6 +64,7 @@
> #include <sys/socket.h>
>
> #include <net/if.h>
> +#include <net/ethernet.h>
> #include <net/bpf.h>
> #include <net/bpfdesc.h>
>
> @@ -617,7 +618,9 @@
> return (0);
>
> bzero(&dst, sizeof(dst));
> - error = bpf_movein(uio, (int)d->bd_bif->bif_dlt, ifp->if_mtu,
> + /* Use VLAN_MTU capability, if supported */
> + error = bpf_movein(uio, (int)d->bd_bif->bif_dlt,
> + ifp->if_mtu + ( (ifp->if_capenable & IFCAP_VLAN_MTU) ? ETHER_VLAN_ENCAP_LEN : 0 ),
> &m, &dst, d->bd_wfilter);
> if (error)
> return (error);
> _______________________________________________
> freebsd-net at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/freebsd-net
> To unsubscribe, send any mail to "freebsd-net-unsubscribe at freebsd.org"
More information about the freebsd-net
mailing list