]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/systemd/sd-event.h
sd-event: add relative timer calls
[thirdparty/systemd.git] / src / systemd / sd-event.h
CommitLineData
53e1b683 1/* SPDX-License-Identifier: LGPL-2.1+ */
fd38203a
LP
2#ifndef foosdeventhfoo
3#define foosdeventhfoo
4
5/***
fd38203a
LP
6 systemd is free software; you can redistribute it and/or modify it
7 under the terms of the GNU Lesser General Public License as published by
8 the Free Software Foundation; either version 2.1 of the License, or
9 (at your option) any later version.
10
11 systemd is distributed in the hope that it will be useful, but
12 WITHOUT ANY WARRANTY; without even the implied warranty of
13 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
14 Lesser General Public License for more details.
15
16 You should have received a copy of the GNU Lesser General Public License
17 along with systemd; If not, see <http://www.gnu.org/licenses/>.
18***/
19
fd38203a
LP
20#include <inttypes.h>
21#include <signal.h>
71d35b6b 22#include <sys/epoll.h>
97ef5391 23#include <sys/inotify.h>
71d35b6b
TA
24#include <sys/signalfd.h>
25#include <sys/types.h>
f8f3f926 26#include <sys/wait.h>
2b97a957 27#include <time.h>
fd38203a 28
0095c454
LP
29#include "_sd-common.h"
30
fd38203a
LP
31/*
32 Why is this better than pure epoll?
33
10b17992
JSJ
34 - Supports event source prioritization
35 - Scales better with a large number of time events because it does not require one timerfd each
eaa3cbef 36 - Automatically tries to coalesce timer events system-wide
bde0848d
LP
37 - Handles signals, child PIDs, inotify events
38 - Supports systemd-style automatic watchdog event generation
fd38203a
LP
39*/
40
0095c454 41_SD_BEGIN_DECLARATIONS;
6695ed7a 42
b937d761
NM
43#define SD_EVENT_DEFAULT ((sd_event *) 1)
44
fd38203a
LP
45typedef struct sd_event sd_event;
46typedef struct sd_event_source sd_event_source;
47
da7e457c 48enum {
baf76283
LP
49 SD_EVENT_OFF = 0,
50 SD_EVENT_ON = 1,
fd38203a 51 SD_EVENT_ONESHOT = -1
da7e457c
LP
52};
53
54enum {
2b0c9ef7
TG
55 SD_EVENT_INITIAL,
56 SD_EVENT_ARMED,
c45a5a74 57 SD_EVENT_PENDING,
da7e457c 58 SD_EVENT_RUNNING,
6203e07a 59 SD_EVENT_EXITING,
0be6c2f6 60 SD_EVENT_FINISHED,
e0c0b07d 61 SD_EVENT_PREPARING
da7e457c 62};
fd38203a 63
6ee69bab 64enum {
10b17992 65 /* And everything in-between and outside is good too */
718db961
LP
66 SD_EVENT_PRIORITY_IMPORTANT = -100,
67 SD_EVENT_PRIORITY_NORMAL = 0,
68 SD_EVENT_PRIORITY_IDLE = 100
6ee69bab
LP
69};
70
718db961
LP
71typedef int (*sd_event_handler_t)(sd_event_source *s, void *userdata);
72typedef int (*sd_event_io_handler_t)(sd_event_source *s, int fd, uint32_t revents, void *userdata);
73typedef int (*sd_event_time_handler_t)(sd_event_source *s, uint64_t usec, void *userdata);
74typedef int (*sd_event_signal_handler_t)(sd_event_source *s, const struct signalfd_siginfo *si, void *userdata);
772afb76 75#if defined _GNU_SOURCE || (defined _POSIX_C_SOURCE && _POSIX_C_SOURCE >= 199309L)
718db961 76typedef int (*sd_event_child_handler_t)(sd_event_source *s, const siginfo_t *si, void *userdata);
b2542bf9
ZJS
77#else
78typedef void* sd_event_child_handler_t;
79#endif
97ef5391 80typedef int (*sd_event_inotify_handler_t)(sd_event_source *s, const struct inotify_event *event, void *userdata);
deae09cc 81typedef _sd_destroy_t sd_event_destroy_t;
fd38203a 82
afc6adb5
LP
83int sd_event_default(sd_event **e);
84
fd38203a
LP
85int sd_event_new(sd_event **e);
86sd_event* sd_event_ref(sd_event *e);
87sd_event* sd_event_unref(sd_event *e);
88
151b9b96 89int sd_event_add_io(sd_event *e, sd_event_source **s, int fd, uint32_t events, sd_event_io_handler_t callback, void *userdata);
6a0f1f6d 90int sd_event_add_time(sd_event *e, sd_event_source **s, clockid_t clock, uint64_t usec, uint64_t accuracy, sd_event_time_handler_t callback, void *userdata);
d6a83dc4 91int sd_event_add_time_relative(sd_event *e, sd_event_source **s, clockid_t clock, uint64_t usec, uint64_t accuracy, sd_event_time_handler_t callback, void *userdata);
151b9b96
LP
92int sd_event_add_signal(sd_event *e, sd_event_source **s, int sig, sd_event_signal_handler_t callback, void *userdata);
93int sd_event_add_child(sd_event *e, sd_event_source **s, pid_t pid, int options, sd_event_child_handler_t callback, void *userdata);
f8f3f926 94int sd_event_add_child_pidfd(sd_event *e, sd_event_source **s, int pidfd, int options, sd_event_child_handler_t callback, void *userdata);
97ef5391 95int sd_event_add_inotify(sd_event *e, sd_event_source **s, const char *path, uint32_t mask, sd_event_inotify_handler_t callback, void *userdata);
151b9b96 96int sd_event_add_defer(sd_event *e, sd_event_source **s, sd_event_handler_t callback, void *userdata);
6e9feda3 97int sd_event_add_post(sd_event *e, sd_event_source **s, sd_event_handler_t callback, void *userdata);
151b9b96 98int sd_event_add_exit(sd_event *e, sd_event_source **s, sd_event_handler_t callback, void *userdata);
fd38203a 99
c45a5a74 100int sd_event_prepare(sd_event *e);
0be6c2f6 101int sd_event_wait(sd_event *e, uint64_t usec);
c45a5a74 102int sd_event_dispatch(sd_event *e);
0be6c2f6 103int sd_event_run(sd_event *e, uint64_t usec);
fd38203a 104int sd_event_loop(sd_event *e);
6203e07a 105int sd_event_exit(sd_event *e, int code);
fd38203a 106
6a0f1f6d
LP
107int sd_event_now(sd_event *e, clockid_t clock, uint64_t *usec);
108
9b364545 109int sd_event_get_fd(sd_event *e);
da7e457c 110int sd_event_get_state(sd_event *e);
afc6adb5 111int sd_event_get_tid(sd_event *e, pid_t *tid);
6203e07a 112int sd_event_get_exit_code(sd_event *e, int *code);
cde93897 113int sd_event_set_watchdog(sd_event *e, int b);
8f726607 114int sd_event_get_watchdog(sd_event *e);
60a3b1e1 115int sd_event_get_iteration(sd_event *e, uint64_t *ret);
fd38203a
LP
116
117sd_event_source* sd_event_source_ref(sd_event_source *s);
118sd_event_source* sd_event_source_unref(sd_event_source *s);
afd15bbb 119sd_event_source* sd_event_source_disable_unref(sd_event_source *s);
fd38203a 120
9a78148e
LP
121sd_event *sd_event_source_get_event(sd_event_source *s);
122void* sd_event_source_get_userdata(sd_event_source *s);
123void* sd_event_source_set_userdata(sd_event_source *s, void *userdata);
124
356779df
LP
125int sd_event_source_set_description(sd_event_source *s, const char *description);
126int sd_event_source_get_description(sd_event_source *s, const char **description);
718db961 127int sd_event_source_set_prepare(sd_event_source *s, sd_event_handler_t callback);
fd38203a 128int sd_event_source_get_pending(sd_event_source *s);
31927c16
LP
129int sd_event_source_get_priority(sd_event_source *s, int64_t *priority);
130int sd_event_source_set_priority(sd_event_source *s, int64_t priority);
baf76283
LP
131int sd_event_source_get_enabled(sd_event_source *s, int *enabled);
132int sd_event_source_set_enabled(sd_event_source *s, int enabled);
305f78bf 133int sd_event_source_get_io_fd(sd_event_source *s);
30caf8f3 134int sd_event_source_set_io_fd(sd_event_source *s, int fd);
ab93297c
NM
135int sd_event_source_get_io_fd_own(sd_event_source *s);
136int sd_event_source_set_io_fd_own(sd_event_source *s, int own);
305f78bf
LP
137int sd_event_source_get_io_events(sd_event_source *s, uint32_t* events);
138int sd_event_source_set_io_events(sd_event_source *s, uint32_t events);
139int sd_event_source_get_io_revents(sd_event_source *s, uint32_t* revents);
fd38203a
LP
140int sd_event_source_get_time(sd_event_source *s, uint64_t *usec);
141int sd_event_source_set_time(sd_event_source *s, uint64_t usec);
d6a83dc4 142int sd_event_source_set_time_relative(sd_event_source *s, uint64_t usec);
c2ba3ad6 143int sd_event_source_get_time_accuracy(sd_event_source *s, uint64_t *usec);
b408026b 144int sd_event_source_set_time_accuracy(sd_event_source *s, uint64_t usec);
6a0f1f6d 145int sd_event_source_get_time_clock(sd_event_source *s, clockid_t *clock);
305f78bf 146int sd_event_source_get_signal(sd_event_source *s);
4bee8012 147int sd_event_source_get_child_pid(sd_event_source *s, pid_t *pid);
f8f3f926
LP
148int sd_event_source_get_child_pidfd(sd_event_source *s);
149int sd_event_source_get_child_pidfd_own(sd_event_source *s);
150int sd_event_source_set_child_pidfd_own(sd_event_source *s, int own);
151int sd_event_source_get_child_process_own(sd_event_source *s);
152int sd_event_source_set_child_process_own(sd_event_source *s, int own);
153#if defined _GNU_SOURCE || (defined _POSIX_C_SOURCE && _POSIX_C_SOURCE >= 199309L)
154int sd_event_source_send_child_signal(sd_event_source *s, int sig, const siginfo_t *si, unsigned flags);
155#else
156int sd_event_source_send_child_signal(sd_event_source *s, int sig, const void *si, unsigned flags);
157#endif
97ef5391 158int sd_event_source_get_inotify_mask(sd_event_source *s, uint32_t *ret);
15723a1d
LP
159int sd_event_source_set_destroy_callback(sd_event_source *s, sd_event_destroy_t callback);
160int sd_event_source_get_destroy_callback(sd_event_source *s, sd_event_destroy_t *ret);
2382c936
YW
161int sd_event_source_get_floating(sd_event_source *s);
162int sd_event_source_set_floating(sd_event_source *s, int b);
fd38203a 163
4afd3348
LP
164/* Define helpers so that __attribute__((cleanup(sd_event_unrefp))) and similar may be used. */
165_SD_DEFINE_POINTER_CLEANUP_FUNC(sd_event, sd_event_unref);
166_SD_DEFINE_POINTER_CLEANUP_FUNC(sd_event_source, sd_event_source_unref);
aa7585fd 167_SD_DEFINE_POINTER_CLEANUP_FUNC(sd_event_source, sd_event_source_disable_unref);
4afd3348 168
0095c454 169_SD_END_DECLARATIONS;
6695ed7a 170
fd38203a 171#endif