summaryrefslogtreecommitdiffstats
path: root/man-pages-posix-2013/man3p/sigaction.3p
blob: 5d68eb26ebcaa557c6267fee33b288180aad627e (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
464
465
466
467
468
469
470
471
472
473
474
475
476
477
478
479
480
481
482
483
484
485
486
487
488
489
490
491
492
493
494
495
496
497
498
499
500
501
502
503
504
505
506
507
508
509
510
511
512
513
514
515
516
517
518
519
520
521
522
523
524
525
526
527
528
529
530
531
532
533
534
535
536
537
538
539
540
541
542
543
544
545
546
547
548
549
550
551
552
553
554
555
556
557
558
559
560
561
562
563
564
565
566
567
568
569
570
571
572
573
574
575
576
577
578
579
580
581
582
583
584
585
586
587
588
589
590
591
592
593
594
595
596
597
598
599
600
601
602
603
604
605
606
607
608
609
610
611
612
613
614
615
616
617
618
619
620
621
622
623
624
625
626
627
628
629
630
631
632
633
634
635
636
637
638
639
640
641
642
643
644
645
646
647
648
649
650
651
652
653
654
655
656
657
658
659
660
661
662
663
664
665
666
667
668
669
670
671
672
673
674
675
676
'\" et
.TH SIGACTION "3P" 2013 "IEEE/The Open Group" "POSIX Programmer's Manual"
.SH PROLOG
This manual page is part of the POSIX Programmer's Manual.
The Linux implementation of this interface may differ (consult
the corresponding Linux manual page for details of Linux behavior),
or the interface may not be implemented on Linux.

.SH NAME
sigaction
\(em examine and change a signal action
.SH SYNOPSIS
.LP
.nf
#include <signal.h>
.P
int sigaction(int \fIsig\fP, const struct sigaction *restrict \fIact\fP,
    struct sigaction *restrict \fIoact\fP);
.fi
.SH DESCRIPTION
The
\fIsigaction\fR()
function allows the calling process to examine and/or specify the
action to be associated with a specific signal. The argument
.IR sig
specifies the signal; acceptable values are defined in
.IR <signal.h> .
.P
The structure
.BR sigaction ,
used to describe an action to be taken, is defined in the
.IR <signal.h> 
header to include at least the following members:
.ad l
.TS
center box tab(!);
cB | cB | cB
lw(1.5i)B | lw(1.25i)I | lw(2.5i).
Member Type!Member Name!Description
_
void(*) (int)!sa_handler!T{
Pointer to a signal-catching function or one of the macros
SIG_IGN or SIG_DFL.
T}
sigset_t!sa_mask!T{
Additional set of signals to be blocked during execution of
signal-catching function.
T}
int!sa_flags!T{
Special flags to affect behavior of signal.
T}
T{
void(*) (int,
.br
\0\0siginfo_t *, void *)
T}!sa_sigaction!Pointer to a signal-catching function.
.TE
.ad b
.P
The storage occupied by
.IR sa_handler
and
.IR sa_sigaction
may overlap, and a conforming application shall not use both
simultaneously.
.P
If the argument
.IR act
is not a null pointer, it points to a structure specifying the action
to be associated with the specified signal. If the argument
.IR oact
is not a null pointer, the action previously associated with the signal
is stored in the location pointed to by the argument
.IR oact .
If the argument
.IR act
is a null pointer, signal handling is unchanged; thus, the call can be
used to enquire about the current handling of a given signal. The
SIGKILL and SIGSTOP signals shall not be added to the signal
mask using this mechanism; this restriction shall be enforced by the
system without causing an error to be indicated.
.P
If the SA_SIGINFO flag (see below) is cleared in the
.IR sa_flags
field of the
.BR sigaction
structure, the
.IR sa_handler
field identifies the action to be associated with the specified signal.
If the SA_SIGINFO flag is set in the
.IR sa_flags
field, the
.IR sa_sigaction
field specifies a signal-catching function.
.P
The
.IR sa_flags
field can be used to modify the behavior of the specified signal.
.P
The following flags, defined in the
.IR <signal.h> 
header, can be set in
.IR sa_flags :
.IP SA_NOCLDSTOP 14
Do not generate SIGCHLD when children stop
or stopped children continue.
.RS 14 
.P
If
.IR sig
is SIGCHLD and the SA_NOCLDSTOP flag is not set in
.IR sa_flags ,
and the implementation supports the SIGCHLD signal, then a SIGCHLD
signal shall be generated for the calling process whenever any of its
child processes stop
and a SIGCHLD signal may be generated for the calling
process whenever any of its stopped child processes are continued.
If
.IR sig
is SIGCHLD and the SA_NOCLDSTOP flag is set in
.IR sa_flags ,
then the implementation shall not generate a SIGCHLD signal in this
way.
.RE
.IP SA_ONSTACK 14
If set and an alternate signal stack has been declared with
\fIsigaltstack\fR(),
the signal shall be delivered to the calling process on that stack.
Otherwise, the signal shall be delivered on the current stack.
.IP SA_RESETHAND 14
If set, the disposition of the signal shall be reset to SIG_DFL and the
SA_SIGINFO flag shall be cleared on entry to the signal handler.
.RS 14 
.TP 10
.BR Note:
SIGILL and SIGTRAP cannot be automatically reset when delivered; the
system silently enforces this restriction.
.P
Otherwise, the disposition of the signal shall not be modified on entry
to the signal handler.
.P
In addition, if this flag is set,
\fIsigaction\fR()
may behave as if the SA_NODEFER flag were also set.
.RE
.IP SA_RESTART 14
This flag affects the behavior of interruptible functions; that is,
those specified to fail with
.IR errno
set to
.BR [EINTR] .
If set, and a function specified as interruptible is interrupted by
this signal, the function shall restart and shall not fail with
.BR [EINTR] 
unless otherwise specified. If an interruptible function which uses a
timeout is restarted, the duration of the timeout following the restart
is set to an unspecified value that does not exceed the original
timeout value. If the flag is not set, interruptible functions
interrupted by this signal shall fail with
.IR errno
set to
.BR [EINTR] .
.IP SA_SIGINFO 14
If cleared and the signal is caught, the signal-catching function
shall be entered as:
.RS 14 
.sp
.RS 4
.nf
\fB
void func(int \fIsigno\fP);
.fi \fR
.P
.RE
.P
where
.IR signo
is the only argument to the signal-catching function. In this case, the
application shall use the
.IR sa_handler
member to describe the signal-catching function and the application
shall not modify the
.IR sa_sigaction
member.
.P
If SA_SIGINFO is set and the signal is caught, the signal-catching
function shall be entered as:
.sp
.RS 4
.nf
\fB
void func(int \fIsigno\fP, siginfo_t *\fIinfo\fP, void *\fIcontext\fP);
.fi \fR
.P
.RE
.P
where two additional arguments are passed to the signal-catching
function. The second argument shall point to an object of type
.BR siginfo_t
explaining the reason why the signal was generated; the third argument
can be cast to a pointer to an object of type
.BR ucontext_t
to refer to the receiving thread's context that was interrupted when
the signal was delivered. In this case, the application shall use the
.IR sa_sigaction
member to describe the signal-catching function and the application
shall not modify the
.IR sa_handler
member.
.P
The
.IR si_signo
member contains the system-generated signal number.
.P
The
.IR si_errno
member may contain implementation-defined additional error
information; if non-zero, it contains an error number identifying the
condition that caused the signal to be generated.
.P
The
.IR si_code
member contains a code identifying the cause of the signal, as
described in
.IR "Section 2.4.3" ", " "Signal Actions".
.RE
.IP SA_NOCLDWAIT 14
If set, and
.IR sig
equals SIGCHLD, child processes of the calling processes shall not
be transformed into zombie processes when they terminate. If the calling
process subsequently waits for its children, and the process has no
unwaited-for children that were transformed into zombie processes, it
shall block until all of its children terminate, and
\fIwait\fR(),
\fIwaitid\fR(),
and
\fIwaitpid\fR()
shall fail and set
.IR errno
to
.BR [ECHILD] .
Otherwise, terminating child processes shall be transformed into zombie
processes, unless SIGCHLD is set to SIG_IGN.
.IP SA_NODEFER 14
If set and
.IR sig
is caught,
.IR sig
shall not be added to the thread's signal mask on entry to the signal
handler unless it is included in
.IR sa_mask .
Otherwise,
.IR sig
shall always be added to the thread's signal mask on entry to the
signal handler.
.P
When a signal is caught by a signal-catching function installed by
\fIsigaction\fR(),
a new signal mask is calculated and installed for the duration of the
signal-catching function (or until a call to either
\fIsigprocmask\fR()
or
\fIsigsuspend\fR()
is made). This mask is formed by taking the union of the current
signal mask and the value of the
.IR sa_mask
for the signal being delivered, and unless SA_NODEFER or
SA_RESETHAND is set,
then including the signal being delivered. If and when the user's
signal handler returns normally, the original signal mask is restored.
.P
Once an action is installed for a specific signal, it shall remain
installed until another action is explicitly requested (by another
call to
\fIsigaction\fR()),
until the SA_RESETHAND flag causes resetting of the handler,
or until one of the
.IR exec
functions is called.
.P
If the previous action for
.IR sig
had been established by
\fIsignal\fR(),
the values of the fields returned in the structure pointed to by
.IR oact
are unspecified, and in particular
.IR oact ->\c
.IR sa_handler
is not necessarily the same value passed to
\fIsignal\fR().
However, if a pointer to the same structure or a copy thereof is passed
to a subsequent call to
\fIsigaction\fR()
via the
.IR act
argument, handling of the signal shall be as if the original call to
\fIsignal\fR()
were repeated.
.P
If
\fIsigaction\fR()
fails, no new signal handler is installed.
.P
It is unspecified whether an attempt to set the action for a signal
that cannot be caught or ignored to SIG_DFL is ignored or causes an
error to be returned with
.IR errno
set to
.BR [EINVAL] .
.P
If SA_SIGINFO is not set in
.IR sa_flags ,
then the disposition of subsequent occurrences of
.IR sig
when it is already pending is implementation-defined; the
signal-catching function shall be invoked with a single argument.
If SA_SIGINFO is set in
.IR sa_flags ,
then subsequent occurrences of
.IR sig
generated by
\fIsigqueue\fR()
or as a result of any signal-generating function that supports the
specification of an application-defined value (when
.IR sig
is already pending) shall be queued in FIFO order until delivered or
accepted; the signal-catching function shall be invoked with three
arguments. The application specified value is passed to the
signal-catching function as the
.IR si_value
member of the
.BR siginfo_t
structure.
.P
The result of the use of
\fIsigaction\fR()
and a
\fIsigwait\fR()
function concurrently within a process on the same signal is
unspecified.
.SH "RETURN VALUE"
Upon successful completion,
\fIsigaction\fR()
shall return 0; otherwise, \(mi1 shall be returned,
.IR errno
shall be set to indicate the error, and no new signal-catching function
shall be installed.
.br
.SH ERRORS
The
\fIsigaction\fR()
function shall fail if:
.TP
.BR EINVAL
The
.IR sig
argument is not a valid signal number or an attempt is made to catch a
signal that cannot be caught or ignore a signal that cannot be ignored.
.TP
.BR ENOTSUP
The SA_SIGINFO bit flag is set in the
.IR sa_flags
field of the
.BR sigaction
structure.
.P
The
\fIsigaction\fR()
function may fail if:
.TP
.BR EINVAL
An attempt was made to set the action to SIG_DFL for a signal that
cannot be caught or ignored (or both).
.P
In addition, the
\fIsigaction\fR()
function may fail if the SA_SIGINFO flag is set in the
.IR sa_flags
field of the
.BR sigaction
structure for a signal not in the range SIGRTMIN to SIGRTMAX.
.LP
.IR "The following sections are informative."
.SH EXAMPLES
.SS "Establishing a Signal Handler"
.P
The following example demonstrates the use of
\fIsigaction\fR()
to establish a handler for the SIGINT signal.
.sp
.RS 4
.nf
\fB
#include <signal.h>
.P
static void handler(int signum)
{
    /* Take appropriate actions for signal delivery */
}
.P
int main()
{
    struct sigaction sa;
.P
    sa.sa_handler = handler;
    sigemptyset(&sa.sa_mask);
    sa.sa_flags = SA_RESTART; /* Restart functions if
                                 interrupted by handler */
    if (sigaction(SIGINT, &sa, NULL) == \(mi1)
        /* Handle error */;
.P
    /* Further code */
}
.fi \fR
.P
.RE
.SH "APPLICATION USAGE"
The
\fIsigaction\fR()
function supersedes the
\fIsignal\fR()
function, and should be used in preference. In particular,
\fIsigaction\fR()
and
\fIsignal\fR()
should not be used in the same process to control the same signal.
The behavior of async-signal-safe functions, as defined in their
respective DESCRIPTION sections, is as specified by this volume of POSIX.1\(hy2008, regardless
of invocation from a signal-catching function. This is the only intended
meaning of the statement that async-signal-safe functions may be used in
signal-catching functions without restrictions. Applications must still
consider all effects of such functions on such things as data structures,
files, and process state. In particular, application developers need
to consider the restrictions on interactions when interrupting
\fIsleep\fR()
and interactions among multiple handles for a file description. The
fact that any specific function is listed as async-signal-safe does not
necessarily mean that invocation of that function from a
signal-catching function is recommended.
.P
In order to prevent errors arising from interrupting non-async-signal-safe
function calls, applications should protect calls to these functions
either by blocking the appropriate signals or through the use of some
programmatic semaphore (see
.IR "\fIsemget\fR\^(\|)",
.IR "\fIsem_init\fR\^(\|)",
.IR "\fIsem_open\fR\^(\|)",
and so on). Note in particular that even the ``safe'' functions may
modify
.IR errno ;
the signal-catching function, if not executing as an independent
thread, should save and restore its value in order to avoid the
possibility that delivery of a signal in between an error return
from a function that sets
.IR errno
and the subsequent examination of
.IR errno
could result in the signal-catching function changing the value of
.IR errno .
Naturally, the same principles apply to the async-signal-safety of
application routines and asynchronous data access. Note that
\fIlongjmp\fR()
and
\fIsiglongjmp\fR()
are not in the list of async-signal-safe functions. This is because
the code executing after
\fIlongjmp\fR()
and
\fIsiglongjmp\fR()
can call any unsafe functions with the same danger as calling those
unsafe functions directly from the signal handler. Applications that
use
\fIlongjmp\fR()
and
\fIsiglongjmp\fR()
from within signal handlers require rigorous protection in order to be
portable. Many of the other functions that are excluded from the list
are traditionally implemented using either
\fImalloc\fR()
or
\fIfree\fR()
functions or the standard I/O library, both of which traditionally
use data structures in a non-async-signal-safe manner. Since any
combination of different functions using a common data structure can
cause async-signal-safety problems, this volume of POSIX.1\(hy2008 does not define the behavior
when any unsafe function is called in a signal handler that interrupts
an unsafe function.
.P
Usually, the signal is executed on the stack that was in effect before
the signal was delivered. An alternate stack may be specified to
receive a subset of the signals being caught.
.P
When the signal handler returns, the receiving thread resumes
execution at the point it was interrupted unless the signal handler
makes other arrangements. If
\fIlongjmp\fR()
or
\fI_longjmp\fR()
is used to leave the signal handler, then the signal mask must be
explicitly restored.
.P
This volume of POSIX.1\(hy2008 defines the third argument of a signal handling function when
SA_SIGINFO is set as a
.BR "void *"
instead of a
.BR "ucontext_t *" ,
but without requiring type checking. New applications should
explicitly cast the third argument of the signal handling function to
.BR "ucontext_t *" .
.P
The BSD optional four argument signal handling function is not
supported by this volume of POSIX.1\(hy2008. The BSD declaration would be:
.sp
.RS 4
.nf
\fB
void handler(int \fIsig\fP, int \fIcode\fP, struct sigcontext *\fIscp\fP,
    char *\fIaddr\fP);
.fi \fR
.P
.RE
.P
where
.IR sig
is the signal number,
.IR code
is additional information on certain signals,
.IR scp
is a pointer to the
.BR sigcontext
structure, and
.IR addr
is additional address information. Much the same information is
available in the objects pointed to by the second argument of the
signal handler specified when SA_SIGINFO is set.
.P
Since the
\fIsigaction\fR()
function is allowed but not required to set SA_NODEFER when the
application sets the SA_RESETHAND flag, applications which depend on the
SA_RESETHAND functionality for the newly installed signal handler must
always explicitly set SA_NODEFER when they set SA_RESETHAND in order to
be portable.
.P
See also the rationale for Realtime Signal Generation and Delivery in
the Rationale (Informative) volume of POSIX.1\(hy2008,
.IR "Section B.2.4.2" ", " "Signal Generation and Delivery".
.SH RATIONALE
Although this volume of POSIX.1\(hy2008 requires that signals that cannot be ignored
shall not be added to the signal mask when a signal-catching function
is entered, there is no explicit requirement that subsequent calls to
\fIsigaction\fR()
reflect this in the information returned in the
.IR oact
argument. In other words, if SIGKILL
is included in the
.IR sa_mask
field of
.IR act ,
it is unspecified whether or not a subsequent call to
\fIsigaction\fR()
returns with SIGKILL included in the
.IR sa_mask
field of
.IR oact .
.P
The SA_NOCLDSTOP
flag, when supplied in the
.IR act ->\c
.IR sa_flags
parameter, allows overloading SIGCHLD with the System V
semantics that each SIGCLD
signal indicates a single terminated child. Most conforming applications
that catch SIGCHLD are expected to install signal-catching functions
that repeatedly call the
\fIwaitpid\fR()
function with the WNOHANG
flag set, acting on each child for which status is returned, until
\fIwaitpid\fR()
returns zero. If stopped children are not of interest, the use of the
SA_NOCLDSTOP
flag can prevent the overhead from invoking the signal-catching routine
when they stop.
.P
Some historical implementations also define other mechanisms for
stopping processes, such as the
\fIptrace\fR()
function. These implementations usually do not generate a SIGCHLD
signal when processes stop due to this mechanism; however, that is
beyond the scope of this volume of POSIX.1\(hy2008.
.P
This volume of POSIX.1\(hy2008 requires that calls to
\fIsigaction\fR()
that supply a NULL
.IR act
argument succeed, even in the case of signals that cannot be caught or
ignored (that is, SIGKILL
or SIGSTOP).
The System V
\fIsignal\fR()
and BSD
\fIsigvec\fR()
functions return
.BR [EINVAL] 
in these cases and, in this respect, their behavior varies from
\fIsigaction\fR().
.P
This volume of POSIX.1\(hy2008 requires that
\fIsigaction\fR()
properly save and restore a signal action set up by the ISO\ C standard
\fIsignal\fR()
function. However, there is no guarantee that the reverse is true, nor
could there be given the greater amount of information conveyed by the
.BR sigaction
structure. Because of this, applications should avoid using both
functions for the same signal in the same process. Since this cannot
always be avoided in case of general-purpose library routines, they
should always be implemented with
\fIsigaction\fR().
.P
It was intended that the
\fIsignal\fR()
function should be implementable as a library routine using
\fIsigaction\fR().
.P
The POSIX Realtime Extension extends the
\fIsigaction\fR()
function as specified by the POSIX.1\(hy1990 standard to allow the application to request
on a per-signal basis via an additional signal action flag that the
extra parameters, including the application-defined signal value, if
any, be passed to the signal-catching function.
.SH "FUTURE DIRECTIONS"
None.
.SH "SEE ALSO"
.IR "Section 2.4" ", " "Signal Concepts",
.IR "\fIexec\fR\^",
.IR "\fIkill\fR\^(\|)",
.IR "\fI_longjmp\fR\^(\|)",
.IR "\fIlongjmp\fR\^(\|)",
.IR "\fIpthread_sigmask\fR\^(\|)",
.IR "\fIraise\fR\^(\|)",
.IR "\fIsemget\fR\^(\|)",
.IR "\fIsem_init\fR\^(\|)",
.IR "\fIsem_open\fR\^(\|)",
.IR "\fIsigaddset\fR\^(\|)",
.IR "\fIsigaltstack\fR\^(\|)",
.IR "\fIsigdelset\fR\^(\|)",
.IR "\fIsigemptyset\fR\^(\|)",
.IR "\fIsigfillset\fR\^(\|)",
.IR "\fIsigismember\fR\^(\|)",
.IR "\fIsignal\fR\^(\|)",
.IR "\fIsigsuspend\fR\^(\|)",
.IR "\fIwait\fR\^(\|)",
.IR "\fIwaitid\fR\^(\|)"
.P
The Base Definitions volume of POSIX.1\(hy2008,
.IR "\fB<signal.h>\fP"
.SH COPYRIGHT
Portions of this text are reprinted and reproduced in electronic form
from IEEE Std 1003.1, 2013 Edition, Standard for Information Technology
-- Portable Operating System Interface (POSIX), The Open Group Base
Specifications Issue 7, Copyright (C) 2013 by the Institute of
Electrical and Electronics Engineers, Inc and The Open Group.
(This is POSIX.1-2008 with the 2013 Technical Corrigendum 1 applied.) In the
event of any discrepancy between this version and the original IEEE and
The Open Group Standard, the original IEEE and The Open Group Standard
is the referee document. The original Standard can be obtained online at
http://www.unix.org/online.html .

Any typographical or formatting errors that appear
in this page are most likely
to have been introduced during the conversion of the source files to
man page format. To report such errors, see
https://www.kernel.org/doc/man-pages/reporting_bugs.html .