xref: /freebsd/lib/libsys/sigfastblock.2 (revision 7d0873ebb83b19ba1e8a89e679470d885efe12e3)
1.\" Copyright (c) 2016 The FreeBSD Foundation
2.\"
3.\" This documentation was written by
4.\" Konstantin Belousov <kib@FreeBSD.org> under sponsorship
5.\" from the FreeBSD Foundation.
6.\"
7.\" Redistribution and use in source and binary forms, with or without
8.\" modification, are permitted provided that the following conditions
9.\" are met:
10.\" 1. Redistributions of source code must retain the above copyright
11.\"    notice, this list of conditions and the following disclaimer.
12.\" 2. Redistributions in binary form must reproduce the above copyright
13.\"    notice, this list of conditions and the following disclaimer in the
14.\"    documentation and/or other materials provided with the distribution.
15.\"
16.\" THIS SOFTWARE IS PROVIDED BY THE AUTHORS AND CONTRIBUTORS ``AS IS'' AND
17.\" ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
18.\" IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
19.\" ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHORS OR CONTRIBUTORS BE LIABLE
20.\" FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
21.\" DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
22.\" OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
23.\" HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
24.\" LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
25.\" OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26.\" SUCH DAMAGE.
27.\"
28.Dd December 13, 2019
29.Dt SIGFASTBLOCK 2
30.Os
31.Sh NAME
32.Nm sigfastblock
33.Nd controls signals blocking with a simple memory write
34.Sh LIBRARY
35.Lb libc
36.Sh SYNOPSIS
37.In sys/signalvar.h
38.Ft int
39.Fn sigfastblock "int cmd" "void *ptr"
40.Sh DESCRIPTION
41.Bf -symbolic
42This function is not intended for a direct usage by applications.
43The functionality is provided for implementing some optimizations in
44.Xr ld-elf.so.1 8
45and
46.Lb libthr .
47.Ef
48.Pp
49The function configures the kernel facility that allows a thread to
50block asynchronous signals delivery with a single write to userspace
51memory, avoiding overhead of system calls like
52.Xr sigprocmask 2
53for establishing critical sections.
54The C runtime uses it to optimize implementation of async-signal-safe
55functionality.
56.Pp
57A thread might register a
58.Dv sigblock
59variable of type
60.Vt int
61as a location which is consulted by kernel when calculating the
62blocked signal mask for delivery of asynchronous signals.
63If the variable indicates that blocking is requested, then the kernel
64effectively operates as if the mask containing all blockable signals was
65supplied to
66.Xr sigprocmask 2 .
67.Pp
68The variable is supposed to be modified only from the owning thread,
69there is no way to guarantee visibility of update from other thread
70to kernel when signals are delivered.
71.Pp
72Lower bits of the sigblock variable are reserved as flags,
73which might be set or cleared by kernel at arbitrary moments.
74Userspace code should use
75.Xr atomic 9
76operations of incrementing and decrementing by
77.Dv SIGFASTBLOCK_INC
78quantity to recursively block or unblock signals delivery.
79.Pp
80If a signal would be delivered when unmasked, kernel might set the
81.Dv SIGFASTBLOCK_PEND
82.Dq pending signal
83flag in the sigblock variable.
84Userspace should perform
85.Dv SIGFASTBLOCK_UNBLOCK
86operation when clearing the variable if it notes the pending signal
87bit is set, which would deliver the pending signals immediately.
88Otherwise, signals delivery might be postponed.
89.Pp
90The
91.Fa cmd
92argument specifies one of the following operations:
93.Bl -tag -width SIGFASTBLOCK_UNSETPTR
94.It Dv SIGFASTBLOCK_SETPTR
95Register the variable of type
96.Vt int
97at location pointed to by the
98.Fa ptr
99argument as sigblock variable for the calling thread.
100.It Dv SIGFASTBLOCK_UNSETPTR
101Unregister the currently registered sigblock location.
102Kernel stops inferring the blocked mask from non-zero value of its
103blocked count.
104New location can be registered after previous one is deregistered.
105.It Dv SIGFASTBLOCK_UNBLOCK
106If there are pending signals which should be delivered to the calling
107thread, they are delivered before returning from the call.
108The sigblock variable should have zero blocking count, and indicate
109that the pending signal exists.
110Effectively this means that the variable should have the value
111.Dv SIGFASTBLOCK_PEND .
112.El
113.Sh RETURN VALUES
114.Rv -std
115.Sh ERRORS
116The operation may fail with the following errors:
117.Bl -tag -width Er
118.It Bq Er EBUSY
119The
120.Dv SIGFASTBLOCK_SETPTR
121attempted while the sigblock address was already registered.
122The
123.Dv SIGFASTBLOCK_UNBLOCK
124was called while sigblock variable value is not equal to
125.Dv SIGFASTBLOCK_PEND .
126.It Bq Er EINVAL
127The variable address passed to
128.Dv SIGFASTBLOCK_SETPTR
129is not aligned naturally.
130The
131.Dv SIGFASTBLOCK_UNSETPTR
132operation was attempted without prior successful call to
133.Dv SIGFASTBLOCK_SETPTR .
134.It Bq Er EFAULT
135Attempt to read or write to the sigblock variable failed.
136Note that kernel generates the
137.Dv SIGSEGV
138signal if an attempt to read from the sigblock variable faulted
139during implicit accesses from syscall entry.
140.El
141.Sh SEE ALSO
142.Xr kill 2 ,
143.Xr signal 2 ,
144.Xr sigprocmask 2 ,
145.Xr libthr 3 ,
146.Xr ld-elf.so.1 8
147.Sh STANDARDS
148The
149.Nm
150function is non-standard, although a similar functionality is a common
151optimization provided by several other systems.
152.Sh HISTORY
153The
154.Nm
155function was introduced in
156.Fx 13.0 .
157.Sh BUGS
158The
159.Nm
160symbol is currently not exported by libc, on purpose.
161Consumers should either use the
162.Dv __sys_fast_sigblock
163symbol from the private libc namespace, or utilize
164.Xr syscall 2 .
165