15ffd83dbSDimitry Andric //===-- LinuxSignals.cpp --------------------------------------------------===//
20b57cec5SDimitry Andric //
30b57cec5SDimitry Andric // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions.
40b57cec5SDimitry Andric // See https://llvm.org/LICENSE.txt for license information.
50b57cec5SDimitry Andric // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
60b57cec5SDimitry Andric //
70b57cec5SDimitry Andric //===----------------------------------------------------------------------===//
80b57cec5SDimitry Andric 
90b57cec5SDimitry Andric #include "LinuxSignals.h"
100b57cec5SDimitry Andric 
11*fe013be4SDimitry Andric #ifdef __linux__
12*fe013be4SDimitry Andric #include <csignal>
13*fe013be4SDimitry Andric 
14*fe013be4SDimitry Andric #ifndef SEGV_BNDERR
15*fe013be4SDimitry Andric #define SEGV_BNDERR 3
16*fe013be4SDimitry Andric #endif
17*fe013be4SDimitry Andric #ifndef SEGV_MTEAERR
18*fe013be4SDimitry Andric #define SEGV_MTEAERR 8
19*fe013be4SDimitry Andric #endif
20*fe013be4SDimitry Andric #ifndef SEGV_MTESERR
21*fe013be4SDimitry Andric #define SEGV_MTESERR 9
22*fe013be4SDimitry Andric #endif
23*fe013be4SDimitry Andric 
24*fe013be4SDimitry Andric #define ADD_SIGCODE(signal_name, signal_value, code_name, code_value, ...)     \
25*fe013be4SDimitry Andric   static_assert(signal_name == signal_value,                                   \
26*fe013be4SDimitry Andric                 "Value mismatch for signal number " #signal_name);             \
27*fe013be4SDimitry Andric   static_assert(code_name == code_value,                                       \
28*fe013be4SDimitry Andric                 "Value mismatch for signal code " #code_name);                 \
29*fe013be4SDimitry Andric   AddSignalCode(signal_value, code_value, __VA_ARGS__)
30*fe013be4SDimitry Andric #else
31*fe013be4SDimitry Andric #define ADD_SIGCODE(signal_name, signal_value, code_name, code_value, ...)     \
32*fe013be4SDimitry Andric   AddSignalCode(signal_value, code_value, __VA_ARGS__)
33*fe013be4SDimitry Andric #endif /* ifdef __linux__ */
34*fe013be4SDimitry Andric 
350b57cec5SDimitry Andric using namespace lldb_private;
360b57cec5SDimitry Andric 
LinuxSignals()370b57cec5SDimitry Andric LinuxSignals::LinuxSignals() : UnixSignals() { Reset(); }
380b57cec5SDimitry Andric 
Reset()390b57cec5SDimitry Andric void LinuxSignals::Reset() {
400b57cec5SDimitry Andric   m_signals.clear();
41e8d8bef9SDimitry Andric   // clang-format off
42e8d8bef9SDimitry Andric   //        SIGNO   NAME            SUPPRESS  STOP    NOTIFY  DESCRIPTION
43e8d8bef9SDimitry Andric   //        ======  ==============  ========  ======  ======  ===================================================
440b57cec5SDimitry Andric   AddSignal(1,      "SIGHUP",       false,    true,   true,   "hangup");
450b57cec5SDimitry Andric   AddSignal(2,      "SIGINT",       true,     true,   true,   "interrupt");
460b57cec5SDimitry Andric   AddSignal(3,      "SIGQUIT",      false,    true,   true,   "quit");
47*fe013be4SDimitry Andric 
480b57cec5SDimitry Andric   AddSignal(4,      "SIGILL",       false,    true,   true,   "illegal instruction");
49*fe013be4SDimitry Andric   ADD_SIGCODE(SIGILL, 4, ILL_ILLOPC, 1, "illegal opcode");
50*fe013be4SDimitry Andric   ADD_SIGCODE(SIGILL, 4, ILL_ILLOPN, 2, "illegal operand");
51*fe013be4SDimitry Andric   ADD_SIGCODE(SIGILL, 4, ILL_ILLADR, 3, "illegal addressing mode");
52*fe013be4SDimitry Andric   ADD_SIGCODE(SIGILL, 4, ILL_ILLTRP, 4, "illegal trap");
53*fe013be4SDimitry Andric   ADD_SIGCODE(SIGILL, 4, ILL_PRVOPC, 5, "privileged opcode");
54*fe013be4SDimitry Andric   ADD_SIGCODE(SIGILL, 4, ILL_PRVREG, 6, "privileged register");
55*fe013be4SDimitry Andric   ADD_SIGCODE(SIGILL, 4, ILL_COPROC, 7, "coprocessor error");
56*fe013be4SDimitry Andric   ADD_SIGCODE(SIGILL, 4, ILL_BADSTK, 8, "internal stack error");
57*fe013be4SDimitry Andric 
58e8d8bef9SDimitry Andric   AddSignal(5,      "SIGTRAP",      true,     true,   true,   "trace trap (not reset when caught)");
590b57cec5SDimitry Andric   AddSignal(6,      "SIGABRT",      false,    true,   true,   "abort()/IOT trap", "SIGIOT");
60*fe013be4SDimitry Andric 
610b57cec5SDimitry Andric   AddSignal(7,      "SIGBUS",       false,    true,   true,   "bus error");
62*fe013be4SDimitry Andric   ADD_SIGCODE(SIGBUS, 7, BUS_ADRALN, 1, "illegal alignment");
63*fe013be4SDimitry Andric   ADD_SIGCODE(SIGBUS, 7, BUS_ADRERR, 2, "illegal address");
64*fe013be4SDimitry Andric   ADD_SIGCODE(SIGBUS, 7, BUS_OBJERR, 3, "hardware error");
65*fe013be4SDimitry Andric 
660b57cec5SDimitry Andric   AddSignal(8,      "SIGFPE",       false,    true,   true,   "floating point exception");
67*fe013be4SDimitry Andric   ADD_SIGCODE(SIGFPE, 8, FPE_INTDIV, 1, "integer divide by zero");
68*fe013be4SDimitry Andric   ADD_SIGCODE(SIGFPE, 8, FPE_INTOVF, 2, "integer overflow");
69*fe013be4SDimitry Andric   ADD_SIGCODE(SIGFPE, 8, FPE_FLTDIV, 3, "floating point divide by zero");
70*fe013be4SDimitry Andric   ADD_SIGCODE(SIGFPE, 8, FPE_FLTOVF, 4, "floating point overflow");
71*fe013be4SDimitry Andric   ADD_SIGCODE(SIGFPE, 8, FPE_FLTUND, 5, "floating point underflow");
72*fe013be4SDimitry Andric   ADD_SIGCODE(SIGFPE, 8, FPE_FLTRES, 6, "floating point inexact result");
73*fe013be4SDimitry Andric   ADD_SIGCODE(SIGFPE, 8, FPE_FLTINV, 7, "floating point invalid operation");
74*fe013be4SDimitry Andric   ADD_SIGCODE(SIGFPE, 8, FPE_FLTSUB, 8, "subscript out of range");
75*fe013be4SDimitry Andric 
760b57cec5SDimitry Andric   AddSignal(9,      "SIGKILL",      false,    true,   true,   "kill");
770b57cec5SDimitry Andric   AddSignal(10,     "SIGUSR1",      false,    true,   true,   "user defined signal 1");
78*fe013be4SDimitry Andric 
790b57cec5SDimitry Andric   AddSignal(11,     "SIGSEGV",      false,    true,   true,   "segmentation violation");
80*fe013be4SDimitry Andric   ADD_SIGCODE(SIGSEGV, 11, SEGV_MAPERR,  1, "address not mapped to object", SignalCodePrintOption::Address);
81*fe013be4SDimitry Andric   ADD_SIGCODE(SIGSEGV, 11, SEGV_ACCERR,  2, "invalid permissions for mapped object", SignalCodePrintOption::Address);
82*fe013be4SDimitry Andric   ADD_SIGCODE(SIGSEGV, 11, SEGV_BNDERR,  3, "failed address bounds checks", SignalCodePrintOption::Bounds);
83*fe013be4SDimitry Andric   ADD_SIGCODE(SIGSEGV, 11, SEGV_MTEAERR, 8, "async tag check fault");
84*fe013be4SDimitry Andric   ADD_SIGCODE(SIGSEGV, 11, SEGV_MTESERR, 9, "sync tag check fault", SignalCodePrintOption::Address);
85*fe013be4SDimitry Andric   // Some platforms will occasionally send nonstandard spurious SI_KERNEL
86*fe013be4SDimitry Andric   // codes. One way to get this is via unaligned SIMD loads. Treat it as invalid address.
87*fe013be4SDimitry Andric   ADD_SIGCODE(SIGSEGV, 11, SI_KERNEL, 0x80, "invalid address", SignalCodePrintOption::Address);
88*fe013be4SDimitry Andric 
890b57cec5SDimitry Andric   AddSignal(12,     "SIGUSR2",      false,    true,   true,   "user defined signal 2");
90e8d8bef9SDimitry Andric   AddSignal(13,     "SIGPIPE",      false,    true,   true,   "write to pipe with reading end closed");
910b57cec5SDimitry Andric   AddSignal(14,     "SIGALRM",      false,    false,  false,  "alarm");
920b57cec5SDimitry Andric   AddSignal(15,     "SIGTERM",      false,    true,   true,   "termination requested");
930b57cec5SDimitry Andric   AddSignal(16,     "SIGSTKFLT",    false,    true,   true,   "stack fault");
94e8d8bef9SDimitry Andric   AddSignal(17,     "SIGCHLD",      false,    false,  true,   "child status has changed", "SIGCLD");
95e8d8bef9SDimitry Andric   AddSignal(18,     "SIGCONT",      false,    false,  true,   "process continue");
960b57cec5SDimitry Andric   AddSignal(19,     "SIGSTOP",      true,     true,   true,   "process stop");
970b57cec5SDimitry Andric   AddSignal(20,     "SIGTSTP",      false,    true,   true,   "tty stop");
980b57cec5SDimitry Andric   AddSignal(21,     "SIGTTIN",      false,    true,   true,   "background tty read");
990b57cec5SDimitry Andric   AddSignal(22,     "SIGTTOU",      false,    true,   true,   "background tty write");
1000b57cec5SDimitry Andric   AddSignal(23,     "SIGURG",       false,    true,   true,   "urgent data on socket");
1010b57cec5SDimitry Andric   AddSignal(24,     "SIGXCPU",      false,    true,   true,   "CPU resource exceeded");
1020b57cec5SDimitry Andric   AddSignal(25,     "SIGXFSZ",      false,    true,   true,   "file size limit exceeded");
1030b57cec5SDimitry Andric   AddSignal(26,     "SIGVTALRM",    false,    true,   true,   "virtual time alarm");
1040b57cec5SDimitry Andric   AddSignal(27,     "SIGPROF",      false,    false,  false,  "profiling time alarm");
1050b57cec5SDimitry Andric   AddSignal(28,     "SIGWINCH",     false,    true,   true,   "window size changes");
106e8d8bef9SDimitry Andric   AddSignal(29,     "SIGIO",        false,    true,   true,   "input/output ready/Pollable event", "SIGPOLL");
1070b57cec5SDimitry Andric   AddSignal(30,     "SIGPWR",       false,    true,   true,   "power failure");
1080b57cec5SDimitry Andric   AddSignal(31,     "SIGSYS",       false,    true,   true,   "invalid system call");
109e8d8bef9SDimitry Andric   AddSignal(32,     "SIG32",        false,    false,  false,  "threading library internal signal 1");
110e8d8bef9SDimitry Andric   AddSignal(33,     "SIG33",        false,    false,  false,  "threading library internal signal 2");
1110b57cec5SDimitry Andric   AddSignal(34,     "SIGRTMIN",     false,    false,  false,  "real time signal 0");
1120b57cec5SDimitry Andric   AddSignal(35,     "SIGRTMIN+1",   false,    false,  false,  "real time signal 1");
1130b57cec5SDimitry Andric   AddSignal(36,     "SIGRTMIN+2",   false,    false,  false,  "real time signal 2");
1140b57cec5SDimitry Andric   AddSignal(37,     "SIGRTMIN+3",   false,    false,  false,  "real time signal 3");
1150b57cec5SDimitry Andric   AddSignal(38,     "SIGRTMIN+4",   false,    false,  false,  "real time signal 4");
1160b57cec5SDimitry Andric   AddSignal(39,     "SIGRTMIN+5",   false,    false,  false,  "real time signal 5");
1170b57cec5SDimitry Andric   AddSignal(40,     "SIGRTMIN+6",   false,    false,  false,  "real time signal 6");
1180b57cec5SDimitry Andric   AddSignal(41,     "SIGRTMIN+7",   false,    false,  false,  "real time signal 7");
1190b57cec5SDimitry Andric   AddSignal(42,     "SIGRTMIN+8",   false,    false,  false,  "real time signal 8");
1200b57cec5SDimitry Andric   AddSignal(43,     "SIGRTMIN+9",   false,    false,  false,  "real time signal 9");
1210b57cec5SDimitry Andric   AddSignal(44,     "SIGRTMIN+10",  false,    false,  false,  "real time signal 10");
1220b57cec5SDimitry Andric   AddSignal(45,     "SIGRTMIN+11",  false,    false,  false,  "real time signal 11");
1230b57cec5SDimitry Andric   AddSignal(46,     "SIGRTMIN+12",  false,    false,  false,  "real time signal 12");
1240b57cec5SDimitry Andric   AddSignal(47,     "SIGRTMIN+13",  false,    false,  false,  "real time signal 13");
1250b57cec5SDimitry Andric   AddSignal(48,     "SIGRTMIN+14",  false,    false,  false,  "real time signal 14");
1260b57cec5SDimitry Andric   AddSignal(49,     "SIGRTMIN+15",  false,    false,  false,  "real time signal 15");
127e8d8bef9SDimitry Andric   AddSignal(50,     "SIGRTMAX-14",  false,    false,  false,  "real time signal 16"); // switching to SIGRTMAX-xxx to match "kill -l" output
1280b57cec5SDimitry Andric   AddSignal(51,     "SIGRTMAX-13",  false,    false,  false,  "real time signal 17");
1290b57cec5SDimitry Andric   AddSignal(52,     "SIGRTMAX-12",  false,    false,  false,  "real time signal 18");
1300b57cec5SDimitry Andric   AddSignal(53,     "SIGRTMAX-11",  false,    false,  false,  "real time signal 19");
1310b57cec5SDimitry Andric   AddSignal(54,     "SIGRTMAX-10",  false,    false,  false,  "real time signal 20");
1320b57cec5SDimitry Andric   AddSignal(55,     "SIGRTMAX-9",   false,    false,  false,  "real time signal 21");
1330b57cec5SDimitry Andric   AddSignal(56,     "SIGRTMAX-8",   false,    false,  false,  "real time signal 22");
1340b57cec5SDimitry Andric   AddSignal(57,     "SIGRTMAX-7",   false,    false,  false,  "real time signal 23");
1350b57cec5SDimitry Andric   AddSignal(58,     "SIGRTMAX-6",   false,    false,  false,  "real time signal 24");
1360b57cec5SDimitry Andric   AddSignal(59,     "SIGRTMAX-5",   false,    false,  false,  "real time signal 25");
1370b57cec5SDimitry Andric   AddSignal(60,     "SIGRTMAX-4",   false,    false,  false,  "real time signal 26");
1380b57cec5SDimitry Andric   AddSignal(61,     "SIGRTMAX-3",   false,    false,  false,  "real time signal 27");
1390b57cec5SDimitry Andric   AddSignal(62,     "SIGRTMAX-2",   false,    false,  false,  "real time signal 28");
1400b57cec5SDimitry Andric   AddSignal(63,     "SIGRTMAX-1",   false,    false,  false,  "real time signal 29");
1410b57cec5SDimitry Andric   AddSignal(64,     "SIGRTMAX",     false,    false,  false,  "real time signal 30");
142e8d8bef9SDimitry Andric   // clang-format on
1430b57cec5SDimitry Andric }
144