SA_SIGINFO
Обработчик сигнала требует 3-х аргументов, а не одного. В этом случае надо использовать параметр sa_sigaction вместо sa_handler. (Поле sa_sigaction было добавлено в Linux 2.1.86.) Параметр siginfo_t поля sa_sigaction является структурой, состоящей из следующих элементов: Прототипы обработчиков. void my_handler(int signo); void my_handler(int signo, siginfo_t *si, void *ucontext_t); struct siginfo_t { int si_signo; /* Номер сигнала */ int si_errno; /* Значение errno */ int si_code; /* Код сигнала */ pid_t si_pid; /* Идентификатор процесса, пославшего сигнал */ uid_t si_uid; /* Реальный идентификатор пользователя процесса, пославшего сигнал */ int si_status; /* Выходное значение или номер сигнала процесса, который завершился*/ clock_t si_utime; /* Занятое пользователем время */ clock_t si_stime; /* Использованное системное время */ sigval_t si_value; /* Значение сигнала */ int si_int; /* Сигнал POSIX.1b */ void * si_ptr; /* Сигнал POSIX.1b */ void * si_addr; /* Адрес в памяти, приводящий к ошибке */ int si_band; /* Общее событие */ int si_fd; /* Описатель файла */} Поля si_signo, si_errno и si_code определены для всех сигналов. Остальная часть структуры может быть объединением, поэтому Вы должны работать только с теми полями, которые имеют смысл для конкретного сигнала. kill (2), сигналы POSIX.1b и SIGCHLD заполняют поля si_pid и si_uid. SIGCHLD также заполняет поля si_status, si_utime и si_stime. Поля si_int и si_ptr задаются процессом, пославшим сигнал POSIX.1b. Сигналы SIGILL, SIGFPE, SIGSEGV и SIGBUS заполняют поле si_addr адресом в памяти, который привел к ошибке. Сигнал IGPOLL заполняет si_band и si_fd. si_code указывает на причину отправки сигнала. Это значение, а не битовая маска. В следующей таблице приведены значения, которые могут вернуть любые сигналы:
Третий параметр
Структура типа ucontext_t – идентифицирует контекст процесса в момент доставки сигнала; typedef struct ucontext { struct ucontext *uc_link; sigset_t uc_sigmask; stack_t uc_stack; mcontext_t uc_mcontext; ... } ucontext_t;
uc_link указывает на контекст, который будет восстановлен при выходе из текущего контекста, если контекст создан с помощью makecontext (вторичный контекст). uc_sigmask используется для хранения сигналов, заблокированных в контексте, а uc_stack является стеком, используемым контекстом. uc_mcontext используется для хранения состояния исполнения, включая все Регистр процессора центрального процессора, указатель инструкцию и указатель на стек; mcontext_t является непрозрачным (opaque) указателем.
Функции sigaction возвращают 0 при удачном завершении работы функции и -1 при ошибке.
|