Bug 194515 - [pf] [vnet] Fatal Trap 12 Kernel with vimage
Summary: [pf] [vnet] Fatal Trap 12 Kernel with vimage
Status: Closed FIXED
Alias: None
Product: Base System
Classification: Unclassified
Component: kern (show other bugs)
Version: 10.1-STABLE
Hardware: amd64 Any
: Normal Affects Many People
Assignee: Bjoern A. Zeeb
URL:
Keywords: crash
: 143808 148155 160496 160541 161094 176112 179264 188018 (view as bug list)
Depends on:
Blocks:
 
Reported: 2014-10-21 18:33 UTC by Ivan
Modified: 2018-10-19 21:07 UTC (History)
15 users (show)

See Also:
koobs: mfc-stable10?


Attachments
fatal_trap12-p1.png (73.88 KB, image/png)
2014-12-13 05:27 UTC, Craig Rodrigues
no flags Details
pf_min.conf (1.79 KB, text/plain)
2014-12-13 05:28 UTC, Craig Rodrigues
no flags Details

Note You need to log in before you can comment on or make changes to this bug.
Description Ivan 2014-10-21 18:33:05 UTC
its enough to start pf inside jail to reproduce this bug.

i  was add to kernel only these options:

options VIMAGE
device pf

final trap image can be seen at http://s25.postimg.org/qmumaj5y7/fatal_trap12.png

uname -a 
FreeBSD host 10.1-RC2 FreeBSD 10.1-RC2 #2: Tue Oct 21 15:22:30 MSK 2014     admin@host:/usr/src/sys/amd64/compile/MSRV  amd64
Comment 1 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-07 22:37:52 UTC
Can you provide more details:

(1)  What command did you use to start the jail?

(2)  What config file did you use for pf?

(3)  What command did you use to start pf?
Comment 2 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 05:27:32 UTC
Created attachment 150526 [details]
fatal_trap12-p1.png
Comment 3 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 05:28:16 UTC
Created attachment 150527 [details]
pf_min.conf
Comment 4 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 05:28:43 UTC
---------- Forwarded message ----------
From: Ivan UAdm <ivan.uadm@gmail.com>
Date: Wed, Dec 10, 2014 at 8:49 AM
Subject: bug id 194515


Hi, Craig

i was update enviroment to 10.1-release, but bug is still there


> Can you provide more details:

(1)  What command did you use to start the jail?
 i start with: jail -c persist name=testjail001 vnet path=/usr/local/jails/testjail001 host.hostname=testjail001 allow.raw_sockets allow.socket_af

(2)  What config file did you use for pf?
see in attach
(3)  What command did you use to start pf?
i start with /etc/rc.d/pf start at jailstart time

-- 
MVH, Ivan
mobile: +7 931 250 2064
Comment 5 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 12:33:12 UTC
*** Bug 188018 has been marked as a duplicate of this bug. ***
Comment 6 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 12:34:39 UTC
(In reply to Craig Rodrigues from comment #5)
> *** Bug 188018 has been marked as a duplicate of this bug. ***

Remember to test:  pfctl -sr -v
Comment 7 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 12:35:35 UTC
*** Bug 143808 has been marked as a duplicate of this bug. ***
Comment 8 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 12:38:49 UTC
*** Bug 179264 has been marked as a duplicate of this bug. ***
Comment 9 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 12:39:31 UTC
(In reply to Craig Rodrigues from comment #8)
> *** Bug 179264 has been marked as a duplicate of this bug. ***

See also:

http://lists.freebsd.org/pipermail/freebsd-virtualization/2013-June/001296.html
Comment 10 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 12:40:53 UTC
*** Bug 161094 has been marked as a duplicate of this bug. ***
Comment 11 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 12:46:12 UTC
*** Bug 176112 has been marked as a duplicate of this bug. ***
Comment 12 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 12:56:24 UTC
*** Bug 160541 has been marked as a duplicate of this bug. ***
Comment 13 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 13:00:09 UTC
*** Bug 160496 has been marked as a duplicate of this bug. ***
Comment 14 Craig Rodrigues freebsd_committer freebsd_triage 2014-12-13 21:31:07 UTC
*** Bug 148155 has been marked as a duplicate of this bug. ***
Comment 15 commit-hook freebsd_committer freebsd_triage 2015-01-06 08:39:32 UTC
A commit references this bug:

Author: rodrigc
Date: Tue Jan  6 08:39:09 UTC 2015
New revision: 276746
URL: https://svnweb.freebsd.org/changeset/base/276746

Log:
  Merge: r258322 from projects/pf branch

      Split functions that initialize various pf parts into their
      vimage parts and global parts.
      Since global parts appeared to be only mutex initializations, just
      abandon them and use MTX_SYSINIT() instead.
      Kill my incorrect VNET_FOREACH() iterator and instead use correct
      approach with VNET_SYSINIT().

  PR:			194515
  Differential Revision:	D1309
  Submitted by: 		glebius, Nikos Vassiliadis <nvass@gmx.com>
  Reviewed by: 		trociny, zec, gnn

Changes:
  head/sys/net/pfvar.h
  head/sys/netpfil/pf/pf.c
  head/sys/netpfil/pf/pf_if.c
  head/sys/netpfil/pf/pf_ioctl.c
  head/sys/netpfil/pf/pf_norm.c
  head/sys/netpfil/pf/pf_table.c
Comment 16 commit-hook freebsd_committer freebsd_triage 2015-01-06 09:03:42 UTC
A commit references this bug:

Author: rodrigc
Date: Tue Jan  6 09:03:04 UTC 2015
New revision: 276747
URL: https://svnweb.freebsd.org/changeset/base/276747

Log:
  Instead of creating a purge thread for every vnet, create
  a single purge thread and clean up all vnets from this thread.

  PR:                     194515
  Differential Revision:  D1315
  Submitted by:           Nikos Vassiliadis <nvass@gmx.com>

Changes:
  head/sys/netpfil/pf/pf.c
Comment 17 commit-hook freebsd_committer freebsd_triage 2015-01-06 16:47:24 UTC
A commit references this bug:

Author: rodrigc
Date: Tue Jan  6 16:47:04 UTC 2015
New revision: 276756
URL: https://svnweb.freebsd.org/changeset/base/276756

Log:
  Reapply previous patch to fix build.

  PR: 194515

Changes:
  head/sys/net/pfvar.h
  head/sys/netpfil/pf/pf.c
  head/sys/netpfil/pf/pf_if.c
  head/sys/netpfil/pf/pf_ioctl.c
  head/sys/netpfil/pf/pf_norm.c
Comment 18 Daniel O'Connor 2015-01-19 02:34:07 UTC
Is this going to be MFCd?
The 3 commits apply cleanly to stable/10 and seem to work (but I have only tested it lightly so far)
Comment 19 Craig Rodrigues freebsd_committer freebsd_triage 2015-01-24 20:50:39 UTC
(In reply to darius from comment #18)

I'm OK with merging this to stable/10, but I would like to get
some feedback from PF users on the state of things in CURRENT before merging.
What is your experience with this patch?
Herbert Skuhra has provided good feedback, but getting a few more people
to try it and report would be great.

Herbert found another bug in CURRENT: https://bugs.freebsd.org/bugzilla/show_bug.cgi?id=195859

That is a bug in the bridge code, and not part of the VIMAGE + PF fixes.
However, all this stuff is interrelated.

It would be nice to get a fix in for PR 195859, so provide a consistent
testing environment for VIMAGE in CURRENT.  That will make it easier to
backport patches to stable/10.
Comment 20 Marcus von Appen freebsd_committer freebsd_triage 2015-02-18 11:54:19 UTC
Updated 10.1-BETA and 10.1-RC versioned bugs to 10.1-STABLE.
Comment 21 Bartek Rutkowski freebsd_committer freebsd_triage 2015-04-24 21:03:16 UTC
Is there any update on these fixes? I've just happened to bump my 10.1-RELEASE into 10-STABLE and created few VIMAGE based jails. As soon as I stop any of them, and I can reproduce it every time, the host OS crashes. That makes the entire VIMAGE completely unusable...
Comment 22 Craig Rodrigues freebsd_committer freebsd_triage 2015-04-27 05:35:37 UTC
The commits done under https://svnweb.freebsd.org/changeset/base/276756
were backed out in https://svnweb.freebsd.org/changeset/base/277519 .

Nikos is working on another patch https://reviews.freebsd.org/D1944
Comment 23 Eugene Grosbein freebsd_committer freebsd_triage 2018-04-16 08:19:10 UTC
It seems the problem was fixed with r302156 before stable/11 was branched but never merged to stable/10.
Comment 24 Kristof Provost freebsd_committer freebsd_triage 2018-10-19 21:07:21 UTC
vnet is now supported in 12.0 (but not in earlier releases).
Many vent-related problems were fixed in pf (and pf-in-vnet-jails is now part of our automated tests).

Please re-open it if you're still having issues on 12 or later.