summaryrefslogtreecommitdiffstats
path: root/templates/man2/signalfd.2.pot
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--templates/man2/signalfd.2.pot961
1 files changed, 961 insertions, 0 deletions
diff --git a/templates/man2/signalfd.2.pot b/templates/man2/signalfd.2.pot
new file mode 100644
index 00000000..d76b68a7
--- /dev/null
+++ b/templates/man2/signalfd.2.pot
@@ -0,0 +1,961 @@
+# SOME DESCRIPTIVE TITLE
+# Copyright (C) YEAR Free Software Foundation, Inc.
+# This file is distributed under the same license as the PACKAGE package.
+# FIRST AUTHOR <EMAIL@ADDRESS>, YEAR.
+#
+#, fuzzy
+msgid ""
+msgstr ""
+"Project-Id-Version: PACKAGE VERSION\n"
+"POT-Creation-Date: 2024-03-01 17:08+0100\n"
+"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
+"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
+"Language-Team: LANGUAGE <LL@li.org>\n"
+"Language: \n"
+"MIME-Version: 1.0\n"
+"Content-Type: text/plain; charset=UTF-8\n"
+"Content-Transfer-Encoding: 8bit\n"
+
+#. type: TH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "signalfd"
+msgstr ""
+
+#. type: TH
+#: archlinux fedora-40 fedora-rawhide mageia-cauldron
+#, no-wrap
+msgid "2023-10-31"
+msgstr ""
+
+#. type: TH
+#: archlinux fedora-40 fedora-rawhide mageia-cauldron
+#, no-wrap
+msgid "Linux man-pages 6.06"
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "NAME"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "signalfd - create a file descriptor for accepting signals"
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "LIBRARY"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Standard C library (I<libc>, I<-lc>)"
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "SYNOPSIS"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<#include E<lt>sys/signalfd.hE<gt>>\n"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<int signalfd(int >I<fd>B<, const sigset_t *>I<mask>B<, int >I<flags>B<);>\n"
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "DESCRIPTION"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"B<signalfd>() creates a file descriptor that can be used to accept signals "
+"targeted at the caller. This provides an alternative to the use of a signal "
+"handler or B<sigwaitinfo>(2), and has the advantage that the file descriptor "
+"may be monitored by B<select>(2), B<poll>(2), and B<epoll>(7)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The I<mask> argument specifies the set of signals that the caller wishes to "
+"accept via the file descriptor. This argument is a signal set whose "
+"contents can be initialized using the macros described in B<sigsetops>(3). "
+"Normally, the set of signals to be received via the file descriptor should "
+"be blocked using B<sigprocmask>(2), to prevent the signals being handled "
+"according to their default dispositions. It is not possible to receive "
+"B<SIGKILL> or B<SIGSTOP> signals via a signalfd file descriptor; these "
+"signals are silently ignored if specified in I<mask>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If the I<fd> argument is -1, then the call creates a new file descriptor and "
+"associates the signal set specified in I<mask> with that file descriptor. "
+"If I<fd> is not -1, then it must specify a valid existing signalfd file "
+"descriptor, and I<mask> is used to replace the signal set associated with "
+"that file descriptor."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Starting with Linux 2.6.27, the following values may be bitwise ORed in "
+"I<flags> to change the behavior of B<signalfd>():"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<SFD_NONBLOCK>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Set the B<O_NONBLOCK> file status flag on the open file description (see "
+"B<open>(2)) referred to by the new file descriptor. Using this flag saves "
+"extra calls to B<fcntl>(2) to achieve the same result."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<SFD_CLOEXEC>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Set the close-on-exec (B<FD_CLOEXEC>) flag on the new file descriptor. See "
+"the description of the B<O_CLOEXEC> flag in B<open>(2) for reasons why this "
+"may be useful."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Up to Linux 2.6.26, the I<flags> argument is unused, and must be specified "
+"as zero."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"B<signalfd>() returns a file descriptor that supports the following "
+"operations:"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<read>(2)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If one or more of the signals specified in I<mask> is pending for the "
+"process, then the buffer supplied to B<read>(2) is used to return one or "
+"more I<signalfd_siginfo> structures (see below) that describe the signals. "
+"The B<read>(2) returns information for as many signals as are pending and "
+"will fit in the supplied buffer. The buffer must be at least "
+"I<sizeof(struct signalfd_siginfo)> bytes. The return value of the "
+"B<read>(2) is the total number of bytes read."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"As a consequence of the B<read>(2), the signals are consumed, so that they "
+"are no longer pending for the process (i.e., will not be caught by signal "
+"handlers, and cannot be accepted using B<sigwaitinfo>(2))."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If none of the signals in I<mask> is pending for the process, then the "
+"B<read>(2) either blocks until one of the signals in I<mask> is generated "
+"for the process, or fails with the error B<EAGAIN> if the file descriptor "
+"has been made nonblocking."
+msgstr ""
+
+#. type: TP
+#: archlinux fedora-40 fedora-rawhide mageia-cauldron
+#, no-wrap
+msgid "B<poll>(2)"
+msgstr ""
+
+#. type: TQ
+#: archlinux fedora-40 fedora-rawhide mageia-cauldron
+#, no-wrap
+msgid "B<select>(2)"
+msgstr ""
+
+#. type: TQ
+#: archlinux fedora-40 fedora-rawhide mageia-cauldron
+#, no-wrap
+msgid "(and similar)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The file descriptor is readable (the B<select>(2) I<readfds> argument; the "
+"B<poll>(2) B<POLLIN> flag) if one or more of the signals in I<mask> is "
+"pending for the process."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The signalfd file descriptor also supports the other file-descriptor "
+"multiplexing APIs: B<pselect>(2), B<ppoll>(2), and B<epoll>(7)."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<close>(2)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"When the file descriptor is no longer required it should be closed. When "
+"all file descriptors associated with the same signalfd object have been "
+"closed, the resources for object are freed by the kernel."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "The signalfd_siginfo structure"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The format of the I<signalfd_siginfo> structure(s) returned by B<read>(2)s "
+"from a signalfd file descriptor is as follows:"
+msgstr ""
+
+#. ssi_trapno is unused on most arches
+#. ssi_addr_lsb: commit b8aeec34175fc8fe8b0d40efea4846dfc1ba663e
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid ""
+"struct signalfd_siginfo {\n"
+" uint32_t ssi_signo; /* Signal number */\n"
+" int32_t ssi_errno; /* Error number (unused) */\n"
+" int32_t ssi_code; /* Signal code */\n"
+" uint32_t ssi_pid; /* PID of sender */\n"
+" uint32_t ssi_uid; /* Real UID of sender */\n"
+" int32_t ssi_fd; /* File descriptor (SIGIO) */\n"
+" uint32_t ssi_tid; /* Kernel timer ID (POSIX timers)\n"
+" uint32_t ssi_band; /* Band event (SIGIO) */\n"
+" uint32_t ssi_overrun; /* POSIX timer overrun count */\n"
+" uint32_t ssi_trapno; /* Trap number that caused signal */\n"
+" int32_t ssi_status; /* Exit status or signal (SIGCHLD) */\n"
+" int32_t ssi_int; /* Integer sent by sigqueue(3) */\n"
+" uint64_t ssi_ptr; /* Pointer sent by sigqueue(3) */\n"
+" uint64_t ssi_utime; /* User CPU time consumed (SIGCHLD) */\n"
+" uint64_t ssi_stime; /* System CPU time consumed\n"
+" (SIGCHLD) */\n"
+" uint64_t ssi_addr; /* Address that generated signal\n"
+" (for hardware-generated signals) */\n"
+" uint16_t ssi_addr_lsb; /* Least significant bit of address\n"
+" (SIGBUS; since Linux 2.6.37) */\n"
+" uint8_t pad[I<X>]; /* Pad size to 128 bytes (allow for\n"
+" additional fields in the future) */\n"
+"};\n"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Each of the fields in this structure is analogous to the similarly named "
+"field in the I<siginfo_t> structure. The I<siginfo_t> structure is "
+"described in B<sigaction>(2). Not all fields in the returned "
+"I<signalfd_siginfo> structure will be valid for a specific signal; the set "
+"of valid fields can be determined from the value returned in the I<ssi_code> "
+"field. This field is the analog of the I<siginfo_t> I<si_code> field; see "
+"B<sigaction>(2) for details."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "fork(2) semantics"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"After a B<fork>(2), the child inherits a copy of the signalfd file "
+"descriptor. A B<read>(2) from the file descriptor in the child will return "
+"information about signals queued to the child."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Semantics of file descriptor passing"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"As with other file descriptors, signalfd file descriptors can be passed to "
+"another process via a UNIX domain socket (see B<unix>(7)). In the receiving "
+"process, a B<read>(2) from the received file descriptor will return "
+"information about signals queued to that process."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "execve(2) semantics"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Just like any other file descriptor, a signalfd file descriptor remains open "
+"across an B<execve>(2), unless it has been marked for close-on-exec (see "
+"B<fcntl>(2)). Any signals that were available for reading before the "
+"B<execve>(2) remain available to the newly loaded program. (This is "
+"analogous to traditional signal semantics, where a blocked signal that is "
+"pending remains pending across an B<execve>(2).)"
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Thread semantics"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The semantics of signalfd file descriptors in a multithreaded program mirror "
+"the standard semantics for signals. In other words, when a thread reads "
+"from a signalfd file descriptor, it will read the signals that are directed "
+"to the thread itself and the signals that are directed to the process (i.e., "
+"the entire thread group). (A thread will not be able to read signals that "
+"are directed to other threads in the process.)"
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "epoll(7) semantics"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If a process adds (via B<epoll_ctl>(2)) a signalfd file descriptor to an "
+"B<epoll>(7) instance, then B<epoll_wait>(2) returns events only for "
+"signals sent to that process. In particular, if the process then uses "
+"B<fork>(2) to create a child process, then the child will be able to "
+"B<read>(2) signals that are sent to it using the signalfd file descriptor, "
+"but B<epoll_wait>(2) will B<not> indicate that the signalfd file descriptor "
+"is ready. In this scenario, a possible workaround is that after the "
+"B<fork>(2), the child process can close the signalfd file descriptor that it "
+"inherited from the parent process and then create another signalfd file "
+"descriptor and add it to the epoll instance. Alternatively, the parent and "
+"the child could delay creating their (separate) signalfd file descriptors "
+"and adding them to the epoll instance until after the call to B<fork>(2)."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "RETURN VALUE"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"On success, B<signalfd>() returns a signalfd file descriptor; this is "
+"either a new file descriptor (if I<fd> was -1), or I<fd> if I<fd> was a "
+"valid signalfd file descriptor. On error, -1 is returned and I<errno> is "
+"set to indicate the error."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "ERRORS"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<EBADF>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "The I<fd> file descriptor is not a valid file descriptor."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<EINVAL>"
+msgstr ""
+
+#. or, the
+#. .I sizemask
+#. argument is not equal to
+#. .IR sizeof(sigset_t) ;
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "I<fd> is not a valid signalfd file descriptor."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"I<flags> is invalid; or, in Linux 2.6.26 or earlier, I<flags> is nonzero."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<EMFILE>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The per-process limit on the number of open file descriptors has been "
+"reached."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<ENFILE>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The system-wide limit on the total number of open files has been reached."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<ENODEV>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Could not mount (internal) anonymous inode device."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<ENOMEM>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "There was insufficient memory to create a new signalfd file descriptor."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "VERSIONS"
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "C library/kernel differences"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The underlying Linux system call requires an additional argument, I<size_t "
+"sizemask>, which specifies the size of the I<mask> argument. The glibc "
+"B<signalfd>() wrapper function does not include this argument, since it "
+"provides the required value for the underlying system call."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"There are two underlying Linux system calls: B<signalfd>() and the more "
+"recent B<signalfd4>(). The former system call does not implement a I<flags> "
+"argument. The latter system call implements the I<flags> values described "
+"above. Starting with glibc 2.9, the B<signalfd>() wrapper function will "
+"use B<signalfd4>() where it is available."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "STANDARDS"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Linux."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "HISTORY"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<signalfd>()"
+msgstr ""
+
+#. signalfd() is in glibc 2.7, but reportedly does not build
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Linux 2.6.22, glibc 2.8."
+msgstr ""
+
+#. type: TP
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<signalfd4>()"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Linux 2.6.27."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "NOTES"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"A process can create multiple signalfd file descriptors. This makes it "
+"possible to accept different signals on different file descriptors. (This "
+"may be useful if monitoring the file descriptors using B<select>(2), "
+"B<poll>(2), or B<epoll>(7): the arrival of different signals will make "
+"different file descriptors ready.) If a signal appears in the I<mask> of "
+"more than one of the file descriptors, then occurrences of that signal can "
+"be read (once) from any one of the file descriptors."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Attempts to include B<SIGKILL> and B<SIGSTOP> in I<mask> are silently "
+"ignored."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The signal mask employed by a signalfd file descriptor can be viewed via the "
+"entry for the corresponding file descriptor in the process's I</proc/>pidI</"
+"fdinfo> directory. See B<proc>(5) for further details."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Limitations"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The signalfd mechanism can't be used to receive signals that are "
+"synchronously generated, such as the B<SIGSEGV> signal that results from "
+"accessing an invalid memory address or the B<SIGFPE> signal that results "
+"from an arithmetic error. Such signals can be caught only via signal "
+"handler."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"As described above, in normal usage one blocks the signals that will be "
+"accepted via B<signalfd>(). If spawning a child process to execute a helper "
+"program (that does not need the signalfd file descriptor), then, after the "
+"call to B<fork>(2), you will normally want to unblock those signals before "
+"calling B<execve>(2), so that the helper program can see any signals that it "
+"expects to see. Be aware, however, that this won't be possible in the case "
+"of a helper program spawned behind the scenes by any library function that "
+"the program may call. In such cases, one must fall back to using a "
+"traditional signal handler that writes to a file descriptor monitored by "
+"B<select>(2), B<poll>(2), or B<epoll>(7)."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "BUGS"
+msgstr ""
+
+#. The fix also was put into Linux 2.6.24.5
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Before Linux 2.6.25, the I<ssi_ptr> and I<ssi_int> fields are not filled in "
+"with the data accompanying a signal sent by B<sigqueue>(3)."
+msgstr ""
+
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "EXAMPLES"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The program below accepts the signals B<SIGINT> and B<SIGQUIT> via a "
+"signalfd file descriptor. The program terminates after accepting a "
+"B<SIGQUIT> signal. The following shell session demonstrates the use of the "
+"program:"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid ""
+"$B< ./signalfd_demo>\n"
+"B<\\[ha]C> # Control-C generates SIGINT\n"
+"Got SIGINT\n"
+"B<\\[ha]C>\n"
+"Got SIGINT\n"
+"B<\\[ha]\\e> # Control-\\e generates SIGQUIT\n"
+"Got SIGQUIT\n"
+"$\n"
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Program source"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-tumbleweed
+#, no-wrap
+msgid ""
+"#include E<lt>err.hE<gt>\n"
+"#include E<lt>signal.hE<gt>\n"
+"#include E<lt>stdio.hE<gt>\n"
+"#include E<lt>stdlib.hE<gt>\n"
+"#include E<lt>sys/signalfd.hE<gt>\n"
+"#include E<lt>unistd.hE<gt>\n"
+"\\&\n"
+"int\n"
+"main(void)\n"
+"{\n"
+" int sfd;\n"
+" ssize_t s;\n"
+" sigset_t mask;\n"
+" struct signalfd_siginfo fdsi;\n"
+"\\&\n"
+" sigemptyset(&mask);\n"
+" sigaddset(&mask, SIGINT);\n"
+" sigaddset(&mask, SIGQUIT);\n"
+"\\&\n"
+" /* Block signals so that they aren\\[aq]t handled\n"
+" according to their default dispositions. */\n"
+"\\&\n"
+" if (sigprocmask(SIG_BLOCK, &mask, NULL) == -1)\n"
+" err(EXIT_FAILURE, \"sigprocmask\");\n"
+"\\&\n"
+" sfd = signalfd(-1, &mask, 0);\n"
+" if (sfd == -1)\n"
+" err(EXIT_FAILURE, \"signalfd\");\n"
+"\\&\n"
+" for (;;) {\n"
+" s = read(sfd, &fdsi, sizeof(fdsi));\n"
+" if (s != sizeof(fdsi))\n"
+" err(EXIT_FAILURE, \"read\");\n"
+"\\&\n"
+" if (fdsi.ssi_signo == SIGINT) {\n"
+" printf(\"Got SIGINT\\en\");\n"
+" } else if (fdsi.ssi_signo == SIGQUIT) {\n"
+" printf(\"Got SIGQUIT\\en\");\n"
+" exit(EXIT_SUCCESS);\n"
+" } else {\n"
+" printf(\"Read unexpected signal\\en\");\n"
+" }\n"
+" }\n"
+"}\n"
+msgstr ""
+
+#. SRC END
+#. type: SH
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "SEE ALSO"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"B<eventfd>(2), B<poll>(2), B<read>(2), B<select>(2), B<sigaction>(2), "
+"B<sigprocmask>(2), B<sigwaitinfo>(2), B<timerfd_create>(2), B<sigsetops>(3), "
+"B<sigwait>(3), B<epoll>(7), B<signal>(7)"
+msgstr ""
+
+#. type: TH
+#: debian-bookworm
+#, no-wrap
+msgid "2023-02-05"
+msgstr ""
+
+#. type: TH
+#: debian-bookworm
+#, no-wrap
+msgid "Linux man-pages 6.03"
+msgstr ""
+
+#. type: TP
+#: debian-bookworm debian-unstable opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "B<poll>(2), B<select>(2) (and similar)"
+msgstr ""
+
+#. signalfd() is in glibc 2.7, but reportedly does not build
+#. type: Plain text
+#: debian-bookworm
+msgid ""
+"B<signalfd>() is available since Linux 2.6.22. Working support is provided "
+"since glibc 2.8. The B<signalfd4>() system call (see NOTES) is available "
+"since Linux 2.6.27."
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm
+msgid "B<signalfd>() and B<signalfd4>() are Linux-specific."
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"#include E<lt>err.hE<gt>\n"
+"#include E<lt>signal.hE<gt>\n"
+"#include E<lt>stdio.hE<gt>\n"
+"#include E<lt>stdlib.hE<gt>\n"
+"#include E<lt>sys/signalfd.hE<gt>\n"
+"#include E<lt>unistd.hE<gt>\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"int\n"
+"main(void)\n"
+"{\n"
+" int sfd;\n"
+" ssize_t s;\n"
+" sigset_t mask;\n"
+" struct signalfd_siginfo fdsi;\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" sigemptyset(&mask);\n"
+" sigaddset(&mask, SIGINT);\n"
+" sigaddset(&mask, SIGQUIT);\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" /* Block signals so that they aren\\[aq]t handled\n"
+" according to their default dispositions. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" if (sigprocmask(SIG_BLOCK, &mask, NULL) == -1)\n"
+" err(EXIT_FAILURE, \"sigprocmask\");\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" sfd = signalfd(-1, &mask, 0);\n"
+" if (sfd == -1)\n"
+" err(EXIT_FAILURE, \"signalfd\");\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" for (;;) {\n"
+" s = read(sfd, &fdsi, sizeof(fdsi));\n"
+" if (s != sizeof(fdsi))\n"
+" err(EXIT_FAILURE, \"read\");\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" if (fdsi.ssi_signo == SIGINT) {\n"
+" printf(\"Got SIGINT\\en\");\n"
+" } else if (fdsi.ssi_signo == SIGQUIT) {\n"
+" printf(\"Got SIGQUIT\\en\");\n"
+" exit(EXIT_SUCCESS);\n"
+" } else {\n"
+" printf(\"Read unexpected signal\\en\");\n"
+" }\n"
+" }\n"
+"}\n"
+msgstr ""
+
+#. type: TH
+#: debian-unstable opensuse-tumbleweed
+#, no-wrap
+msgid "2023-05-03"
+msgstr ""
+
+#. type: TH
+#: debian-unstable opensuse-tumbleweed
+#, no-wrap
+msgid "Linux man-pages 6.05.01"
+msgstr ""
+
+#. type: TH
+#: opensuse-leap-15-6
+#, no-wrap
+msgid "2023-03-30"
+msgstr ""
+
+#. type: TH
+#: opensuse-leap-15-6
+#, no-wrap
+msgid "Linux man-pages 6.04"
+msgstr ""