svn commit: r284222 - head/sys/netpfil/pf
Oliver Pinter
oliver.pinter at hardenedbsd.org
Wed Jun 10 14:53:36 UTC 2015
On 6/10/15, Kristof Provost <kp at freebsd.org> wrote:
> Author: kp
> Date: Wed Jun 10 13:44:04 2015
> New Revision: 284222
> URL: https://svnweb.freebsd.org/changeset/base/284222
>
> Log:
> pf: address family must be set when creating a pf_fragment
>
> Fix a panic when handling fragmented ip4 packets with 'drop-ovl' set.
> In that scenario we take a different branch in pf_normalize_ip(), taking
> us to
> pf_fragcache() (rather than pf_reassemble()). In pf_fragcache() we create
> a
> pf_fragment, but do not set the address family. This leads to a panic when
> we
> try to insert that into pf_frag_tree because pf_addr_cmp(), which is used
> to
> compare the pf_fragments doesn't know what to do if the address family is
> not
> set.
>
> Simply ensure that the address family is set correctly (always AF_INET in
> this
> path).
>
> PR: 200330
> Differential Revision: https://reviews.freebsd.org/D2769
> Approved by: philip (mentor), gnn (mentor)
>
> Modified:
> head/sys/netpfil/pf/pf_norm.c
This commit required to 10-STABLE too or this bug exists only in
11-CURRENT? If the former, you have any plan to MFC the patch?
>
> Modified: head/sys/netpfil/pf/pf_norm.c
> ==============================================================================
> --- head/sys/netpfil/pf/pf_norm.c Wed Jun 10 13:17:41 2015 (r284221)
> +++ head/sys/netpfil/pf/pf_norm.c Wed Jun 10 13:44:04 2015 (r284222)
> @@ -823,6 +823,7 @@ pf_fragcache(struct mbuf **m0, struct ip
> (*frag)->fr_max = 0;
> (*frag)->fr_src.v4 = h->ip_src;
> (*frag)->fr_dst.v4 = h->ip_dst;
> + (*frag)->fr_af = AF_INET;
> (*frag)->fr_id = h->ip_id;
> (*frag)->fr_timeout = time_uptime;
>
> _______________________________________________
> svn-src-head at freebsd.org mailing list
> http://lists.freebsd.org/mailman/listinfo/svn-src-head
> To unsubscribe, send any mail to "svn-src-head-unsubscribe at freebsd.org"
>
More information about the svn-src-all
mailing list