POLL(2) System Calls POLL(2)

NAME


poll - input/output multiplexing

SYNOPSIS


#include <poll.h>

int poll(struct pollfd fds[], nfds_t nfds, int timeout);

int ppoll(struct pollfd *restrict fds, nfds_t nfds,
const struct timespec *restrict tsp, const sigset_t *restrict sigmask);


DESCRIPTION


The poll() and ppoll() functions provides applications with a mechanism
for multiplexing input/output over a set of file descriptors. For each
member of the array pointed to by fds, poll() and ppoll() examine the
given file descriptor for the event(s) specified in events. The number
of pollfd structures in the fds array is specified by nfds. The poll()
and ppoll() functions identify those file descriptors on which an
application can read or write data, or on which certain events have
occurred.


The ppoll() function behaves identically to poll(), except as follows:

o For the ppoll function, the timeout period is given in seconds
and nanoseconds in an argument of type struct timespec, where
as poll() takes a timeout in milliseconds in the form of an
integer argument.

o The ppoll() function takes an optional sigmask argument. When
a non-NULL pointer is passed, the calling threads signal mask
is replaced by the one specified in sigset before examining
file descriptors, and restored before returning.


The fds argument specifies the file descriptors to be examined and the
events of interest for each file descriptor. It is a pointer to an array
with one member for each open file descriptor of interest. The array's
members are pollfd structures, which contain the following members:

int fd; /* file descriptor */
short events; /* requested events */
short revents; /* returned events */


The fd member specifies an open file descriptor and the events and
revents members are bitmasks constructed by a logical OR operation of any
combination of the following event flags:

POLLIN
Data other than high priority data may be read without
blocking. For streams, this flag is set in revents even if
the message is of zero length.


POLLRDNORM
Normal data (priority band equals 0) may be read without
blocking. For streams, this flag is set in revents even if
the message is of zero length.


POLLRDBAND
Data from a non-zero priority band may be read without
blocking. For streams, this flag is set in revents even if
the message is of zero length.


POLLPRI
High priority data may be received without blocking. For
streams, this flag is set in revents even if the message is
of zero length.


POLLOUT
Normal data (priority band equals 0) may be written without
blocking.


POLLWRNORM
The same as POLLOUT.


POLLWRBAND
Priority data (priority band > 0) may be written. This
event only examines bands that have been written to at
least once.


POLLERR
An error has occurred on the device or stream. This flag
is only valid in the revents bitmask; it is not used in the
events member.


POLLHUP
A hangup has occurred on the stream. This event and
POLLOUT are mutually exclusive; a stream can never be
writable if a hangup has occurred. However, this event and
POLLIN, POLLRDNORM, POLLRDBAND, or POLLPRI are not mutually
exclusive. This flag is only valid in the revents bitmask;
it is not used in the events member.


POLLNVAL
The specified fd value does not belong to an open file.
This flag is only valid in the revents member; it is not
used in the events member.


If the value fd is less than 0, events is ignored and revents is set to 0
in that entry on return from poll() and ppoll().


The results of the poll() or ppoll() query are stored in the revents
member in the pollfd structure. Bits are set in the revents bitmask to
indicate which of the requested events are true. If none are true, none
of the specified bits are set in revents when either the poll() or
ppoll() call returns. The event flags POLLHUP, POLLERR, and POLLNVAL
are always set in revents if the conditions they indicate are true; this
occurs even though these flags were not present in events.


If none of the defined events have occurred on any selected file
descriptor, poll() and ppoll() wait at least timeout milliseconds for an
event to occur on any of the selected file descriptors. On a computer
where millisecond timing accuracy is not available, timeout is rounded up
to the nearest legal value available on that system. If the value timeout
is 0, poll() returns immediately. If the value of timeout is -1, poll()
blocks until a requested event occurs or until the call is interrupted.
If the value of tsp is NULL, then ppoll() blocks until a requested event
occurs or until the call is interrupted. The poll() and ppoll() functions
are not affected by the O_NDELAY and O_NONBLOCK flags.


The poll() and ppoll() functions support regular files, terminal and
pseudo-terminal devices, streams-based files, FIFOs, pipes, and sockets.
The behavior of poll() and ppoll() on elements of fds that refer to other
types of file is unspecified.


A file descriptor for a socket that is listening for connections will
indicate that it is ready for reading, once connections are available. A
file descriptor for a socket that is connecting asynchronously will
indicate that it is ready for writing, once a connection has been
established.


Regular files always poll() and ppoll() TRUE for reading and writing.

RETURN VALUES


Upon successful completion, a non-negative value is returned. A positive
value indicates the total number of file descriptors that has been
selected (that is, file descriptors for which the revents member is non-
zero). A value of 0 indicates that the call timed out and no file
descriptors have been selected. Upon failure, -1 is returned and errno is
set to indicate the error.

ERRORS


The poll() and ppoll() functions will fail if:

EAGAIN
Allocation of internal data structures failed, but the request
may be attempted again.


EFAULT
Some argument points to an illegal address.


EINTR
A signal was caught during the poll() or ppoll() function.


EINVAL
The argument nfds is greater than {OPEN_MAX}, or one of the fd
members refers to a stream or multiplexer that is linked
(directly or indirectly) downstream from a multiplexer.


ATTRIBUTES


See attributes(7) for descriptions of the following attributes:


+--------------------+-----------------+
| ATTRIBUTE TYPE | ATTRIBUTE VALUE |
+--------------------+-----------------+
|Interface Stability | Standard |
+--------------------+-----------------+

SEE ALSO


Intro(2), getmsg(2), getrlimit(2), putmsg(2), read(2), write(2),
select(3C), attributes(7), standards(7), chpoll(9E)


STREAMS Programming Guide

NOTES


Non-STREAMS drivers use chpoll(9E) to implement poll() on these
devices.

August 23, 2001 POLL(2)