| PANIC(9) | Kernel Developer's Manual | PANIC(9) | 
void
vpanic(const char *fmt, va_list ap);
void
panic(const char *fmt, ...);
If a kernel debugger is installed, control is passed to it after the message is printed. If the kernel debugger is ddb(4), control may be passed to it, depending on the value of ddb.onpanic. See options(4) for more details on setting ddb.onpanic. If control is not passed through to ddb(4), a ddb(4)-specific function is used to print the kernel stack trace, and then control returns to panic().
If control remains in panic(), an attempt is made to save an image of system memory on the configured dump device.
If during the process of handling the panic, panic() is called again (from the filesystem synchronization routines, for example), the system is rebooted immediately without synchronizing any filesystems.
panic() is meant to be used in situations where something unexpected has happened and it is difficult to recover the system to a stable state, or in situations where proceeding might make things worse, leading to data corruption and/or loss. It is not meant to be used in scenarios where the system could easily ignore and/or isolate the condition/subsystem and proceed.
In general developers should try to reduce the number of panic() calls in the kernel to improve stability.
| September 29, 2011 | NetBSD 7.1 |