Skip site navigation (1)Skip section navigation (2)
Date:      Tue, 2 Sep 2003 06:29:07 -0700 (PDT)
From:      David Wolfskill <david@catwhisker.org>
To:        current@freebsd.org
Subject:   Oh, bother!  Fatal trap 12: page fault while in kernel mode
Message-ID:  <200309021329.h82DT7wf009714@bunrab.catwhisker.org>

next in thread | raw e-mail | index | archive | help
Running -CURRENT with sources updated between 0347 - 0356 hrs. PDT
(US/Pacific -- 7 hrs. west of GMT at this time of year) yesterday;
in the process of building today's -CURRENT.  (Had a similar-looking
problem yesterday, but I got involved in some other things, and didn't
make the time to report it in any useful manner.  So I backed off to
the previous day's kernel -- which I saved off, in case I might need it
again.)

I can let this sit for a bit, so if someone wants more specific info,
please send a note.

The machine is a dual-CPU box (2x886 MHz PIII; a single ATA disk drive);
been in service for a couple of years now, but spends a great deal of
time turned off (to reduce heat, noise, and electric bills).

It's set up to multi-boot:  I track -STABLE daily on slice 1; I track
-CURRENT daily on slice 4.  Thus, it is currently booted from /dev/ad0s4a.

Here's a cut/paste from the serial console:

Additional TCP options:.
Starting inetd.
Starting background file system checks in 60 seconds.

Tue Sep  2 06:05:00 PDT 2003

FreeBSD/i386 (freebeast.catwhisker.org) (cuaa0)

login: 

Fatal trap 12: page fault while in kernel mode
cpuid = 1; lapic.id = 01000000
fault virtual address   = 0xdeadc1e6
fault code              = supervisor read, page not present
instruction pointer     = 0x8:0xc03071e2
stack pointer           = 0x10:0xd96d5550
frame pointer           = 0x10:0xd96d5580
code segment            = base 0x0, limit 0xfffff, type 0x1b
                        = DPL 0, pres 1, def32 1, gran 1
processor eflags        = interrupt enabled, resume, IOPL = 0
current process         = 1177 (collect2)
kernel: type 12 trap, code=0
Stopped at      getdirtybuf+0x22:       cmpl    $0,0x108(%ebx)
db> tr
getdirtybuf(c468783c,0,1,1,d96d55b8) at getdirtybuf+0x22
flush_deplist(c46d0144,1,d96d55b8,d96d55bc,0) at flush_deplist+0x3d
flush_inodedep_deps(c4200000,322c0,c428fdb0,124,c03b8903) at flush_inodedep_deps+0x89
softdep_sync_metadata(d96d56f0,0,c03b8903,124,0) at softdep_sync_metadata+0x87
ffs_fsync(d96d56f0,c040d6c0,2b3,c03a6c2a,c040d6c0) at ffs_fsync+0x3b9
ffs_truncate(c428fdb0,400,0,804,c4407100) at ffs_truncate+0x6f9
ufs_direnter(c428fdb0,c47f0490,d96d5908,d96d5c00,0) at ufs_direnter+0x839
ufs_makeinode(8180,c428fdb0,d96d5bec,d96d5c00,180) at ufs_makeinode+0x274
ufs_create(d96d5a70,d96d5b2c,c024b597,d96d5a70,d96d5a6c) at ufs_create+0x39
ufs_vnoperate(d96d5a70,d96d5a6c,2,c04153e0,c43b4130) at ufs_vnoperate+0x18
vn_open_cred(d96d5bd8,d96d5cd8,180,c4407100,3) at vn_open_cred+0x187
vn_open(d96d5bd8,d96d5cd8,180,3,c03a10df) at vn_open+0x30
kern_open(c43b4130,805c120,0,a03,180) at kern_open+0x13a
open(c43b4130,d96d5d10,c03c06c7,3eb,3) at open+0x30
syscall(2f,2f,2f,805c120,805c129) at syscall+0x2b3
Xint0x80_syscall() at Xint0x80_syscall+0x1d
--- syscall (5, FreeBSD ELF32, open), eip = 0x280cd8cf, esp = 0xbfbff11c, ebp = 0xbfbff1c8 ---
db> show pcpu 0 
cpuid        = 0
curthread    = 0xc150e980: pid 33 "pagezero"
curpcb       = 0xd7173da0
fpcurthread  = none
idlethread   = 0xc1507980: pid 12 "idle: cpu0"
currentldt   = 0x28
spin locks held:
db> show pcpu 1
cpuid        = 1
curthread    = 0xc43b4130: pid 1177 "collect2"
curpcb       = 0xd96d5da0
fpcurthread  = none
idlethread   = 0xc1507850: pid 11 "idle: cpu1"
currentldt   = 0x28
spin locks held:
db> panic
panic: from debugger
cpuid = 1; lapic.id = 01000000
boot() called on cpu#1
Uptime: 7m42s
pfs_vncache_unload(): 1 entries remaining
Shutting down ACPI
panic: absolutely cannot call smp_ipi_shootdown with interrupts already disabled
cpuid = 1; lapic.id = 01000000
boot() called on cpu#1
Uptime: 7m42s
kernel trap 12 with interrupts disabled


Fatal trap 12: page fault while in kernel mode
cpuid = 1; lapic.id = 01000000
fault virtual address   = 0xdeadc0e2
fault code              = supervisor write, page not present
instruction pointer     = 0x8:0xc0202855
stack pointer           = 0x10:0xd96d4f28
frame pointer           = 0x10:0xd96d4f40
code segment            = base 0x0, limit 0xfffff, type 0x1b
                        = DPL 0, pres 1, def32 1, gran 1
processor eflags        = resume, IOPL = 0
current process         = 1177 (collect2)
kernel: type 12 trap, code=0
Stopped at      eventhandler_deregister+0x45:   movl    %eax,0x4(%edx)
db> 

As noted, I'll leave it in this state for a bit, in case anyone wants me
to extract some more information from it; it doesn't look as if getting
a crash dump is going to happen (and apparently I wouldn't be able to
save it even if I got one).

Thanks....

Peace,
david
-- 
David H. Wolfskill				david@catwhisker.org
If you want true virus-protection for your PC, install a non-Microsoft OS
on it.  Plausible candidates include FreeBSD, Linux, NetBSD, OpenBSD, and
Solaris (in alphabetical order).



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200309021329.h82DT7wf009714>