Skip site navigation (1)Skip section navigation (2)
Date:      Thu, 18 Jun 2015 21:24:35 +0000
From:      bugzilla-noreply@freebsd.org
To:        freebsd-pf@FreeBSD.org
Subject:   [Bug 200330] panic: pf_addr_cmp: unknown address family 0 when scrub fragment drop-ovl is used
Message-ID:  <bug-200330-17777-eyDLEoHVTr@https.bugs.freebsd.org/bugzilla/>
In-Reply-To: <bug-200330-17777@https.bugs.freebsd.org/bugzilla/>
References:  <bug-200330-17777@https.bugs.freebsd.org/bugzilla/>

next in thread | previous in thread | raw e-mail | index | archive | help
https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=200330

--- Comment #19 from commit-hook@freebsd.org ---
A commit references this bug:

Author: kp
Date: Thu Jun 18 21:23:42 UTC 2015
New revision: 284580
URL: https://svnweb.freebsd.org/changeset/base/284580

Log:
  Merge r284222, r284260

  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).

  When we try to look up a pf_fragment with pf_find_fragment() we compare (see
  pf_frag_compare()) addresses (and family), but also protocol.  We failed to
  save the protocol to the pf_fragment in pf_fragcache(), resulting in failing
  reassembly.

  PR:        200330
  Differential Revision:    https://reviews.freebsd.org/D2824
  Reviewed by:    gnn

Changes:
_U  stable/10/
  stable/10/sys/netpfil/pf/pf_norm.c

-- 
You are receiving this mail because:
You are on the CC list for the bug.



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?bug-200330-17777-eyDLEoHVTr>