blob: 2bad655292c4e095118045de4c62790b37082738 [file] [log] [blame]
The Android Open Source Project1dc9e472009-03-03 19:28:35 -08001/*
2 * Copyright (C) 2008 The Android Open Source Project
3 * All rights reserved.
4 *
5 * Redistribution and use in source and binary forms, with or without
6 * modification, are permitted provided that the following conditions
7 * are met:
8 * * Redistributions of source code must retain the above copyright
9 * notice, this list of conditions and the following disclaimer.
10 * * Redistributions in binary form must reproduce the above copyright
11 * notice, this list of conditions and the following disclaimer in
12 * the documentation and/or other materials provided with the
13 * distribution.
14 *
15 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
16 * "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
17 * LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS
18 * FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
19 * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT,
20 * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING,
21 * BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS
22 * OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
23 * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
24 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
25 * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
26 * SUCH DAMAGE.
27 */
Elliott Hughes93de3d82013-10-23 11:25:54 -070028
Elliott Hughes4c62e592023-07-13 15:45:33 -070029#pragma once
30
31/**
32 * @file sys/epoll.h
33 * @brief I/O event file descriptors.
34 */
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080035
David 'Digit' Turner49f0a8f2010-02-09 14:05:43 -080036#include <sys/cdefs.h>
Elliott Hughes93de3d82013-10-23 11:25:54 -070037#include <sys/types.h>
Elliott Hughes11952072013-10-24 15:15:14 -070038#include <signal.h> /* For sigset_t. */
David 'Digit' Turner49f0a8f2010-02-09 14:05:43 -080039
Elliott Hughes893fd972017-02-22 23:22:51 -080040#include <linux/eventpoll.h>
Elliott Hughes893fd972017-02-22 23:22:51 -080041
David 'Digit' Turner49f0a8f2010-02-09 14:05:43 -080042__BEGIN_DECLS
43
Elliott Hughes4c62e592023-07-13 15:45:33 -070044/**
45 * [epoll_create(2)](http://man7.org/linux/man-pages/man2/epoll_create.2.html)
46 * creates a new [epoll](http://man7.org/linux/man-pages/man7/epoll.7.html)
47 * file descriptor.
48 *
49 * Returns a new file descriptor on success and returns -1 and sets `errno` on
50 * failure.
51 */
Elliott Hughesff26a162017-08-17 22:34:21 +000052int epoll_create(int __size);
Elliott Hughes4c62e592023-07-13 15:45:33 -070053
54/**
55 * [epoll_create1(2)](http://man7.org/linux/man-pages/man2/epoll_create1.2.html)
56 * creates a new [epoll](http://man7.org/linux/man-pages/man7/epoll.7.html)
57 * file descriptor with the given flags.
58 *
59 * Returns a new file descriptor on success and returns -1 and sets `errno` on
60 * failure.
61 */
Elliott Hughes655e4302023-06-16 12:39:33 -070062int epoll_create1(int __flags);
Dan Albertcdfface2017-05-22 12:52:00 -070063
Elliott Hughes4c62e592023-07-13 15:45:33 -070064/**
65 * [epoll_ctl(2)](http://man7.org/linux/man-pages/man2/epoll_ctl.2.html)
66 * adds/modifies/removes file descriptors from the given epoll file descriptor.
67 *
68 * Returns 0 on success and returns -1 and sets `errno` on failure.
69 */
zijunzhaod555a332023-02-14 02:27:20 +000070int epoll_ctl(int __epoll_fd, int __op, int __fd, struct epoll_event* __BIONIC_COMPLICATED_NULLNESS __event);
Elliott Hughes4c62e592023-07-13 15:45:33 -070071
72/**
73 * [epoll_wait(2)](http://man7.org/linux/man-pages/man2/epoll_wait.2.html)
74 * waits for an event on the given epoll file descriptor.
75 *
76 * Returns the number of ready file descriptors on success, 0 on timeout,
77 * or -1 and sets `errno` on failure.
78 */
zijunzhaod555a332023-02-14 02:27:20 +000079int epoll_wait(int __epoll_fd, struct epoll_event* _Nonnull __events, int __event_count, int __timeout_ms);
Elliott Hughes4c62e592023-07-13 15:45:33 -070080
81/**
82 * Like epoll_wait() but atomically applying the given signal mask.
83 */
Elliott Hughes655e4302023-06-16 12:39:33 -070084int epoll_pwait(int __epoll_fd, struct epoll_event* _Nonnull __events, int __event_count, int __timeout_ms, const sigset_t* _Nullable __mask);
Elliott Hughes4c62e592023-07-13 15:45:33 -070085
86/**
87 * Like epoll_pwait() but using a 64-bit signal mask even on 32-bit systems.
88 *
89 * Available since API level 28.
90 */
zijunzhaod555a332023-02-14 02:27:20 +000091int epoll_pwait64(int __epoll_fd, struct epoll_event* _Nonnull __events, int __event_count, int __timeout_ms, const sigset64_t* _Nullable __mask) __INTRODUCED_IN(28);
The Android Open Source Project1dc9e472009-03-03 19:28:35 -080092
Elliott Hughes4c62e592023-07-13 15:45:33 -070093/**
94 * Like epoll_pwait() but with a `struct timespec` timeout, for nanosecond resolution.
95 *
96 * Available since API level 35.
97 */
98int epoll_pwait2(int __epoll_fd, struct epoll_event* _Nonnull __events, int __event_count, const struct timespec* _Nullable __timeout, const sigset_t* _Nullable __mask) __INTRODUCED_IN(35);
David 'Digit' Turner49f0a8f2010-02-09 14:05:43 -080099
Elliott Hughes4c62e592023-07-13 15:45:33 -0700100/**
101 * Like epoll_pwait2() but using a 64-bit signal mask even on 32-bit systems.
102 *
103 * Available since API level 35.
104 */
105int epoll_pwait2_64(int __epoll_fd, struct epoll_event* _Nonnull __events, int __event_count, const struct timespec* _Nullable __timeout, const sigset64_t* _Nullable __mask) __INTRODUCED_IN(35);
106
107__END_DECLS