panic in vgonel()
pluknet
pluknet at gmail.com
Fri Aug 7 12:48:40 UTC 2009
2009/8/7 Kostik Belousov <kostikbel at gmail.com>:
> On Fri, Aug 07, 2009 at 04:37:07PM +0400, pluknet wrote:
>> 2009/8/7 Kostik Belousov <kostikbel at gmail.com>:
>> > On Fri, Aug 07, 2009 at 03:37:11PM +0400, pluknet wrote:
>> >> This is on 7.2-R amd64.
>> >>
>> >> I'm curious if it might be due to glusterfs on it.
>> >>
>> >> Fatal trap 12: page fault while in kernel mode
>> >> cpuid = 3; apic id = 03
>> >> fault virtual address = 0x0
>> >> fault code = supervisor write data, page not present
>> >> instruction pointer = 0x8:0xffffffff805a52ba
>> >> stack pointer = 0x10:0xfffffffefc3474a0
>> >> frame pointer = 0x10:0xfffffffefc347510
>> >> code segment = base 0x0, limit 0xfffff, type
>> >> = DPL 0, pres 1, long 1, def32 0, gran 1
>> >> processor eflags = interrupt enabled, resume, IOPL = 0
>> >> current process = 35425 (find)
>> >>
>> >> db> bt
>> >> Tracing pid 35425 tid 100194 td 0xffffff003c165370
>> >> vgonel() at vgonel+0x1aa
>> >> vnlru_free() at vnlru_free+0x36c
>> >> getnewvnode() at getnewvnode+0x281
>> >> ffs_vgetf() at ffs_vgetf+0xdf
>> >> ufs_lookup() at ufs_lookup+0x2dd
>> >> vfs_cache_lookup() at vfs_cache_lookup+0xf3
>> >> VOP_LOOKUP_APV() at VOP_LOOKUP_APV+0x40
>> >> lookup() at lookup+0x598
>> >> namei() at namei+0x33e
>> >> kern_lstat() at kern_lstat+0x5e
>> >> lstat() at lstat+0x2a
>> >> syscall() at syscall+0x256
>> >> Xfast_syscall() at Xfast_syscall+0xab
>> >> --- syscall (190, FreeBSD ELF64, lstat), rip = 0x80071063c, rsp =
>> >> 0x7fffffffea48, rbp = 0x800a06910 ---
>> >
>> > Did you got the vmcore ? If yes, please find the value for vgonel()
>> > argument, vp, and print the vnode content.
>>
>> I didn't. Same problem as in my another mail. :(
>>
>> >
>> > Regardless of this, look up the source line for vgonel+0x1aa.
>> >
>>
>> I could resolve only address which belongs to instruction pointer
>> = 0x8:0xffffffff805a52ba
>> (eh, I don't know if I should sum these numbers, so I did this for both cases):
>>
>> dev2# addr2line -e /boot/kernel/kernel.symbols 0xffffffff805a52ba
>> /usr/src/sys/kern/vfs_subr.c:979
>> delmntque(): TAILQ_REMOVE(&mp->mnt_nvnodelist, vp, v_nmntvnodes);
>>
>> dev2# addr2line -e /boot/kernel/kernel.symbols 0xffffffff805a52c2
>> /usr/src/sys/kern/vfs_subr.c:981
>> delmntque(): MNT_REL(mp);
>
> load kernel.debug into gdb, and then do "list *(vgonel+0x1aa)"
>
Ah, of course. Sorry.
(gdb) list *(vgonel+0x1aa)
0xffffffff805a52ba is in vgonel (/usr/src/sys/kern/vfs_subr.c:979).
974 return;
975 MNT_ILOCK(mp);
976 vp->v_mount = NULL;
977 VNASSERT(mp->mnt_nvnodelistsize > 0, vp,
978 ("bad mount point vnode list size"));
979 TAILQ_REMOVE(&mp->mnt_nvnodelist, vp, v_nmntvnodes);
980 mp->mnt_nvnodelistsize--;
981 MNT_REL(mp);
982 MNT_IUNLOCK(mp);
983 }
--
wbr,
pluknet
More information about the freebsd-stable
mailing list