ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/libev/ev_vars.h
(Generate patch)

Comparing libev/ev_vars.h (file contents):
Revision 1.19 by root, Wed Dec 12 00:17:08 2007 UTC vs.
Revision 1.67 by root, Fri Dec 27 16:08:24 2019 UTC

1/*
2 * loop member variable declarations
3 *
4 * Copyright (c) 2007,2008,2009,2010,2011,2012,2013,2019 Marc Alexander Lehmann <libev@schmorp.de>
5 * All rights reserved.
6 *
7 * Redistribution and use in source and binary forms, with or without modifica-
8 * tion, are permitted provided that the following conditions are met:
9 *
10 * 1. Redistributions of source code must retain the above copyright notice,
11 * this list of conditions and the following disclaimer.
12 *
13 * 2. Redistributions in binary form must reproduce the above copyright
14 * notice, this list of conditions and the following disclaimer in the
15 * documentation and/or other materials provided with the distribution.
16 *
17 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR IMPLIED
18 * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MER-
19 * CHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO
20 * EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPE-
21 * CIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
22 * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
23 * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
24 * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTH-
25 * ERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
26 * OF THE POSSIBILITY OF SUCH DAMAGE.
27 *
28 * Alternatively, the contents of this file may be used under the terms of
29 * the GNU General Public License ("GPL") version 2 or any later version,
30 * in which case the provisions of the GPL are applicable instead of
31 * the above. If you wish to allow the use of your version of this file
32 * only under the terms of the GPL and not to allow others to use your
33 * version of this file under the BSD license, indicate your decision
34 * by deleting the provisions above and replace them with the notice
35 * and other provisions required by the GPL. If you do not delete the
36 * provisions above, a recipient may use your version of this file under
37 * either the BSD or the GPL.
38 */
39
1#define VARx(type,name) VAR(name, type name) 40#define VARx(type,name) VAR(name, type name)
2 41
3VARx(ev_tstamp, now_floor) /* last time we refreshed rt_time */ 42VARx(ev_tstamp, now_floor) /* last time we refreshed rt_time */
4VARx(ev_tstamp, mn_now) /* monotonic clock "now" */ 43VARx(ev_tstamp, mn_now) /* monotonic clock "now" */
5VARx(ev_tstamp, rtmn_diff) /* difference realtime - monotonic time */ 44VARx(ev_tstamp, rtmn_diff) /* difference realtime - monotonic time */
45
46/* for reverse feeding of events */
47VARx(W *, rfeeds)
48VARx(int, rfeedmax)
49VARx(int, rfeedcnt)
50
51VAR (pendings, ANPENDING *pendings [NUMPRI])
52VAR (pendingmax, int pendingmax [NUMPRI])
53VAR (pendingcnt, int pendingcnt [NUMPRI])
54VARx(int, pendingpri) /* highest priority currently pending */
55VARx(ev_prepare, pending_w) /* dummy pending watcher */
56
57VARx(ev_tstamp, io_blocktime)
58VARx(ev_tstamp, timeout_blocktime)
59
6VARx(int, backend) 60VARx(int, backend)
7VARx(int, activecnt) /* total number of active events ("refcount") */ 61VARx(int, activecnt) /* total number of active events ("refcount") */
8VARx(unsigned int, loop_count); /* total number of loop iterations/blocks */ 62VARx(EV_ATOMIC_T, loop_done) /* signal by ev_break */
9 63
64VARx(int, backend_fd)
10VARx(ev_tstamp, backend_fudge) /* assumed typical timer resolution */ 65VARx(ev_tstamp, backend_mintime) /* assumed typical timer resolution */
11VAR (backend_modify, void (*backend_modify)(EV_P_ int fd, int oev, int nev)) 66VAR (backend_modify, void (*backend_modify)(EV_P_ int fd, int oev, int nev))
12VAR (backend_poll , void (*backend_poll)(EV_P_ ev_tstamp timeout)) 67VAR (backend_poll , void (*backend_poll)(EV_P_ ev_tstamp timeout))
68
69VARx(ANFD *, anfds)
13VARx(int, backend_fd) 70VARx(int, anfdmax)
71
72VAR (evpipe, int evpipe [2])
73VARx(ev_io, pipe_w)
74VARx(EV_ATOMIC_T, pipe_write_wanted)
75VARx(EV_ATOMIC_T, pipe_write_skipped)
14 76
15#if !defined(_WIN32) || EV_GENWRAP 77#if !defined(_WIN32) || EV_GENWRAP
16VARx(pid_t, curpid) 78VARx(pid_t, curpid)
17#endif 79#endif
18 80
19VARx(int, postfork) /* true if we need to recreate kernel state after fork */ 81VARx(char, postfork) /* true if we need to recreate kernel state after fork */
20 82
21#if EV_USE_SELECT || EV_GENWRAP 83#if EV_USE_SELECT || EV_GENWRAP
22VARx(void *, vec_ri) 84VARx(void *, vec_ri)
23VARx(void *, vec_ro) 85VARx(void *, vec_ro)
24VARx(void *, vec_wi) 86VARx(void *, vec_wi)
25VARx(void *, vec_wo) 87VARx(void *, vec_wo)
88#if defined(_WIN32) || EV_GENWRAP
89VARx(void *, vec_eo)
90#endif
26VARx(int, vec_max) 91VARx(int, vec_max)
27#endif 92#endif
28 93
29#if EV_USE_POLL || EV_GENWRAP 94#if EV_USE_POLL || EV_GENWRAP
30VARx(struct pollfd *, polls) 95VARx(struct pollfd *, polls)
35#endif 100#endif
36 101
37#if EV_USE_EPOLL || EV_GENWRAP 102#if EV_USE_EPOLL || EV_GENWRAP
38VARx(struct epoll_event *, epoll_events) 103VARx(struct epoll_event *, epoll_events)
39VARx(int, epoll_eventmax) 104VARx(int, epoll_eventmax)
105VARx(int *, epoll_eperms)
106VARx(int, epoll_epermcnt)
107VARx(int, epoll_epermmax)
108#endif
109
110#if EV_USE_LINUXAIO || EV_GENWRAP
111VARx(aio_context_t, linuxaio_ctx)
112VARx(int, linuxaio_iteration)
113VARx(struct aniocb **, linuxaio_iocbps)
114VARx(int, linuxaio_iocbpmax)
115VARx(struct iocb **, linuxaio_submits)
116VARx(int, linuxaio_submitcnt)
117VARx(int, linuxaio_submitmax)
118VARx(ev_io, linuxaio_epoll_w)
119#endif
120
121#if EV_USE_IOURING || EV_GENWRAP
122VARx(int, iouring_fd)
123VARx(unsigned, iouring_to_submit);
124VARx(int, iouring_entries)
125VARx(int, iouring_max_entries)
126VARx(void *, iouring_sq_ring)
127VARx(void *, iouring_cq_ring)
128VARx(void *, iouring_sqes)
129VARx(uint32_t, iouring_sq_ring_size)
130VARx(uint32_t, iouring_cq_ring_size)
131VARx(uint32_t, iouring_sqes_size)
132VARx(uint32_t, iouring_sq_head)
133VARx(uint32_t, iouring_sq_tail)
134VARx(uint32_t, iouring_sq_ring_mask)
135VARx(uint32_t, iouring_sq_ring_entries)
136VARx(uint32_t, iouring_sq_flags)
137VARx(uint32_t, iouring_sq_dropped)
138VARx(uint32_t, iouring_sq_array)
139VARx(uint32_t, iouring_cq_head)
140VARx(uint32_t, iouring_cq_tail)
141VARx(uint32_t, iouring_cq_ring_mask)
142VARx(uint32_t, iouring_cq_ring_entries)
143VARx(uint32_t, iouring_cq_overflow)
144VARx(uint32_t, iouring_cq_cqes)
145VARx(ev_tstamp, iouring_tfd_to)
146VARx(int, iouring_tfd)
147VARx(ev_io, iouring_tfd_w)
40#endif 148#endif
41 149
42#if EV_USE_KQUEUE || EV_GENWRAP 150#if EV_USE_KQUEUE || EV_GENWRAP
151VARx(pid_t, kqueue_fd_pid)
43VARx(struct kevent *, kqueue_changes) 152VARx(struct kevent *, kqueue_changes)
44VARx(int, kqueue_changemax) 153VARx(int, kqueue_changemax)
45VARx(int, kqueue_changecnt) 154VARx(int, kqueue_changecnt)
46VARx(struct kevent *, kqueue_events) 155VARx(struct kevent *, kqueue_events)
47VARx(int, kqueue_eventmax) 156VARx(int, kqueue_eventmax)
50#if EV_USE_PORT || EV_GENWRAP 159#if EV_USE_PORT || EV_GENWRAP
51VARx(struct port_event *, port_events) 160VARx(struct port_event *, port_events)
52VARx(int, port_eventmax) 161VARx(int, port_eventmax)
53#endif 162#endif
54 163
55VARx(ANFD *, anfds) 164#if EV_USE_IOCP || EV_GENWRAP
56VARx(int, anfdmax) 165VARx(HANDLE, iocp)
57 166#endif
58VAR (pendings, ANPENDING *pendings [NUMPRI])
59VAR (pendingmax, int pendingmax [NUMPRI])
60VAR (pendingcnt, int pendingcnt [NUMPRI])
61 167
62VARx(int *, fdchanges) 168VARx(int *, fdchanges)
63VARx(int, fdchangemax) 169VARx(int, fdchangemax)
64VARx(int, fdchangecnt) 170VARx(int, fdchangecnt)
65 171
66VARx(WT *, timers) 172VARx(ANHE *, timers)
67VARx(int, timermax) 173VARx(int, timermax)
68VARx(int, timercnt) 174VARx(int, timercnt)
69 175
70#if EV_PERIODIC_ENABLE || EV_GENWRAP 176#if EV_PERIODIC_ENABLE || EV_GENWRAP
71VARx(WT *, periodics) 177VARx(ANHE *, periodics)
72VARx(int, periodicmax) 178VARx(int, periodicmax)
73VARx(int, periodiccnt) 179VARx(int, periodiccnt)
74#endif 180#endif
75 181
76#if EV_IDLE_ENABLE || EV_GENWRAP 182#if EV_IDLE_ENABLE || EV_GENWRAP
92VARx(struct ev_fork **, forks) 198VARx(struct ev_fork **, forks)
93VARx(int, forkmax) 199VARx(int, forkmax)
94VARx(int, forkcnt) 200VARx(int, forkcnt)
95#endif 201#endif
96 202
203#if EV_CLEANUP_ENABLE || EV_GENWRAP
204VARx(struct ev_cleanup **, cleanups)
205VARx(int, cleanupmax)
206VARx(int, cleanupcnt)
207#endif
208
209#if EV_ASYNC_ENABLE || EV_GENWRAP
210VARx(EV_ATOMIC_T, async_pending)
211VARx(struct ev_async **, asyncs)
212VARx(int, asyncmax)
213VARx(int, asynccnt)
214#endif
215
97#if EV_USE_INOTIFY || EV_GENWRAP 216#if EV_USE_INOTIFY || EV_GENWRAP
98VARx(int, fs_fd) 217VARx(int, fs_fd)
99VARx(ev_io, fs_w) 218VARx(ev_io, fs_w)
219VARx(char, fs_2625) /* whether we are running in linux 2.6.25 or newer */
100VAR (fs_hash, ANFS fs_hash [EV_INOTIFY_HASHSIZE]) 220VAR (fs_hash, ANFS fs_hash [EV_INOTIFY_HASHSIZE])
101#endif 221#endif
102 222
223VARx(EV_ATOMIC_T, sig_pending)
224#if EV_USE_SIGNALFD || EV_GENWRAP
225VARx(int, sigfd)
226VARx(ev_io, sigfd_w)
227VARx(sigset_t, sigfd_set)
228#endif
229
230#if EV_USE_TIMERFD || EV_GENWRAP
231VARx(int, timerfd) /* timerfd for time jump detection */
232VARx(ev_io, timerfd_w)
233#endif
234
235VARx(unsigned int, origflags) /* original loop flags */
236
237#if EV_FEATURE_API || EV_GENWRAP
238VARx(unsigned int, loop_count) /* total number of loop iterations/blocks */
239VARx(unsigned int, loop_depth) /* #ev_run enters - #ev_run leaves */
240
241VARx(void *, userdata)
242/* C++ doesn't support the ev_loop_callback typedef here. stinks. */
243VAR (release_cb, void (*release_cb)(EV_P) EV_NOEXCEPT)
244VAR (acquire_cb, void (*acquire_cb)(EV_P) EV_NOEXCEPT)
245VAR (invoke_cb , ev_loop_callback invoke_cb)
246#endif
247
103#undef VARx 248#undef VARx
104 249

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines