Studying a panic
The following list outlines the process
for determining which kernel component
caused a system panic.
For detailed information about interpreting
crash(ADM)
output, see
``Using the crash(ADM) diagnostic tool''.
-
PANICBOOT=NO must be set
in the /etc/default/boot file for this to work.
-
When the system panics,
write down the type of panic (see the
trap(M)
manual page),
the EIP number, and the size of the dump in pages
from the console display.
-
When the machine reboots,
save the kernel dump that is on the dump device
as shown in
``Recovering from a system panic''.
-
Put the machine in single-user mode.
-
Run
crash(ADM)
on the image.
-
Use the panic command in crash
to find the routine in which the panic happened.
Be sure to verify that
the trap type and EIP
match those copied from the console screen after the panic.
-
Note the name (symbol name)
of the routine that was executing
when the system panicked.
This is the function listed first under the
Kernel Stack before Trap
line.
-
Quit the crash command.
-
Use
strings(C)
or
nm(CP)
to determine the driver in which that routine is located.
You can run a script such as the following,
which uses strings.
:
for FILE in `find /etc/conf/pack.d -name '*.[oa]' -print`
do
strings $FILE | grep $1 && echo $FILE
done
If this script were installed as findpanic,
you would run it with one argument
that gives the name of the kernel routine:
findpanic symbol_name
This script will output something like:
routine_name
/etc/conf/pack.d/foo/Driver.o
This indicates that the foo driver
may have been responsible for the system panic.
Next topic:
Additional help from Technical Support
Previous topic:
Examining a memory dump with crash(ADM)
© 2005 The SCO Group, Inc. All rights reserved.
SCO OpenServer Release 6.0.0 -- 03 June 2005