SIGSEGV
|
|
It has been suggested that this article or section be merged into Unix signal . (Discuss) Proposed since January 2012. |
| Description | Invalid memory reference | ||||
|---|---|---|---|---|---|
| Default action | Abnormal termination of the process | ||||
| SA_SIGINFO macros | |||||
|
|||||
On POSIX-compliant platforms, SIGSEGV is the signal sent to a process when it makes an invalid memory reference, or segmentation fault. The symbolic constant for SIGSEGV is defined in the header file signal.h. Symbolic signal names are used because signal numbers can vary across platforms; in practice it is usually signal number 11.[1]
Contents |
[edit] Etymology
SIG is a common prefix for signal names; SEGV is an abbreviation of segmentation violation.
[edit] Usage
Computer programs may throw SIGSEGV for improper memory handling (see segmentation fault). The operating system may inform the application of the nature of the error using the signal stack, which developers can use to debug their programs or handle errors.
The default action for a program upon receiving SIGSEGV is abnormal termination. This action will end the process, but may generate a core file to aid debugging, or perform some other platform-dependent action. For example, Linux systems using the grsecurity patch may log SIGSEGV signals in order to monitor for possible intrusion attempts using buffer overflows.
SIGSEGV can be caught; that is, applications can request what action they want to occur in place of the default. Examples of such action might be ignoring it, calling a function, or restoring the default action. In some circumstances, ignoring SIGSEGV results in undefined behavior.[2]
An example of an application that might handle SIGSEGV is a debugger, which might check the signal stack and inform the developer of what happened, and where the program terminated.
SIGSEGV is usually generated by the operating system, but users with appropriate permissions can use the kill system call or kill command (a userland program, or sometimes a shell builtin) to send the signal to a process at will.
[edit] References
- ^ "sourceware.org Git - glibc.git/blob - bits/signum.h". 2001-07-06. http://sourceware.org/git/?p=glibc.git;a=blob;f=bits/signum.h. Retrieved 2009-11-18T05:37:46+00:00.
- ^ "System Interfaces Chapter 2". 2004. http://www.opengroup.org/onlinepubs/009695399/functions/xsh_chap02_04.html. Retrieved 2009-11-18T06:51:28+00:00.
[edit] External links
|
||||||||