НАЗВАНИЕ
poll - мультиплексирование псевдоустройств по вводу/выводу
СИНТАКСИС
#include <stropts.h> #include <poll.h> int poll (fds, nfds, timeout) struct pollfd fds [ ]; unsigned long nfds; int timeout;
ОПИСАНИЕ
Системный вызов poll предоставляет пользователю механизм одновременного управления вводом/выводом (мультиплексирования) для набора дескрипторов открытых потоков
[см. intro(2)]. Poll идентифицирует потоки, с которыми
пользователь может обменяться сообщениями, а также потоки, в которых произошли определенные события. Сообщения можно принимать с помощью системных вызовов read(2)
или getmsg(2), а посылать посредством write(2) или
putmsg(2). Некоторые команды из группы ioctl(2), такие
как I_RECVFD и I_SENDFD [см. streamio(7)], также могут
быть использованы для приема и посылки сообщений.
Аргумент fds задает дескрипторы файлов, которые должны анализироваться, и интересующие пользователя события для каждого из дескрипторов. Fds есть указатель на массив из стольких элементов, сколько дескрипторов файлов интересует пользователя. Элементами массива являются структуры типа pollfd, содержащие следующие элементы:
int fd; /* Дескриптор файла */ short events; /* Интересующие события */ short revents; /* Происшедшие события */
Компонент fd задает дескриптор открытого файла, а events и revents являются масками, построенными с помощью побитной операции ИЛИ из следующих флагов:
Для каждого элемента массива, на который указывает аргумент fds, poll проверяет дескриптор файла fd на наличие событий, указанных в events. Количество дескрипторов файлов задается аргументом nfds. Если nfds превосходит NOFILES - системное ограничение на количество одновременно открытых файлов [см. intro(2)] - poll завершается неудачей.
Если значение fd меньше нуля, events игнорируется, а revents для этого элемента устанавливается равным 0.
Результаты работы системного вызова poll помещаются в поле revents структуры типа pollfd. Единичные биты в revents показывают, какие из событий, интересующих пользователя, произошли. Если ни одно из событий не произошло, poll возвращает в revents нулевые значения бит. Флаги POLLHUP, POLLERR и POLLNVAL устанавливаются в revents, если выполнены соответствующие условия; это происходит даже тогда, когда перечисленные флаги не установлены в поле events.
Если ни одно из ожидаемых событий ни для одного из указанных дескрипторов файлов не имеет места, poll будет ждать как минимум timeout миллисекунд того, чтобы по крайней мере одно событие хотя бы для одного дескриптора произошло. На компьютерах, где время не может быть измерено с точностью до миллисекунд, timeout округляется до ближайшего доступного системе значения. Если значение timeout равно 0, poll возвращает управление немедленно. Если значение timeout равно -1, poll ждет, пока не произойдет одно из событий, или системный вызов не будет прерван. Флаг O_NDELAY не влияет на poll.
Системный вызов poll завершается неудачей, если выполнено хотя бы одно из следующих условий:
СМ. ТАКЖЕ
intro(2), read(2), getmsg(2), putmsg(2), write(2).
streamio(7) в Справочнике администратора.
ДИАГНОСТИКА
При успешном завершении возвращается неотрицательное
целое число. Положительный результат равен количеству
дескрипторов, для которых произошли события (то есть
компонент revents не равен 0). Нулевой результат означает, что истек таймаут, а никаких событий не произошло. В случае ошибки возвращается -1, а переменной errno
присваивается код ошибки.