Nullfs - Panic when umounting and lower fs has been removed
Antoine Brodin
antoine at FreeBSD.org
Sun May 19 20:41:04 UTC 2013
Hi there,
I encountered a panic on head today with nullfs using poudriere.
It is quite easy to reproduce, the script is probably doing something
wrong but panicking is not nice
%%%
mkdir /tmp/.new_packages /mnt/new_packages
mount -t nullfs /tmp/.new_packages /mnt/new_packages
dd if=/dev/zero of=/mnt/new_packages/bar count=20000
mv /tmp/.new_packages/bar /tmp/
rm -rf /tmp/.new_packages
umount -f /mnt/new_packages
%%%
The panic:
userret: returning with the following locks held:
exclusive lockmgr ufs (ufs) r = 0 (0xfffffe0010a77548) locked @
/usr/src/sys/modules/nullfs/../../fs/nullfs/null_vnops.c:615
panic: witness_warn
cpuid = 0
KDB: enter: panic
db:1:lockinfo> show locks
exclusive lockmgr ufs (ufs) r = 0 (0xfffffe0010a77548) locked @
/usr/src/sys/modules/nullfs/../../fs/nullfs/null_vnops.c:615
db:1:locks> show alllocks
Process 1032 (umount) thread 0xfffffe0010623920 (100116)
exclusive lockmgr ufs (ufs) r = 0 (0xfffffe0010a77548) locked @
/usr/src/sys/modules/nullfs/../../fs/nullfs/null_vnops.c:615
db:1:alllocks> show lockedvnods
Locked vnodes
0xfffffe0010a774e0: tag ufs, type VDIR
usecount 0, writecount 0, refcount 0 mountedhere 0
flags (VI_FREE)
v_object 0xfffffe0010af0960 ref 0 pages 0
#0 0xffffffff8088cd59 at __lockmgr_args+0x979
#1 0xffffffff80af4df2 at ffs_lock+0x92
#2 0xffffffff80ce96f9 at VOP_LOCK1_APV+0xf9
#3 0xffffffff81a5f8df at null_lock+0xdf
#4 0xffffffff80ce96f9 at VOP_LOCK1_APV+0xf9
#5 0xffffffff8095a836 at _vn_lock+0xc6
#6 0xffffffff8094b681 at vflush+0x3a1
#7 0xffffffff81a5eace at nullfs_unmount+0x2e
#8 0xffffffff809436cb at dounmount+0x39b
#9 0xffffffff8094330b at sys_unmount+0x37b
#10 0xffffffff80c41322 at amd64_syscall+0x282
#11 0xffffffff80c2981b at Xfast_syscall+0xfb
db:0:kdb.enter.panic> bt
Tracing pid 1032 tid 100116 td 0xfffffe0010623920
kdb_enter() at kdb_enter+0x3e/frame 0xffffff8122567940
vpanic() at vpanic+0x146/frame 0xffffff8122567980
kassert_panic() at kassert_panic+0x136/frame 0xffffff81225679f0
witness_warn() at witness_warn+0x4e4/frame 0xffffff8122567ab0
userret() at userret+0x89/frame 0xffffff8122567ae0
amd64_syscall() at amd64_syscall+0x397/frame 0xffffff8122567bf0
Xfast_syscall() at Xfast_syscall+0xfb/frame 0xffffff8122567bf0
--- syscall (0, FreeBSD ELF64, nosys), rip = 0x80087abcc, rsp =
0x7fffffffd398, rbp = 0x800c0a9d0 ---
Cheers,
Antoine
More information about the freebsd-fs
mailing list