summaryrefslogtreecommitdiffstats
path: root/templates/man7/epoll.7.pot
diff options
context:
space:
mode:
Diffstat (limited to '')
-rw-r--r--templates/man7/epoll.7.pot974
1 files changed, 974 insertions, 0 deletions
diff --git a/templates/man7/epoll.7.pot b/templates/man7/epoll.7.pot
new file mode 100644
index 00000000..358b3cac
--- /dev/null
+++ b/templates/man7/epoll.7.pot
@@ -0,0 +1,974 @@
+# 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 16:55+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 "epoll"
+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 "epoll - I/O event notification facility"
+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/epoll.hE<gt>>\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 ""
+"The B<epoll> API performs a similar task to B<poll>(2): monitoring multiple "
+"file descriptors to see if I/O is possible on any of them. The B<epoll> API "
+"can be used either as an edge-triggered or a level-triggered interface and "
+"scales well to large numbers of watched file descriptors."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The central concept of the B<epoll> API is the B<epoll> I<instance>, an in-"
+"kernel data structure which, from a user-space perspective, can be "
+"considered as a container for two lists:"
+msgstr ""
+
+#. type: IP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "\\[bu]"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The I<interest> list (sometimes also called the B<epoll> set): the set of "
+"file descriptors that the process has registered an interest in monitoring."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The I<ready> list: the set of file descriptors that are \"ready\" for I/O. "
+"The ready list is a subset of (or, more precisely, a set of references to) "
+"the file descriptors in the interest list. The ready list is dynamically "
+"populated by the kernel as a result of I/O activity on those file "
+"descriptors."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The following system calls are provided to create and manage an B<epoll> "
+"instance:"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"B<epoll_create>(2) creates a new B<epoll> instance and returns a file "
+"descriptor referring to that instance. (The more recent "
+"B<epoll_create1>(2) extends the functionality of B<epoll_create>(2).)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Interest in particular file descriptors is then registered via "
+"B<epoll_ctl>(2), which adds items to the interest list of the B<epoll> "
+"instance."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"B<epoll_wait>(2) waits for I/O events, blocking the calling thread if no "
+"events are currently available. (This system call can be thought of as "
+"fetching items from the ready list of the B<epoll> instance.)"
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Level-triggered and edge-triggered"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The B<epoll> event distribution interface is able to behave both as edge-"
+"triggered (ET) and as level-triggered (LT). The difference between the two "
+"mechanisms can be described as follows. Suppose that this scenario happens:"
+msgstr ""
+
+#. type: IP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "(1)"
+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 that represents the read side of a pipe (I<rfd>) is "
+"registered on the B<epoll> instance."
+msgstr ""
+
+#. type: IP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "(2)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "A pipe writer writes 2\\ kB of data on the write side of the pipe."
+msgstr ""
+
+#. type: IP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "(3)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"A call to B<epoll_wait>(2) is done that will return I<rfd> as a ready file "
+"descriptor."
+msgstr ""
+
+#. type: IP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "(4)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "The pipe reader reads 1\\ kB of data from I<rfd>."
+msgstr ""
+
+#. type: IP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "(5)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "A call to B<epoll_wait>(2) is done."
+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<rfd> file descriptor has been added to the B<epoll> interface using "
+"the B<EPOLLET> (edge-triggered) flag, the call to B<epoll_wait>(2) done in "
+"step B<5> will probably hang despite the available data still present in the "
+"file input buffer; meanwhile the remote peer might be expecting a response "
+"based on the data it already sent. The reason for this is that edge-"
+"triggered mode delivers events only when changes occur on the monitored file "
+"descriptor. So, in step B<5> the caller might end up waiting for some data "
+"that is already present inside the input buffer. In the above example, an "
+"event on I<rfd> will be generated because of the write done in B<2> and the "
+"event is consumed in B<3>. Since the read operation done in B<4> does not "
+"consume the whole buffer data, the call to B<epoll_wait>(2) done in step "
+"B<5> might block indefinitely."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"An application that employs the B<EPOLLET> flag should use nonblocking file "
+"descriptors to avoid having a blocking read or write starve a task that is "
+"handling multiple file descriptors. The suggested way to use B<epoll> as an "
+"edge-triggered (B<EPOLLET>) interface is as follows:"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "with nonblocking file descriptors; and"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"by waiting for an event only after B<read>(2) or B<write>(2) return "
+"B<EAGAIN>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"By contrast, when used as a level-triggered interface (the default, when "
+"B<EPOLLET> is not specified), B<epoll> is simply a faster B<poll>(2), and "
+"can be used wherever the latter is used since it shares the same semantics."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Since even with edge-triggered B<epoll>, multiple events can be generated "
+"upon receipt of multiple chunks of data, the caller has the option to "
+"specify the B<EPOLLONESHOT> flag, to tell B<epoll> to disable the associated "
+"file descriptor after the receipt of an event with B<epoll_wait>(2). When "
+"the B<EPOLLONESHOT> flag is specified, it is the caller's responsibility to "
+"rearm the file descriptor using B<epoll_ctl>(2) with B<EPOLL_CTL_MOD>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If multiple threads (or processes, if child processes have inherited the "
+"B<epoll> file descriptor across B<fork>(2)) are blocked in "
+"B<epoll_wait>(2) waiting on the same epoll file descriptor and a file "
+"descriptor in the interest list that is marked for edge-triggered "
+"(B<EPOLLET>) notification becomes ready, just one of the threads (or "
+"processes) is awoken from B<epoll_wait>(2). This provides a useful "
+"optimization for avoiding \"thundering herd\" wake-ups in some scenarios."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Interaction with autosleep"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If the system is in B<autosleep> mode via I</sys/power/autosleep> and an "
+"event happens which wakes the device from sleep, the device driver will keep "
+"the device awake only until that event is queued. To keep the device awake "
+"until the event has been processed, it is necessary to use the "
+"B<epoll_ctl>(2) B<EPOLLWAKEUP> flag."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"When the B<EPOLLWAKEUP> flag is set in the B<events> field for a I<struct "
+"epoll_event>, the system will be kept awake from the moment the event is "
+"queued, through the B<epoll_wait>(2) call which returns the event until the "
+"subsequent B<epoll_wait>(2) call. If the event should keep the system "
+"awake beyond that time, then a separate I<wake_lock> should be taken before "
+"the second B<epoll_wait>(2) call."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "/proc interfaces"
+msgstr ""
+
+#. Following was added in Linux 2.6.28, but them removed in Linux 2.6.29
+#. .TP
+#. .IR /proc/sys/fs/epoll/max_user_instances " (since Linux 2.6.28)"
+#. This specifies an upper limit on the number of epoll instances
+#. that can be created per real user ID.
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The following interfaces can be used to limit the amount of kernel memory "
+"consumed by epoll:"
+msgstr ""
+
+#. type: TP
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "I</proc/sys/fs/epoll/max_user_watches> (since Linux 2.6.28)"
+msgstr ""
+
+#. Linux 2.6.29 (in Linux 2.6.28, the default was 1/32 of lowmem)
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"This specifies a limit on the total number of file descriptors that a user "
+"can register across all epoll instances on the system. The limit is per "
+"real user ID. Each registered file descriptor costs roughly 90 bytes on a "
+"32-bit kernel, and roughly 160 bytes on a 64-bit kernel. Currently, the "
+"default value for I<max_user_watches> is 1/25 (4%) of the available low "
+"memory, divided by the registration cost in bytes."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Example for suggested usage"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"While the usage of B<epoll> when employed as a level-triggered interface "
+"does have the same semantics as B<poll>(2), the edge-triggered usage "
+"requires more clarification to avoid stalls in the application event loop. "
+"In this example, listener is a nonblocking socket on which B<listen>(2) has "
+"been called. The function I<do_use_fd()> uses the new ready file descriptor "
+"until B<EAGAIN> is returned by either B<read>(2) or B<write>(2). An event-"
+"driven state machine application should, after having received B<EAGAIN>, "
+"record its current state so that at the next call to I<do_use_fd()> it will "
+"continue to B<read>(2) or B<write>(2) from where it stopped before."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-tumbleweed
+#, no-wrap
+msgid ""
+"#define MAX_EVENTS 10\n"
+"struct epoll_event ev, events[MAX_EVENTS];\n"
+"int listen_sock, conn_sock, nfds, epollfd;\n"
+"\\&\n"
+"/* Code to set up listening socket, \\[aq]listen_sock\\[aq],\n"
+" (socket(), bind(), listen()) omitted. */\n"
+"\\&\n"
+"epollfd = epoll_create1(0);\n"
+"if (epollfd == -1) {\n"
+" perror(\"epoll_create1\");\n"
+" exit(EXIT_FAILURE);\n"
+"}\n"
+"\\&\n"
+"ev.events = EPOLLIN;\n"
+"ev.data.fd = listen_sock;\n"
+"if (epoll_ctl(epollfd, EPOLL_CTL_ADD, listen_sock, &ev) == -1) {\n"
+" perror(\"epoll_ctl: listen_sock\");\n"
+" exit(EXIT_FAILURE);\n"
+"}\n"
+"\\&\n"
+"for (;;) {\n"
+" nfds = epoll_wait(epollfd, events, MAX_EVENTS, -1);\n"
+" if (nfds == -1) {\n"
+" perror(\"epoll_wait\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+"\\&\n"
+" for (n = 0; n E<lt> nfds; ++n) {\n"
+" if (events[n].data.fd == listen_sock) {\n"
+" conn_sock = accept(listen_sock,\n"
+" (struct sockaddr *) &addr, &addrlen);\n"
+" if (conn_sock == -1) {\n"
+" perror(\"accept\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+" setnonblocking(conn_sock);\n"
+" ev.events = EPOLLIN | EPOLLET;\n"
+" ev.data.fd = conn_sock;\n"
+" if (epoll_ctl(epollfd, EPOLL_CTL_ADD, conn_sock,\n"
+" &ev) == -1) {\n"
+" perror(\"epoll_ctl: conn_sock\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+" } else {\n"
+" do_use_fd(events[n].data.fd);\n"
+" }\n"
+" }\n"
+"}\n"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"When used as an edge-triggered interface, for performance reasons, it is "
+"possible to add the file descriptor inside the B<epoll> interface "
+"(B<EPOLL_CTL_ADD>) once by specifying (B<EPOLLIN>|B<EPOLLOUT>). This "
+"allows you to avoid continuously switching between B<EPOLLIN> and "
+"B<EPOLLOUT> calling B<epoll_ctl>(2) with B<EPOLL_CTL_MOD>."
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Questions and answers"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"What is the key used to distinguish the file descriptors registered in an "
+"interest list?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The key is the combination of the file descriptor number and the open file "
+"description (also known as an \"open file handle\", the kernel's internal "
+"representation of an open file)."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"What happens if you register the same file descriptor on an B<epoll> "
+"instance twice?"
+msgstr ""
+
+#
+#
+#. But a file descriptor duplicated by fork(2) can't be added to the
+#. set, because the [file *, fd] pair is already in the epoll set.
+#. That is a somewhat ugly inconsistency. On the one hand, a child process
+#. cannot add the duplicate file descriptor to the epoll set. (In every
+#. other case that I can think of, file descriptors duplicated by fork have
+#. similar semantics to file descriptors duplicated by dup() and friends.) On
+#. the other hand, the very fact that the child has a duplicate of the
+#. file descriptor means that even if the parent closes its file descriptor,
+#. then epoll_wait() in the parent will continue to receive notifications for
+#. that file descriptor because of the duplicated file descriptor in the child.
+#. See http://thread.gmane.org/gmane.linux.kernel/596462/
+#. "epoll design problems with common fork/exec patterns"
+#. mtk, Feb 2008
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"You will probably get B<EEXIST>. However, it is possible to add a duplicate "
+"(B<dup>(2), B<dup2>(2), B<fcntl>(2) B<F_DUPFD>) file descriptor to the "
+"same B<epoll> instance. This can be a useful technique for filtering "
+"events, if the duplicate file descriptors are registered with different "
+"I<events> masks."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Can two B<epoll> instances wait for the same file descriptor? If so, are "
+"events reported to both B<epoll> file descriptors?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Yes, and events would be reported to both. However, careful programming may "
+"be needed to do this correctly."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Is the B<epoll> file descriptor itself poll/epoll/selectable?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Yes. If an B<epoll> file descriptor has events waiting, then it will "
+"indicate as being readable."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"What happens if one attempts to put an B<epoll> file descriptor into its own "
+"file descriptor set?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The B<epoll_ctl>(2) call fails (B<EINVAL>). However, you can add an "
+"B<epoll> file descriptor inside another B<epoll> file descriptor set."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Can I send an B<epoll> file descriptor over a UNIX domain socket to another "
+"process?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Yes, but it does not make sense to do this, since the receiving process "
+"would not have copies of the file descriptors in the interest list."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Will closing a file descriptor cause it to be removed from all B<epoll> "
+"interest lists?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Yes, but be aware of the following point. A file descriptor is a reference "
+"to an open file description (see B<open>(2)). Whenever a file descriptor is "
+"duplicated via B<dup>(2), B<dup2>(2), B<fcntl>(2) B<F_DUPFD>, or "
+"B<fork>(2), a new file descriptor referring to the same open file "
+"description is created. An open file description continues to exist until "
+"all file descriptors referring to it have been closed."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"A file descriptor is removed from an interest list only after all the file "
+"descriptors referring to the underlying open file description have been "
+"closed. This means that even after a file descriptor that is part of an "
+"interest list has been closed, events may be reported for that file "
+"descriptor if other file descriptors referring to the same underlying file "
+"description remain open. To prevent this happening, the file descriptor "
+"must be explicitly removed from the interest list (using B<epoll_ctl>(2) "
+"B<EPOLL_CTL_DEL>) before it is duplicated. Alternatively, the application "
+"must ensure that all file descriptors are closed (which may be difficult if "
+"file descriptors were duplicated behind the scenes by library functions that "
+"used B<dup>(2) or B<fork>(2))."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If more than one event occurs between B<epoll_wait>(2) calls, are they "
+"combined or reported separately?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "They will be combined."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Does an operation on a file descriptor affect the already collected but not "
+"yet reported events?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"You can do two operations on an existing file descriptor. Remove would be "
+"meaningless for this case. Modify will reread available I/O."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Do I need to continuously read/write a file descriptor until B<EAGAIN> when "
+"using the B<EPOLLET> flag (edge-triggered behavior)?"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Receiving an event from B<epoll_wait>(2) should suggest to you that such "
+"file descriptor is ready for the requested I/O operation. You must consider "
+"it ready until the next (nonblocking) read/write yields B<EAGAIN>. When "
+"and how you will use the file descriptor is entirely up to you."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"For packet/token-oriented files (e.g., datagram socket, terminal in "
+"canonical mode), the only way to detect the end of the read/write I/O space "
+"is to continue to read/write until B<EAGAIN>."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"For stream-oriented files (e.g., pipe, FIFO, stream socket), the condition "
+"that the read/write I/O space is exhausted can also be detected by checking "
+"the amount of data read from / written to the target file descriptor. For "
+"example, if you call B<read>(2) by asking to read a certain amount of data "
+"and B<read>(2) returns a lower number of bytes, you can be sure of having "
+"exhausted the read I/O space for the file descriptor. The same is true when "
+"writing using B<write>(2). (Avoid this latter technique if you cannot "
+"guarantee that the monitored file descriptor always refers to a stream-"
+"oriented file.)"
+msgstr ""
+
+#. type: SS
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+#, no-wrap
+msgid "Possible pitfalls and ways to avoid them"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "B<Starvation (edge-triggered)>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If there is a large amount of I/O space, it is possible that by trying to "
+"drain it the other files will not get processed causing starvation. (This "
+"problem is not specific to B<epoll>.)"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The solution is to maintain a ready list and mark the file descriptor as "
+"ready in its associated data structure, thereby allowing the application to "
+"remember which files need to be processed but still round robin amongst all "
+"the ready files. This also supports ignoring subsequent events you receive "
+"for file descriptors that are already ready."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid "B<If using an event cache...>"
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"If you use an event cache or store all the file descriptors returned from "
+"B<epoll_wait>(2), then make sure to provide a way to mark its closure "
+"dynamically (i.e., caused by a previous event's processing). Suppose you "
+"receive 100 events from B<epoll_wait>(2), and in event #47 a condition "
+"causes event #13 to be closed. If you remove the structure and B<close>(2) "
+"the file descriptor for event #13, then your event cache might still say "
+"there are events waiting for that file descriptor causing confusion."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"One solution for this is to call, during the processing of event 47, "
+"B<epoll_ctl>(B<EPOLL_CTL_DEL>) to delete file descriptor 13 and "
+"B<close>(2), then mark its associated data structure as removed and link it "
+"to a cleanup list. If you find another event for file descriptor 13 in your "
+"batch processing, you will discover the file descriptor had been previously "
+"removed and there will be no confusion."
+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: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"Some other systems provide similar mechanisms; for example, FreeBSD has "
+"I<kqueue>, and Solaris has I</dev/poll>."
+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 ""
+
+#. Its interface should be finalized in Linux 2.5.66.
+#. type: Plain text
+#: archlinux debian-unstable fedora-40 fedora-rawhide mageia-cauldron
+#: opensuse-leap-15-6 opensuse-tumbleweed
+msgid "Linux 2.5.44. glibc 2.3.2."
+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 ""
+"The set of file descriptors that is being monitored via an epoll file "
+"descriptor can be viewed via the entry for the epoll file descriptor in the "
+"process's I</proc/>pidI</fdinfo> directory. See B<proc>(5) for further "
+"details."
+msgstr ""
+
+#. type: Plain text
+#: archlinux debian-bookworm debian-unstable fedora-40 fedora-rawhide
+#: mageia-cauldron opensuse-leap-15-6 opensuse-tumbleweed
+msgid ""
+"The B<kcmp>(2) B<KCMP_EPOLL_TFD> operation can be used to test whether a "
+"file descriptor is present in an epoll instance."
+msgstr ""
+
+#. 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<epoll_create>(2), B<epoll_create1>(2), B<epoll_ctl>(2), B<epoll_wait>(2), "
+"B<poll>(2), B<select>(2)"
+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: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"#define MAX_EVENTS 10\n"
+"struct epoll_event ev, events[MAX_EVENTS];\n"
+"int listen_sock, conn_sock, nfds, epollfd;\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"/* Code to set up listening socket, \\[aq]listen_sock\\[aq],\n"
+" (socket(), bind(), listen()) omitted. */\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"epollfd = epoll_create1(0);\n"
+"if (epollfd == -1) {\n"
+" perror(\"epoll_create1\");\n"
+" exit(EXIT_FAILURE);\n"
+"}\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"ev.events = EPOLLIN;\n"
+"ev.data.fd = listen_sock;\n"
+"if (epoll_ctl(epollfd, EPOLL_CTL_ADD, listen_sock, &ev) == -1) {\n"
+" perror(\"epoll_ctl: listen_sock\");\n"
+" exit(EXIT_FAILURE);\n"
+"}\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+"for (;;) {\n"
+" nfds = epoll_wait(epollfd, events, MAX_EVENTS, -1);\n"
+" if (nfds == -1) {\n"
+" perror(\"epoll_wait\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm opensuse-leap-15-6
+#, no-wrap
+msgid ""
+" for (n = 0; n E<lt> nfds; ++n) {\n"
+" if (events[n].data.fd == listen_sock) {\n"
+" conn_sock = accept(listen_sock,\n"
+" (struct sockaddr *) &addr, &addrlen);\n"
+" if (conn_sock == -1) {\n"
+" perror(\"accept\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+" setnonblocking(conn_sock);\n"
+" ev.events = EPOLLIN | EPOLLET;\n"
+" ev.data.fd = conn_sock;\n"
+" if (epoll_ctl(epollfd, EPOLL_CTL_ADD, conn_sock,\n"
+" &ev) == -1) {\n"
+" perror(\"epoll_ctl: conn_sock\");\n"
+" exit(EXIT_FAILURE);\n"
+" }\n"
+" } else {\n"
+" do_use_fd(events[n].data.fd);\n"
+" }\n"
+" }\n"
+"}\n"
+msgstr ""
+
+#. Its interface should be finalized in Linux kernel 2.5.66.
+#. type: Plain text
+#: debian-bookworm
+msgid ""
+"The B<epoll> API was introduced in Linux kernel 2.5.44. Support was added "
+"in glibc 2.3.2."
+msgstr ""
+
+#. type: Plain text
+#: debian-bookworm
+msgid ""
+"The B<epoll> API is Linux-specific. Some other systems provide similar "
+"mechanisms, for example, FreeBSD has I<kqueue>, and Solaris has I</dev/poll>."
+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 ""