cvs commit: src/sys/i386/i386 trap.c src/sys/amd64/amd64 trap.c
John Baldwin
jhb at freebsd.org
Fri Jan 27 14:46:36 PST 2006
On Friday 27 January 2006 17:22, John Baldwin wrote:
> jhb 2006-01-27 22:22:10 UTC
>
> FreeBSD src repository
>
> Modified files:
> sys/i386/i386 trap.c
> sys/amd64/amd64 trap.c
> Log:
> Call WITNESS_CHECK() in the page fault handler and immediately assume it
> is a fatal fault if we are holding any non-sleepable locks. This should
> cut down on the number of bogus LORs we currently get when the kernel
> panics due to a NULL (or bogus) pointer dereference that goes wandering
> off into the VM system which tries to acquire locks and then kicks off
> the spurious LORs. This should probably be ported to all the archs at
> some point.
>
> Tested on: i386
Sample output for a fault with a mutex held:
32 fault with a mutex held
# sysctl debug.crash.test=32
debug.crash.testc: r0as -> h: fa0ult
with a mutex held
Kern# el page fault with the following non-sleepable locks held:
exclusive sleep mutex test r = 0 (0xc4c318d4) locked @ crash.c:95
KDB: stack backtrace:
kdb_backtrace(c0811c3c,e00dabe4,1,c4774780,c4777678) at kdb_backtrace+0x2e
witness_warn(5,0,c0773810,c4774780,0) at witness_warn+0x1d3
trap(c0540008,c4c30028,28,c4c2f910,21) at trap+0x13e
calltrap() at calltrap+0x5
--- trap 0xc, eip = 0xc4c2e1db, esp = 0xe00dacb0, ebp = 0xe00dacc4 ---
fault_with_lock(c4c304e9,c4c2ffbf,c4c2ffd7,255,0) at fault_with_lock+0x2b
crash_thread(0,e00dad38,c074f249,30e,c4774780) at crash_thread+0xdd
fork_exit(c4c2f910,0,e00dad38) at fork_exit+0x117
fork_trampoline() at fork_trampoline+0x8
--- trap 0x1, eip = 0, esp = 0xe00dad6c, ebp = 0 ---
Fatal trap 12: page fault while in kernel mode
cpuid = 3; apic id = 03
fault virtual address = 0x0
fault code = supervisor read, page not present
instruction pointer = 0x20:0xc4c2e1db
stack pointer = 0x28:0xe00dacb0
frame pointer = 0x28:0xe00dacc4
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 = 1325 (crash)
[thread pid 1325 tid 100087 ]
Stopped at fault_with_lock+0x2b: movsbl 0,%ebx
db>
--
John Baldwin <jhb at FreeBSD.org> <>< http://www.FreeBSD.org/~jhb/
"Power Users Use the Power to Serve" = http://www.FreeBSD.org
More information about the cvs-all
mailing list