1 | Revision history for libev, a high-performance and full-featured event loop |
1 | Revision history for libev, a high-performance and full-featured event loop. |
2 | |
2 | |
|
|
3 | TODO: ABI??? API????? Changes??? |
|
|
4 | TODO: win32 write() to socket for signal handling |
|
|
5 | TODO: poll asert |
|
|
6 | TODO: EV_USE__XXX default with config, document |
|
|
7 | - "PORTING FROM LIBEV 3.X TO 4.X" (in ev.pod) is recommended reading. |
|
|
8 | - ev_embed_stop did not correctly stop the watcher (very good |
|
|
9 | testcase by Vladimir Timofeev). |
|
|
10 | - applied win32 fixes by Michael Lenaghan (also James Mansion). |
|
|
11 | - replace EV_MINIMAL by EV_FEATURES. |
|
|
12 | - remove dependency on sys/queue.h on freebsd (patch by Vanilla Hsu). |
|
|
13 | - add (undocumented) EV_ENABLE when adding events with kqueue, |
|
|
14 | this might help with OS X, which seems to need it despite documenting |
|
|
15 | not to need it (helpfully pointed out by Tilghman Lesher). |
|
|
16 | - do not use poll by default on freebsd, it's broken (what isn't |
|
|
17 | on freebsd...). |
|
|
18 | - configure now prepends -O3, not appends it, so one can still |
|
|
19 | override it. |
|
|
20 | - disable poll backend on AIX, the poll header spams the namespace |
|
|
21 | and it's not worth working around dead platforms (reported |
|
|
22 | and analyzed by Aivars Kalvans). |
|
|
23 | - improve header file compatibility of the standalone eventfd code |
|
|
24 | in an obscure case. |
|
|
25 | - implement EV_AVOID_STDIO option. |
|
|
26 | - do not use sscanf to parse linux version number (smaller, faster, |
|
|
27 | no sscanf dependency). |
|
|
28 | - new EV_CHILD_ENABLE and EV_SIGNAL_ENABLE configurable settings. |
|
|
29 | - update libev.m4 HAVE_CLOCK_SYSCALL test for newer glibcs. |
|
|
30 | - add section on accept() problems to the manpage. |
|
|
31 | - rename EV_TIMEOUT to EV_TIMER. |
|
|
32 | - rename ev_loop_count/depth/verify. |
|
|
33 | - switch to two-digit minor version. |
|
|
34 | |
|
|
35 | 3.9 Thu Dec 31 07:59:59 CET 2009 |
|
|
36 | - signalfd is no longer used by default and has to be requested |
|
|
37 | explicitly - this means that easy to catch bugs become hard to |
|
|
38 | catch race conditions, but the users have spoken. |
|
|
39 | - point out the unspecified signal mask in the documentation, and |
|
|
40 | that this is a race condition regardless of EV_SIGNALFD. |
|
|
41 | - backport inotify code to C89. |
|
|
42 | - inotify file descriptors could leak into child processes. |
|
|
43 | - ev_stat watchers could keep an errornous extra ref on the loop, |
|
|
44 | preventing exit when unregistering all watchers (testcases |
|
|
45 | provided by ry@tinyclouds.org). |
|
|
46 | - implement EV_WIN32_HANDLE_TO_FD and EV_WIN32_CLOSE_FD configuration |
|
|
47 | symbols to make it easier for apps to do their own fd management. |
|
|
48 | - support EV_IDLE_ENABLE being disabled in ev++.h |
|
|
49 | (patch by Didier Spezia). |
|
|
50 | - take advantage of inotify_init1, if available, to set cloexec/nonblock |
|
|
51 | on fd creation, to avoid races. |
|
|
52 | - the signal handling pipe wasn't always initialised under windows |
|
|
53 | (analysed by lekma). |
|
|
54 | - changed minimum glibc requirement from glibc 2.9 to 2.7, for |
|
|
55 | signalfd. |
|
|
56 | - add missing string.h include (Denis F. Latypoff). |
|
|
57 | - only replace ev_stat.prev when we detect an actual difference, |
|
|
58 | so prev is (almost) always different to attr. this might |
|
|
59 | have caused the probems with 04_stat.t. |
|
|
60 | - add ev::timer->remaining () method to C++ API. |
|
|
61 | |
|
|
62 | 3.8 Sun Aug 9 14:30:45 CEST 2009 |
|
|
63 | - incompatible change: do not necessarily reset signal handler |
|
|
64 | to SIG_DFL when a sighandler is stopped. |
|
|
65 | - ev_default_destroy did not properly free or zero some members, |
|
|
66 | potentially causing crashes and memory corruption on repated |
|
|
67 | ev_default_destroy/ev_default_loop calls. |
|
|
68 | - take advantage of signalfd on GNU/Linux systems. |
|
|
69 | - document that the signal mask might be in an unspecified |
|
|
70 | state when using libev's signal handling. |
|
|
71 | - take advantage of some GNU/Linux calls to set cloexec/nonblock |
|
|
72 | on fd creation, to avoid race conditions. |
|
|
73 | |
|
|
74 | 3.7 Fri Jul 17 16:36:32 CEST 2009 |
|
|
75 | - ev_unloop and ev_loop wrongly used a global variable to exit loops, |
|
|
76 | instead of using a per-loop variable (bug caught by accident...). |
|
|
77 | - the ev_set_io_collect_interval interpretation has changed. |
|
|
78 | - add new functionality: ev_set_userdata, ev_userdata, |
|
|
79 | ev_set_invoke_pending_cb, ev_set_loop_release_cb, |
|
|
80 | ev_invoke_pending, ev_pending_count, together with a long example |
|
|
81 | about thread locking. |
|
|
82 | - add ev_timer_remaining (as requested by Denis F. Latypoff). |
|
|
83 | - add ev_loop_depth. |
|
|
84 | - calling ev_unloop in fork/prepare watchers will no longer poll |
|
|
85 | for new events. |
|
|
86 | - Denis F. Latypoff corrected many typos in example code snippets. |
|
|
87 | - honor autoconf detection of EV_USE_CLOCK_SYSCALL, also double- |
|
|
88 | check that the syscall number is available before trying to |
|
|
89 | use it (reported by ry@tinyclouds). |
|
|
90 | - use GetSystemTimeAsFileTime instead of _timeb on windows, for |
|
|
91 | slightly higher accuracy. |
|
|
92 | - properly declare ev_loop_verify and ev_now_update even when |
|
|
93 | !EV_MULTIPLICITY. |
|
|
94 | - do not compile in any priority code when EV_MAXPRI == EV_MINPRI. |
|
|
95 | - support EV_MINIMAL==2 for a reduced API. |
|
|
96 | - actually 0-initialise struct sigaction when installing signals. |
|
|
97 | - add section on hibernate and stopped processes to ev_timer docs. |
|
|
98 | |
|
|
99 | 3.6 Tue Apr 28 02:49:30 CEST 2009 |
|
|
100 | - multiple timers becoming ready within an event loop iteration |
|
|
101 | will be invoked in the "correct" order now. |
|
|
102 | - do not leave the event loop early just because we have no active |
|
|
103 | watchers, fixing a problem when embedding a kqueue loop |
|
|
104 | that has active kernel events but no registered watchers |
|
|
105 | (reported by blacksand blacksand). |
|
|
106 | - correctly zero the idx values for arrays, so destroying and |
|
|
107 | reinitialising the default loop actually works (patch by |
|
|
108 | Malek Hadj-Ali). |
|
|
109 | - implement ev_suspend and ev_resume. |
|
|
110 | - new EV_CUSTOM revents flag for use by applications. |
|
|
111 | - add documentation section about priorites. |
|
|
112 | - add a glossary to the dcoumentation. |
|
|
113 | - extend the ev_fork description slightly. |
|
|
114 | - optimize a jump out of call_pending. |
|
|
115 | |
|
|
116 | 3.53 Sun Feb 15 02:38:20 CET 2009 |
|
|
117 | - fix a bug in event pipe creation on win32 that would cause a |
|
|
118 | failed assertion on event loop creation (patch by Malek Hadj-Ali). |
|
|
119 | - probe for CLOCK_REALTIME support at runtime as well and fall |
|
|
120 | back to gettimeofday if there is an error, to support older |
|
|
121 | operating systems with newer header files/libraries. |
|
|
122 | - prefer gettimeofday over clock_gettime with USE_CLOCK_SYSCALL |
|
|
123 | (default most everywhere), otherwise not. |
|
|
124 | |
|
|
125 | 3.52 Wed Jan 7 21:43:02 CET 2009 |
|
|
126 | - fix compilation of select backend in fd_set mode when NFDBITS is |
|
|
127 | missing (to get it to compile on QNX, reported by Rodrigo Campos). |
|
|
128 | - better select-nfds handling when select backend is in fd_set mode. |
|
|
129 | - diagnose fd_set overruns when select backend is in fd_set mode. |
|
|
130 | - due to a thinko, instead of disabling everything but |
|
|
131 | select on the borked OS X platform, everything but select was |
|
|
132 | allowed (reported by Emanuele Giaquinta). |
|
|
133 | - actually verify that local and remote port are matching in |
|
|
134 | libev's socketpair emulation, which makes denial-of-service |
|
|
135 | attacks harder (but not impossible - it's windows). Make sure |
|
|
136 | it even works under vista, which thinks that getpeer/sockname |
|
|
137 | should return fantasy port numbers. |
|
|
138 | - include "libev" in all assertion messages for potentially |
|
|
139 | clearer diagnostics. |
|
|
140 | - event_get_version (libevent compatibility) returned |
|
|
141 | a useless string instead of the expected version string |
|
|
142 | (patch by W.C.A. Wijngaards). |
|
|
143 | |
|
|
144 | 3.51 Wed Dec 24 23:00:11 CET 2008 |
|
|
145 | - fix a bug where an inotify watcher was added twice, causing |
|
|
146 | freezes on hash collisions (reported and analysed by Graham Leggett). |
|
|
147 | - new config symbol, EV_USE_CLOCK_SYSCALL, to make libev use |
|
|
148 | a direct syscall - slower, but no dependency on librt et al. |
|
|
149 | - assume negative return values != -1 signals success of port_getn |
|
|
150 | (http://cvs.epicsol.org/cgi/viewcvs.cgi/epic5/source/newio.c?rev=1.52) |
|
|
151 | (no known failure reports, but it doesn't hurt). |
|
|
152 | - fork detection in ev_embed now stops and restarts the watcher |
|
|
153 | automatically. |
|
|
154 | - EXPERIMENTAL: default the method to operator () in ev++.h, |
|
|
155 | to make it nicer to use functors (requested by Benedek László). |
|
|
156 | - fixed const object callbacks in ev++.h. |
|
|
157 | - replaced loop_ref argument of watcher.set (loop) by a direct |
|
|
158 | ev_loop * in ev++.h, to avoid clashes with functor patch. |
|
|
159 | - do not try to watch the empty string via inotify. |
|
|
160 | - inotify watchers could be leaked under certain circumstances. |
|
|
161 | - OS X 10.5 is actually even more broken than earlier versions, |
|
|
162 | so fall back to select on that piece of garbage. |
|
|
163 | - fixed some weirdness in the ev_embed documentation. |
|
|
164 | |
|
|
165 | 3.49 Wed Nov 19 11:26:53 CET 2008 |
|
|
166 | - ev_stat watchers will now use inotify as a mere hint on |
|
|
167 | kernels <2.6.25, or if the filesystem is not in the |
|
|
168 | "known to be good" list. |
|
|
169 | - better mingw32 compatibility (it's not as borked as native win32) |
|
|
170 | (analysed by Roger Pack). |
|
|
171 | - include stdio.h in the example program, as too many people are |
|
|
172 | confused by the weird C language otherwise. I guess the next thing |
|
|
173 | I get told is that the "..." ellipses in the examples don't compile |
|
|
174 | with their C compiler. |
|
|
175 | |
|
|
176 | 3.48 Thu Oct 30 09:02:37 CET 2008 |
|
|
177 | - further optimise away the EPOLL_CTL_ADD/MOD combo in the epoll |
|
|
178 | backend by assuming the kernel event mask hasn't changed if |
|
|
179 | ADD fails with EEXIST. |
|
|
180 | - work around spurious event notification bugs in epoll by using |
|
|
181 | a 32-bit generation counter. recreate kernel state if we receive |
|
|
182 | spurious notifications or unwanted events. this is very costly, |
|
|
183 | but I didn't come up with this horrible design. |
|
|
184 | - use memset to initialise most arrays now and do away with the |
|
|
185 | init functions. |
|
|
186 | - expand time-out strategies into a "Be smart about timeouts" section. |
|
|
187 | - drop the "struct" from all ev_watcher declarations in the |
|
|
188 | documentation and did other clarifications (yeah, it was a mistake |
|
|
189 | to have a struct AND a function called ev_loop). |
|
|
190 | - fix a bug where ev_default would not initialise the default |
|
|
191 | loop again after it was destroyed with ev_default_destroy. |
|
|
192 | - rename syserr to ev_syserr to avoid name clashes when embedding, |
|
|
193 | do similar changes for event.c. |
|
|
194 | |
|
|
195 | 3.45 Tue Oct 21 21:59:26 CEST 2008 |
|
|
196 | - disable inotify usage on linux <2.6.25, as it is broken |
|
|
197 | (reported by Yoann Vandoorselaere). |
|
|
198 | - ev_stat errornously would try to add inotify watchers |
|
|
199 | even when inotify wasn't available (this should only |
|
|
200 | have a performance impact). |
|
|
201 | - ev_once now passes both timeout and io to the callback if both |
|
|
202 | occur concurrently, instead of giving timeouts precedence. |
|
|
203 | - disable EV_USE_INOTIFY when sys/inotify.h is too old. |
|
|
204 | |
|
|
205 | 3.44 Mon Sep 29 05:18:39 CEST 2008 |
|
|
206 | - embed watchers now automatically invoke ev_loop_fork on the |
|
|
207 | embedded loop when the parent loop forks. |
|
|
208 | - new function: ev_now_update (loop). |
|
|
209 | - verify_watcher was not marked static. |
|
|
210 | - improve the "associating..." manpage section. |
|
|
211 | - documentation tweaks here and there. |
|
|
212 | |
|
|
213 | 3.43 Sun Jul 6 05:34:41 CEST 2008 |
|
|
214 | - include more include files on windows to get struct _stati64 |
|
|
215 | (reported by Chris Hulbert, but doesn't quite fix his issue). |
|
|
216 | - add missing #include <io.h> in ev.c on windows (reported by |
|
|
217 | Matt Tolton). |
|
|
218 | |
|
|
219 | 3.42 Tue Jun 17 12:12:07 CEST 2008 |
|
|
220 | - work around yet another windows bug: FD_SET actually adds fd's |
|
|
221 | multiple times to the fd_*SET*, despite official MSN docs claiming |
|
|
222 | otherwise. Reported and well-analysed by Matt Tolton. |
|
|
223 | - define NFDBITS to 0 when EV_SELECT_IS_WINSOCKET to make it compile |
|
|
224 | (reported any analysed by Chris Hulbert). |
|
|
225 | - fix a bug in ev_ebadf (this function is only used to catch |
|
|
226 | programming errors in the libev user). reported by Matt Tolton. |
|
|
227 | - fix a bug in fd_intern on win32 (could lead to compile errors |
|
|
228 | under some circumstances, but would work correctly if it compiles). |
|
|
229 | reported by Matt Tolton. |
|
|
230 | - (try to) work around missing lstat on windows. |
|
|
231 | - pass in the write fd set as except fd set under windows. windows |
|
|
232 | is so uncontrollably lame that it requires this. this means that |
|
|
233 | switching off oobinline is not supported (but tcp/ip doesn't |
|
|
234 | have oob, so that would be stupid anyways. |
|
|
235 | - use posix module symbol to auto-detect monotonic clock presence |
|
|
236 | and some other default values. |
|
|
237 | |
|
|
238 | 3.41 Fri May 23 18:42:54 CEST 2008 |
|
|
239 | - work around an obscure bug in winsocket select: if you |
|
|
240 | provide only empty fd sets then select returns WSAEINVAL. how sucky. |
|
|
241 | - improve timer scheduling stability and reduce use of time_epsilon. |
|
|
242 | - use 1-based 2-heap for EV_MINIMAL, simplifies code, reduces |
|
|
243 | codesize and makes for better cache-efficiency. |
|
|
244 | - use 3-based 4-heap for !EV_MINIMAL. this makes better use |
|
|
245 | of cpu cache lines and gives better growth behaviour than |
|
|
246 | 2-based heaps. |
|
|
247 | - cache timestamp within heap for !EV_MINIMAL, to avoid random |
|
|
248 | memory accesses. |
|
|
249 | - document/add EV_USE_4HEAP and EV_HEAP_CACHE_AT. |
|
|
250 | - fix a potential aliasing issue in ev_timer_again. |
|
|
251 | - add/document ev_periodic_at, retract direct access to ->at. |
|
|
252 | - improve ev_stat docs. |
|
|
253 | - add portability requirements section. |
|
|
254 | - fix manpage headers etc. |
|
|
255 | - normalise WSA error codes to lower range on windows. |
|
|
256 | - add consistency check code that can be called automatically |
|
|
257 | or on demand to check for internal structures (ev_loop_verify). |
|
|
258 | |
|
|
259 | 3.31 Wed Apr 16 20:45:04 CEST 2008 |
|
|
260 | - added last minute fix for ev_poll.c by Brandon Black. |
|
|
261 | |
|
|
262 | 3.3 Wed Apr 16 19:04:10 CEST 2008 |
|
|
263 | - event_base_loopexit should return 0 on success |
|
|
264 | (W.C.A. Wijngaards). |
|
|
265 | - added linux eventfd support. |
|
|
266 | - try to autodetect epoll and inotify support |
|
|
267 | by libc header version if not using autoconf. |
|
|
268 | - new symbols: EV_DEFAULT_UC and EV_DEFAULT_UC_. |
|
|
269 | - declare functions defined in ev.h as inline if |
|
|
270 | C99 or gcc are available. |
|
|
271 | - enable inlining with gcc versions 2 and 3. |
|
|
272 | - work around broken poll implementations potentially |
|
|
273 | not clearing revents field in ev_poll (Brandon Black) |
|
|
274 | (no such systems are known at this time). |
|
|
275 | - work around a bug in realloc on openbsd and darwin, |
|
|
276 | also makes the errornous valgrind complaints |
|
|
277 | go away (noted by various people). |
|
|
278 | - fix ev_async_pending, add c++ wrapper for ev_async |
|
|
279 | (based on patch sent by Johannes Deisenhofer. |
|
|
280 | - add sensible set method to ev::embed. |
|
|
281 | - made integer constants type int in ev.h. |
|
|
282 | |
|
|
283 | 3.2 Wed Apr 2 17:11:19 CEST 2008 |
|
|
284 | - fix a 64 bit overflow issue in the select backend, |
|
|
285 | by using fd_mask instead of int for the mask. |
|
|
286 | - rename internal sighandler to avoid clash with very old perls. |
|
|
287 | - entering ev_loop will not clear the ONESHOT or NONBLOCKING |
|
|
288 | flags of any outer loops anymore. |
|
|
289 | - add ev_async_pending. |
|
|
290 | |
|
|
291 | 3.1 Thu Mar 13 13:45:22 CET 2008 |
|
|
292 | - implement ev_async watchers. |
|
|
293 | - only initialise signal pipe on demand. |
|
|
294 | - make use of sig_atomic_t configurable. |
|
|
295 | - improved documentation. |
|
|
296 | |
|
|
297 | 3.0 Mon Jan 28 13:14:47 CET 2008 |
|
|
298 | - API/ABI bump to version 3.0. |
3 | - ev++.h includes "ev.h" by default now, not <ev.h>. |
299 | - ev++.h includes "ev.h" by default now, not <ev.h>. |
4 | - slightly improved documentation. |
300 | - slightly improved documentation. |
|
|
301 | - speed up signal detection after a fork. |
|
|
302 | - only optionally return trace status changed in ev_child |
|
|
303 | watchers. |
|
|
304 | - experimental (and undocumented) loop wrappers for ev++.h. |
5 | |
305 | |
6 | 2.01 Tue Dec 25 08:04:41 CET 2007 |
306 | 2.01 Tue Dec 25 08:04:41 CET 2007 |
7 | - separate Changes file. |
307 | - separate Changes file. |
8 | - fix ev_path_set => ev_stat_set typo. |
308 | - fix ev_path_set => ev_stat_set typo. |
9 | - remove event_compat.h from the libev tarball. |
309 | - remove event_compat.h from the libev tarball. |