xref: /freebsd/contrib/ntp/sntp/libevent/ChangeLog (revision 2830819497fb2deae3dd71574592ace55f2fbdba)
1Changes in version 2.1.5-beta (5 January 2015)
2
3 Security Fixes (evbuffers)
4   o Avoid integer overflow bugs in evbuffer_add() and related functions.  See CVE-2014-6272 advisory for more information. (d49bc0e88b81a5812116074dc007f1db0ca1eecd)
5
6 New APIs (evconnlistener)
7   o Provide support for SO_REUSEPORT through LEV_OPT_REUSABLE_PORT (b625361 Maciej Soltysiak)
8
9 Bugfixes (core)
10    o Fix use-after-free error in EV_CLOSURE_EVENT callback (3cc0eac John Ohl)
11    o Fix race caused by event_active (3c7d6fc vjpai)
12
13 Bugfixes (evbuffer)
14   o Fix evbuffer_peek() with len==-1 and start_at non-NULL. (ba59923)
15   o Consistently check for failure from evbuffer_pullup() (60f8f72)
16   o Fix evbuffer_peek() with len==-1 and start_at non-NULL. (fb7e76a)
17
18 Bugfixes (windows, IOCP)
19   o be async: avoid double close() (f133b86 Azat Khuzhin)
20
21 Bugfixes (bufferevents)
22   o Fix issue #127, double free for filterevents that use BEV_OPT_CLOSE_ON_FREE (2c82aa0 John Ohl)
23   o make bufferevent_getwatermark api more robust (a21e510 ufo2243)
24   o [Bugfix] fix bufferevent setwatermark suspend_read (b34e4ac ufo2243)
25   o bufferevent_openssl: reset fd_is_set when setfd with -1 is called (3da84c2 Azat Khuzhin)
26   o Fix compilation for older OpenSSL versions. (5c7282f Joakim Soderberg)
27
28 New APIs (evhttp)
29   o Add evhttp_connection_set_family() to set addrinfo->family for DNS requests (12c29b0 Azat Khuzhin)
30   o Implement interface that provides the ability to have an outbound evhttp_connection free itself once all requests have completed (2b9ec4c,10fe4f John Ohl)
31
32 New APIs (core)
33   o Implement new/free for struct evutil_monotonic_timer and export monotonic time functions (f2645f8 Andrea Shepard)
34
35 Bugfixes (evdns)
36   o Load hosts file on Windows. (a0b247c Vilmos Nebehaj)
37   o Don't truncate hosts file path on Windows. (d0dc861 Vilmos Nebehaj)
38   o Fix a crash in evdns related to shutting down evdns (9f39c88,e8fe749)
39   o evdns: avoid read-after-free in evdns_request_timeout_callback() (61262a0 Azat Khuzhin)
40   o Correctly handle allocation failures in evdns_getaddrinfo (6a53d15)
41   o evdns: fix EVDNS_BASE_DISABLE_WHEN_INACTIVE in case retransmit/retry (74d0eee Azat Khuzhin)
42   o evdns: add retry/reissue tests for EVDNS_BASE_DISABLE_WHEN_INACTIVE (3ca9d43 Azat Khuzhin)
43   o evdns: fail ns after we are failing/retrasmitting request (97c750d Azat Khuzhin)
44
45 Bugfixes (evhttp)
46   o http: reset connection before installing retry timer (fix http retries handling) (bc79cc5 Azat Khuzhin)
47
48
49 Testing
50   o regress_dns: fix leaks in getaddrinfo_async{,_cancel_stress} tests (2fdc5f2 Azat Khuzhin)
51   o test: add family argument for http_connection_test_() (177b8a7 Azat Khuzhin)
52   o test: add regress for evhttp_connection_set_family() with AF_INET and AF_UNSPEC (42aefeb Azat Khuzhin)
53   o test/http: add regress test for set family to AF_INET6 (3fbf3cc Azat Khuzhin)
54   o Update to a more recent tinytest_macros. (8da5a18)
55   o test/regress: add simplestsignal: to track reorder bugs separately (b897bef Azat Khuzhin)
56   o test/evbuffer_peek: add regress in case we have first buffer greater (e2d139d Azat Khuzhin)
57   o More evbuffer_peek() test cases (154006a)
58   o use correct tt macro for pointer compare (08c88ea)
59   o regress_buffer: fix 'memcmp' compare size (79800df Maks Naumov)
60   o Fix a use-after-free in unit tests. CID 752027 (3739057)
61   o Fix a dead-code warning in unit tests. CID 1193548 (c119f24)
62   o Use evutil_weakrand() in unit tests. (a677b72, 364c110)
63   o Use a more precise calculation for max in time-ratelim.c (ca5b5c7)
64   o Make a buffer larger in the tests to avoid a scary evbuffer_copyout_from() (fb57b8b)
65   o Fix several memory leaks in the unit tests. (89c1a3b)
66   o Add test for evhttp_connection_free_on_completion (b0e9924 John Ohl)
67   o Fix annoying heisenbug in test-time.c (cb73704)
68
69 Sample code
70   o Make http-server.c output into good html5 (6d72bdc)
71   o Use FindClose for handle from FindFirstFile in http-server.c (6466e88)
72   o https-client: add -retries argument, for connection retries (d9da844 Azat Khuzhin)
73
74 Bugfixes (build)
75   o Add missing headerfile for cmake (15d90cc Trond Norbye)
76   o ignore one more test binary (b6593aa Michael Richardson)
77   o ignore config.cache/test-driver files (c83f333 Mike Frysinger)
78   o add a --disable-samples configure flag (0c492b3 Mike Frysinger)
79   o Add a few files created by "make verify" to .gitignore. (1a8295a Pierre Phaneuf)
80   o updates in cmake build (27bd9fa Sergey Nikulov)
81   o Fix cmake error when the Module path has more than one entry. (befbd13 Acer Yang)
82   o Fix CMake shared library build (e69d910 Nobuaki Sukegawa)
83   o Fix warnings when compiling with clang 3.5 (f5b4765 John Ohl)
84   o Fix mixed declarations and code (forbidden by ISO C90) (8afbdbc Thomas Bernard)
85
86 Bugfixes (miscellaneous)
87   o tree.h: drop duplicated content of tree.h (6193187 Azat Khuzhin)
88   o evdns: disable probing with EVDNS_BASE_DISABLE_WHEN_INACTIVE (610410b,ad0493e,fea86a6,d83b337,5ca9e97 Azat Khuzhin)
89   o [Bugfix] fix grammer error (3a4d249 ufo2243)
90   o Change return type of evutil_load_windows_system_library_ to HMODULE (f691389)
91   o Fix a c90 warning (76643dd)
92   o Fix a typo in a doxygen comment. Reported by 亦得. (be1aeff)
93   o remove trailing comma from enum (b361b8a Jean-Philippe Ouellet)
94
95 Bugfixes (FreeBSD)
96   o Handle ENOTCAPABLE from FreeBSD - this is returned if an event in the changelist is for an FD that has been closed. (6fd7394 Adrian Chadd)
97
98
99
100Changes in version 2.1.4-alpha (21 Mar 2014)
101
102 Libevent 2.1.4-alpha adds a number of new miscellaneous APIs to make
103 Libevent more useful, including support for early close detection with
104 epoll via EPOLLRDHUP, triggering bufferevent callbacks, adding more
105 evhttp callbacks, and more. There are also numerous bugfixes, including
106 a number for finalize-related issues from 2.1.3-alpha; and an
107 alternative (non-primary!) cmake-based build mechanism.
108
109 New APIs (core)
110   o Added event_base_get_num_events() (0fa107d Mobai Zhang)
111   o New event_base_active_by_fd API (865a142 Greg Hazel, 5c9da9a, 87fa2b0)
112   o Add event_base_active_by_signal by analogy (4865943)
113   o Add access to max event count stats (5173bef, efbd3dc, 26230a2
114     Andrew Sweeney)
115   o Implemented EV_CLOSED event for epoll backend
116     (EPOLLRDHUP). (b1b69ac Diego Giagio, 53d2793, 43ffcf6, dfe1e52
117     Marcin Juszkiewicz, ff26633 Joakim Soderberg, 3908a5e)
118
119 New APIs (evutil_secure_rng)
120   o Add evutil_secure_rng_set_urandom_device_file (2bbb5d7)
121
122 New APIs (bufferevents)
123   o Add function to fetch underlying ratelimit cfg (4b3d5af Mark Ellzey)
124   o Pass and return const for bufferevent_get_token_bucket_cfg (1c77fbb
125     Mark Ellzey)
126   o Add watermark introspection (4ce242b Ondřej Kuzník)
127   o Add an option to trigger bufferevent I/O callbacks (61ee18b Ondřej Kuzník)
128   o Add an option to trigger bufferevent event callbacks (a7384c7
129     Ondřej Kuzník)
130   o Clarifications in response to merge req. comments (bd41947 Ondřej
131     Kuzník)
132   o Minor optimizations on bufferevent_trigger options (a3172a4)
133
134 New APIs (evhttp)
135   o Add evhttp_connection_get_server(). (a7f82a3 Maxime Henrion)
136   o add a http default content type option (5a5acd9 Nicolas Martyanoff)
137   o http: implement new evhttp_connection_get_addr() api. (0c7f040 Azat
138     Khuzhin)
139   o Add a variant of evhttp_send_reply_chunk() with a callback on
140     evhttp_write_buffer() (8d8decf Julien BLACHE)
141   o Allow registering callback for parsing HTTP headers (b0bd7fe Balint Reczey)
142   o Provide on request complete callback facility (b083ca0 Andrew Sweeney)
143   o evhttp_request_set_on_complete_cb to be more specific about what
144     the function actually does and usage (da86dda Andrew Sweeney)
145   o Update unit test to make sure that the callback happens after the
146     output data is written (b85f398 Andrew Sweeney)
147
148 Features (evdns)
149   o bug fix for issues #293 evdns_base_load_hosts doesn't remove
150     outdated addresses (954d2f9, f03d353, 45eba6f Kuldeep Gupta)
151
152 Features: (cmake build support)
153   o Initial CMake commit. (e415196 Joakim Soderberg)
154   o Add all tests and benchmarks to CMake project. (e9fc014 Joakim Soderberg)
155   o More work on adding tests to CMake project (99c1dc3 Joakim Soderberg)
156   o Generate a dummy evconfig-private.h so things build
157     properly. (ce14def Joakim Soderberg)
158   o Link libm on unix platforms. (58fcd42 Joakim Soderberg)
159   o Added some GCC specific options. (19222e5 Joakim Soderberg)
160   o Use evutil_closesocket instead. (dbf2b51 Joakim Soderberg)
161   o Add copyright and licensing files for CMake modules. (c259d53
162     Joakim Soderberg)
163   o Only include WIN32 getopt where it is used. (9bbce0b Joakim Soderberg)
164   o Fix bench_cascade program on Windows. (78da644 Joakim Soderberg)
165   o Don't segfault on no found event backend. (8f2af50 Joakim Soderberg)
166   o Only test the event backends available on the system. (7ea4159
167     Joakim Soderberg)
168   o Added a "make verify" target. (e053c4f Joakim Soderberg)
169   o Fix the make "verify" target on Windows. (67e5d74 Joakim Soderberg)
170   o Get rid of deprecation warnings for OpenSSL on OSX 10.7+ (69c3516
171     Joakim Söderberg)
172   o Fix kqueue support. (a831f2f Joakim Söderberg)
173   o Added a test for testing if kqueue works with pipes. (2799b35
174     Joakim Söderberg)
175   o Change the BSD license from 4 to 3-clause. (86df3ed Joakim Soderberg)
176   o Minimum required python version is 2.4. (968e97b Joakim Soderberg)
177   o Get rid of unknown pragma warnings. (0ef1d04 Joakim Soderberg)
178   o Add a "make verify_coverage" target generation coverage
179     info. (f2483f8 Joakim Soderberg)
180   o Fix the "make verify" target on NetBSD (4ac086a Joakim Soderberg)
181   o Only look for ZLib when it is used (if tests are
182     included). (f780593 Joakim Soderberg)
183   o Added EVENT__ENABLE_GCC_WARNINGS, turns all warnings into
184     errors. (dd413bd Joakim Soderberg)
185   o Add CMake config and install targets. (f3446ed Joakim Soderberg)
186   o Fix typo (4b754df Joakim Soderberg)
187   o Some work on making it possible to simply do add_subdirectory() on
188     the project. (49ab363 Joakim Soderberg)
189   o Set USE_DEBUG=1 on EVENT__ENABLE_VERBOSE_DEBUG (fd42e70 Joakim Soderberg)
190   o Fix so that old nmake project still builds. (24d6466 Joakim
191     Soderberg)
192   o Rename README to README.md and use markdown to format. (d2bc39a
193     Joakim Soderberg)
194   o Update README with CMake build instructions. (604b8cc Joakim Soderberg)
195   o Clean up the README some. (8d4cb35 JoakimSoderberg)
196   o Forgotten headers for old nmake project compatability. (8697b99
197     Joakim Soderberg)
198   o Change all uses of WIN32 to _WIN32 (4e14395 Joakim Söderberg)
199   o Fix include bug. (2024467 Joakim Söderberg)
200   o Check if we're on OSX before disabling deprecation in le-proxy
201     (8b40a5b Joakim Söderberg)
202   o Fix broken autotools build. (ae1bd82 Joakim Söderberg)
203   o Disclaimerize cmake a little in the README (d03b5bf)
204   o Fix CMake compile when OpenSSL is disabled. (e423d42 Joakim
205     Söderberg)
206   o CMake: Get rid of python not found warning when regress tests
207     turned off. (d38d798 Joakim Söderberg)
208   o Fix https-client compilation on Windows. (d7be788 Joakim Soderberg)
209   o Guard against EVENT_NOWIN32 being set during testing. (f1715b4
210     Joakim Soderberg)
211   o Check for OSX when checking for clang. (e212c54 Joakim Soderberg)
212   o Added a Travis-CI configuration file. (8c0f0a9 Joakim Soderberg)
213   o Added -Qunused-arguments for clang on macosx (ed99d92 Trond Norbye)
214   o Rename event_extras to event_extra (a0dd5df Trond Norbye)
215   o Add option to build shared library (4545fa9 Trond Norbye)
216   o Add -Qunused-arguments for clang on macos (b56611d Trond Norbye)
217   o Add cmake-related files to .gitignore (e061321 Trond Norbye)
218   o Export event_extra not event_extras. (2b41bcf Joakim Söderberg)
219
220 Bugfixes (core)
221   o If evsel->del() fails, don't leave the evmap in an inconsistent
222     state (9b5a527 Maxime Henrion)
223   o Move event_debug_note_teardown_ before mm_free. (69b5c64)
224   o Check CLOCK_MONOTONIC_* at runtime if needed. (911abf3)
225   o Fix reinit of fds with EV_WRITE but not EV_READ. (ebfd8a8 maksqwe)
226   o Tweaked callbacks to prevent race condition
227     (https://github.com/libevent/libevent/issues/104) (40830f1, 2ea15ed
228     John Ohl)
229   o Move assert(ev) to before we use ev in EV_CLOSURE_EVENT_FINALIZE
230     case (9805972)
231
232 Bugfixes (evhttp)
233   o Fix a double close() bug in evhttp when the underlying bufferevent uses
234     BEV_OPT_CLOSE_ON_FREE. (31db8a0 Maxime Henrion)
235   o Fix an unlikely but possible error case for http connections (f22049e)
236   o Avoid racy bufferevent activation (5eb1788 Nate Rosenblum)
237
238 Bugfixes on 2.0 (Windows)
239   o Use windows vsnprintf fixup logic on all windows environments (e826f19)
240   o libevent/win32_dealloc() : fix sizeof(pointer) vs sizeof(*pointer)
241    (b8f5980 Frank Denis)
242
243 Bugfixes (evutil_secure_rng)
244   o When we seed from /proc/sys/kernel/random/uuid, count it as success
245     (e35b540)
246   o We should return after arc4random_buf() (1ea1f26 Makoto Kato)
247   o Avoid other RNG initialization FS reads when urandom file is
248     specified (9695e9c)
249   o Really remove RNG seeds from the stack (f5ced88)
250   o Fix another arc4random_buf-related warning (e64a2b0)
251
252 Bugfixes (bufferevents)
253   o Initialize async bufferevent timeout CBs unconditionally (af9b2a7)
254
255 Bugfixes (evdns)
256   o Checking request nameserver for NULL, before using it. (5c710c0
257     Belobrov Andrey)
258   o Fix SEGFAULT after evdns_base_resume if no nameservers
259     installed. (14971a8 Azat Khuzhin)
260   o Actually use the log facility for reporting evdns problems. (e1766a1)
261   o Fix SEGFAULT after evdns_base_resume if no nameservers
262     installed. (f8d7df8 Azat Khuzhin)
263   o fix for ServFail from RIPE Atlas release (62f596b Antony Antony)
264
265 Bugfixes (compilation)
266   o Fix test compilation with nmake: add the gdi.lib dependency (5ba8ab7)
267   o Whoops. It is gdi.lib, not gdi32.lib. (github issue #61) (8ab612e)
268   o Don't use return since return type is void and build error occurs
269     using clang (838161d Makoto Kato)
270   o Use void casts to suppress some "unchecked return value" warns (7080d55)
271   o rpcgen: Generate regress.gen.[c,h] in build rather than src dir
272     (243386c Ross Lagerwall)
273   o Fix a compiler warning when checking for arc4random_buf linker
274     breakage. (5cb3865)
275   o Fix 'make distcheck' by adding regress.gen.[ch] to DISTCLEANFILES
276    (239d834)
277
278   o Fix a c90 warning (c207682)
279   o Fix consts in WIN32-Code/getopt*.[ch] (57abb35)
280
281 Bugfixes (locks, synchronization)
282   o Missed lock acquire/release in event_base_cancel_single_callback_()
283     (d3d999a Azat Khuzhin)
284   o Fix locking in bufferevent_get_options_(). (dbc9cd4 Maxime Henrion)
285
286 Bugfixes (leaks)
287   o Avoid leaking segment mappings when offset is not a page multiple (d409514)
288
289 Testing
290   o Add tests for evdns_base_resume(). (1cd9ff5 Azat Khuzhin)
291   o Fix dns/leak_resume_send_err test. (7e876df Azat Khuzhin)
292   o Add checks for evhttp_connection_get_server() in unit
293     tests. (fbc323b Maxime Henrion)
294   o Fix a (failure-only) null dereference in the unit tests (1104d0b)
295   o Fix a logic error in test_evbuffer_freeze (7765884)
296   o Add missing check to test_evbuffer_file_segment_add_cleanup_cb (eba4506)
297   o Fix some crash-on-fail cases in DNS regression tests (87cd6f0)
298   o DNS tests: add a missing check (f314900)
299   o Finalize tests: add a missing check (82b6956)
300   o test_evutil_rtrim: add another missing check. (e193c95)
301   o regress_main: logging all if env EVENT_DEBUG_LOGGING_ALL isset
302     (611e28b Azat Khuzhin)
303   o regress_http: add tests for evhttp_connection_get_addr() (4dd500c
304     Azat Khuzhin)
305   o Update to the latest version of tinytest (7a80476)
306   o Heap-allocate zlib data structure in regress_zlib tests (4947c18)
307
308 Performance tweaks (core)
309   o Avoid redundant syscall to make a nonblocking socket nonblocking
310     (42c03da Maxime Henrion)
311   o Avoid redundant syscall if making a socket cloexec twice (1f29b18)
312   o Avoid redundant invocations of init_extension_functions for IOCP (3b77d62)
313
314 Documentation
315   o Document that arc4random is not a great cryptographic PRNG. (6e49696)
316   o Small doxygen tweaks (6e67b51)
317   o Try another doxygen tweak (ccf432b)
318   o Clarify event_base_loop exit conditions (031a803)
319   o Fix a typo (be7bf2c Ondřej Kuzník)
320   o Document deferred eventcb behaviour (13a9a02 Ondřej Kuzník)
321   o Typo fixes from Linus Nordberg (cec62cb, 8cd695b)
322   o Fix duplicate paragraph in evbuffer_ptr documentation (58408ee)
323
324 Code Improvements (coverity)
325   o Fix a pile of coverity warnings in the unit tests (867f401)
326   o Fix coverity warnings in benchmark tools. (ff7f739)
327   o Whoops; fix compilation in bench.c (544cf88)
328   o Remove spurious checks in evrpc.c error cases (coverity) (991b362)
329   o Fix a couple of compilation warnings in regress_http.c (860767e)
330   o Fix even more coverity warnings. (d240328)
331   o Stop checking for inet_aton; we don't use it. (f665d5c)
332   o Add an include to evrpc-internal to fix openbsd compilation warning
333     (5e161c6)
334
335 Cleanups
336   o Remove an unreachable return statement in minheap-internal.h (e639a9e)
337   o Refactor evmap_{io,signal}_active_() to tolerate bad inputs (974c60e)
338   o Fix needless bufferevent includes in evdns.c (254c04e)
339   o Fix a couple of "#ifdef WIN32" instances (88ecda3)
340   o Remove unneeded declaration in bufferevent-internal.h (4c8ebcd)
341
342 Sample code
343   o le-proxy: Fail more gracefully if opening listener fails (44b2491)
344   o http-server: drop uri_root from base_url in http-server. (6171e1c Azat Khuzhin)
345   o https-client: POST supported, args supported (c5887f7 Alexey Ozeritsky)
346   o https-client: code cleanup (29af65e Alexey Ozeritsky)
347   o https-client: Small tweaks to https-client.c (90786eb)
348   o https-client: Set hostname for SNI extension (by f69m) (d1976f8)
349   o https-client: add a cast to https-client.c (462e6b6)
350
351
352
353Changes in version 2.1.3-alpha (1 May 2013)
354
355 Libevent 2.1.3-alpha fixes various bugs, adds new unit tests, and cleans
356 up the code in a couple of places. It has a new callback in evhttp for
357 reporting errors during a request, a new feature for allowing evdns to
358 not keep the event_base looping when there are no requests inflight, and
359 example code for writing an https client.
360
361 Libevent 2.1.3-alpha also has an important new (experimental) event
362 finalization feature to allow safe event teardown in multithreaded
363 programs. This ought to fix the longstanding bug with deadlocks in
364 multithreaded use of SSL-based bufferevents that some people have been
365 experiencing since Libevent 2.0.
366
367
368 Core (event finalization)
369   o Implement event_finalize() and related functions to avoid certain
370     deadlocks (8eedeab)
371   o Use finalization feature so bufferevents can avoid deadlocks (02fbf68)
372   o Always run pending finalizers when event_base_free() is called (e9ebef8)
373   o Remove bufferevent_del_generic_timeout_cbs as now unused (4ea4c6a)
374   o More documentation for finalization feature (a800b91)
375   o Make the event_finalize* functions return an error code (5d11f4f)
376   o Mark the finalize stuff as experiemental in case it needs to
377     change (23e2e29)
378
379 Evdns
380   o evdns: New flag to make evdns not prevent the event loop from
381     exiting (6b7fa62 Azat Khuzhin)
382
383 Bugfixes (Core)
384   o Make event_remove_timer behave correctly with persistent timers (5623e80)
385   o Unit test for event_remove_timer with EV_PERSIST. (96150dd)
386   o Double-check next timeout when adding events (9443868 Nate Rosenblum)
387   o event_base_update_cache_time should be a no-op if the loop isn't
388     running (5e6fa2a)
389
390 Bugfixes (evhttp, crash fix, from 2.0)
391   o fix #73 and fix http_connection_fail_test to catch it (b618204 Greg Hazel)
392
393 Bugfixes (compilation and portability, from 2.0)
394   o Fix compilation with WIN32_HAVE_CONDITION_VARIABLES enabled (7e45739)
395   o Fix missing AC_PROG_SED on older Autoconfs (9ab2b3f Tay Ray Chuan)
396   o Backport libevent to vanilla Autoconf 2.59 (as used in RHEL5)
397     (74d4c44 Kevin Bowling)
398   o Use AC_CONFIG_HEADERS in place of AM_CONFIG_HEADERS for autmake
399     1.13 compat (817ea36)
400   o Rename configure.in to configure.ac to appease newer autoconfs (0c79787)
401   o Avoid using top_srcdir in TESTS: new automakes do not like this (a55514e)
402
403 Bugfixes (resource leaks/lock errors on error, from 2.0)
404   o Avoid leaking fds on evconnlistener with no callback set (69db261)
405   o Avoid double-close on getsockname error in evutil_ersatz_socketpair
406     (0a822a6)
407   o Fix a locking error in bufferevent_socket_get_dns_error. (0a5eb2e)
408
409 Documentation Fixes (from 2.0)
410   o Fix a mistake in evbuffer_remove() arguments in example http server code
411     (c322c20 Gyepi Sam)
412   o Fix a typo in a comment in buffer.h. Spotted by Alt_F4 (773b0a5)
413
414 Documentation Fixes
415   o minor documentation typos (809586a Patrick Pelletier)
416   o Fix cut-and-paste err in whatsnew-2.1 (49905ac)
417   o Fix comment to refer to sample/include.am correctly (9e8cdf3 Sebastian
418     Hahn)
419   o Fix typo : Dispatching instead of Dispaching (0c2bacc Volker Lendecke)
420   o fix some hinky indentation in evhttp_make_request (80e220e Patrick
421     Pelletier)
422   o "buffer" spelling (a452811 Patrick Pelletier)
423   o Specify return behavior in header for evbuffer_pullup() in corner case
424     (cf8d1cd Dan Petro)
425   o Clarify an important point about event_base_foreach_event() (920a5e6)
426
427 Compilation Fixes/Tool Support
428   o avoid valgrind false positive by zeroing epoll_event (1258614 Patrick
429     Pelletier)
430   o Fix harmless clang enum warning (b452a43 Sebastian Hahn)
431   o remove all exes on "make clean", not just regress.exe (974bfa0 Patrick
432     Pelletier)
433   o Make --disable-libevent-regress work again (787fd74)
434   o Do not build strlcpy.c when it will have no code. (4914620)
435
436 Portability Fixes
437   o When EWOULDBLOCK is not EAGAIN, treat it as equivalent to it (bf7a0ff)
438   o Preliminary changes for Minix3. (0dda56a Nicholas Heath)
439   o Use AC_CONFIG_HEADERS in place of AM_CONFIG_HEADERS for autmake 1.13
440     compat (bf278b)
441   o Avoid using $(top_srcdir) in TESTS. (2863c83)
442   o build test/test-script.sh on systems with a less-featureful $< (f935e21)
443   o Implement EVUTIL_ERR_IS_EAGAIN on windows. (42aaf4d)
444
445 Evhttp changes:
446   o Fix ipv6 support for http. When URL contain domain, not IP
447     address. (71e709c Azat Khuzhin)
448   o uri decode: fix for warning "use of uninitialised value" (64b6ece Azat
449     Khuzhin)
450   o uri decode: changed the test for the existence of the next character
451     (e1903e3 Azat Khuzhin)
452   o Move prototype of evhttp_decode_uri_internal() to http-internal.h
453     (de8101a Azat Khuzhin)
454   o Test: decoding just part of string with evhttp_decode_uri_internal()
455     (1367653 Azat Khuzhin)
456   o Add new error_cb for actual reporting of HTTP request errors. (7b07719
457     Azat Khuzhin)
458   o Add test for EVREQ_HTTP_REQUEST_CANCEL into http_cancel_test() (862c217
459     Azat Khuzhin)
460   o Drop extra header http_struct.h from regress_http.c (54cc800 Azat Khuzhin)
461
462 Testing
463   o Add regress test ipv6_for_domain. (9ec88bd Azat Khuzhin)
464   o Add an environment variable (EVENT_DEBUG_MODE) to run unit tests in debug
465     mode (2fad0f3)
466   o Add a test with an active_later event at event_base_free time. (1c3147f)
467   o Make all tests pass under EVENT_DEBUG_MODE=1 (b1b054f)
468   o Add some verbose notes to bufferevent unit tests (9d893c9)
469   o New test for active_later->active transition on event_active (a153874)
470   o New tests for event_base_foreach_event() (0b096ef)
471   o Unit tests for event_base_gettimeofday_cached() and
472     event_base_update_cache_time() (30ea291)
473   o A test for event_get_assignment() (f09629e)
474   o More unit tests for initializing common timeouts. (d596739)
475   o Fix a bug in the new main/event_foreach test (702c9aa)
476
477 Windows:
478   o use FormatMessage for winsock errors (0c6ec5d, 2078e9b, 4ccdd53, c9ad3af
479     Patrick Pelletier)
480   o a program to print out the error strings for winsock errors (7296512
481     Patrick Pelletier)
482   o Fix a warning introduced in 0c6ec5d8 (eeb700c)
483   o Fix another warning introduced in 0c6ec5d8 (ed26561)
484
485 Examples (http)
486   o Add sample/https-client.c, an example of stacking evhttp as a client on
487     top of bufferevent_ssl. (be46c99 Catalin Patulea)
488   o use ${OPENSSL_LIBS} instead of -lssl -lcrypto (bf31fa5 Patrick Pelletier)
489   o https-client was putting newlines at 256-byte boundaries (42d7441 Patrick
490     Pelletier)
491   o better handling of OpenSSL errors (5754d96 Patrick Pelletier)
492   o use Debian's default root certificate location (aacd674 Patrick Pelletier)
493   o use iSECPartners code to validate hostname in certificate (64d9f16
494     Patrick Pelletier)
495   o avoid sign mismatch warning in openssl_hostname_validation.c (6021cb5
496     Patrick Pelletier)
497   o pull in wildcard matching code from cURL (4db9da6 Patrick Pelletier)
498   o Another tweak to https-client.c (95acdaa)
499   o Remove http_struct.h usage in sample/https-client.c (8a90a85)
500
501
502
503Changes in version 2.1.2-alpha (18 Nov 2012)
504
505 Libevent 2.1.2-alpha includes more portable for monotonic timers,
506 refactors much of Libevent's internal and external infrastructure,
507 closes some longstanding gaps in the interface, makde other
508 improvements.  Ths log below tries to organize features by rough area of
509 effect.  It omits a few commits which were pure bugfixes on other commits
510 listed below.  For more detail, see the git changelogs.  For more
511 insight, see the "whatsnew-2.1.txt" document included in the Libevent
512 2.1.2-alpha distribution.
513
514 Libevent 2.1.2-alpha also includes all changes made in 2.0.19-stable
515 through 2.0.21-stable inclusive.
516
517 Performance (core):
518   o Replace pipe-based notification with EVFILT_USER where possible. This
519     should make multithreaded programs on OSX and *BSD alert the main thread a
520     little faster. (53a07fe)
521   o Make th_base_lock nonrecursive. (9cd5acb)
522
523 New/Changed API Functions:
524   o New event_get_priority() function to return an event's priority (f90e255)
525   o Add a bufferevent_get_priority() function (bd39554)
526   o Add an event_base_loopcontinue() to tell Libevent to rescan for more
527     events right away (7d6aa5e)
528   o Add a new callback to get called on evbuffer_file_segment free
529     (e9f8feb yangacer, 64051b9)
530   o Expose event_base_foreach_event() as a public API. (84fd6d7 Roman
531      Puls, 232055e, ffe1643)
532   o Add an event_remove_timer() to remove timer on an event without
533     deleting it (e3b2e08)
534   o Make bufferevent_set_timeouts(bev, NULL, NULL) have plausible
535     semantics (9dee36b)
536   o Rename event_enable_lock_debuging() to ..._debugging(). (The old name
537     should still work.) (07e132e)
538   o Add missing implementation for event_enable_debug_logging (3b3e21d)
539
540 PORTABLE MONOTONIC TIMERS:
541
542   Libevent 2.1.2 includes internal support for monotonic timers on
543   (nearly) all supported platforms, including Windows, and OSX.  Libevent
544   applications should now be more resilient to jumps forwards or backwards
545   in the system clock.  Also, on Linux systems with epoll, we now
546   optionally support microsecond-level timeouts (whereas epoll only
547   supports millisecond-precision timeouts).
548
549   o Use mach_absolute_time() for monotonic clock support on OSX. (b8fd6f9)
550   o Do not track use_monotonic field when is no monotonic clock (cb653a0)
551   o EVENT_BASE_FLAG_PRECISE_TIMER indicates we want fine timer precision
552     (ddd69d3)
553   o On Linux, use CLOCK_MONOTONIC_COARSE by default (55780a7)
554   o Implement a GetTickCount-based monotonic timer for Windows (d5e1d5a)
555   o Refactor monotonic timer handling into a new type and set of
556     functions; add a gettimeofday-based ratcheting implementation (f5e4eb0)
557   o Add EVENT_PRECISE_TIMER environment var for selecting precise-but-slow
558     timer (a2598ec)
559   o Implement fast/precise monotonic clocks on Windows (2c47045)
560   o Simple unit tests for monotonic timers (630f077)
561   o Improve the monotonic-time unit test: make it check the step size (7428c78)
562   o When PRECISE_TIMERS is set with epoll, use timerfd for microsecond
563     precision (26c7582)
564   o Split out time-related evutil functions into a new evutil_time.c (c419485)
565   o Split out time-related prototypes into time-internal.h (71bca50)
566   o Add evutil_time.obj to Makefile.nmake (0ba0683)
567   o Avoid giving a spurious warning when timerfd support is unavailable
568     (1aaf9f0 Dave Hart)
569   o Make test_evutil_monotonic a little more tolerant (def3b83)
570   o Avoid unused-var warning on systems with clock_gettime but without
571     CLOCK_MONOTONIC_COARSE (9be5468)
572
573EVENT_BASE_ONCE LEAKS:
574   If a callback added by event_base_once() is never invoked, Libevent no
575   longer leaks internal memory.
576
577   o Free dangling event_once objects on event_base_free() (c17dd59)
578   o Add a unit test in which an event is created with event_base_once()
579     but never fires (4343edf)
580
581TESTING SUPPORT, FIXES AND IMPROVEMENTS:
582
583   Libevent now disables by default its unit tests that would touch the
584   network, or that tend to fail on heavily-loaded systems.  To re-enable
585   them, invoke the ./test/regress program with the @all alias.
586
587   o Simplify test.sh code significantly. (9b856fd Ross Lagerwall)
588   o Make all tests that hit the network disabled by default (f2cea87)
589   o Avoid a resource leak on error in http client benchmark (ea92fba)
590   o Update to latest tinytest (911b4f0349377) (ef7c4f7)
591   o Avoid (unlikely) overflow in bench_httpclient.c (5671033)
592   o Shave 700 msec off the persistent_timeout_jump test (21205b8)
593   o Check return value of write() in regress.c (c8009d2)
594   o Make load-dependent monotonic timer tests off-by-default (2b6fe8b)
595   o Add deferred_cb_skew to list of timing-dependent tests (34c8f31)
596   o Avoid test -e; older shs don't have one. (f1bd938)
597   o Fix renegotiation test to work around openssl 1.0.1 bug (c2f3086)
598   o Fix a couple of compile warnings in the unit tests (5a9a014)
599
600MISC:
601   o Change evutil_weakrand_() to avoid platform random() (e86af4b Nicholas
602     Marriott, 3aa4415)
603
604INFRASTRUCTURE (Active-later events):
605   As a simplification and optimization to Libevent's "deferred callback"
606   logic (introduced in 2.0 to avoid callback recursion), Libevent now
607   treats all of its deferrable callback types using the same logic it uses
608   for active events.  Now deferred events no longer cause priority
609   inversion, no longer require special code to cancel them, and so on.
610
611   o Refactor the callback part of an event into its own event_callback
612     type (cba59e5)
613   o Add "active later" event_callbacks to supersede deferred (745a63d)
614   o event_base_assert_ok: check value of event_active_count for
615     correctness (fec8bae)
616   o Replace deferred_cbs with event_callback-based implementation. (ae2b84b)
617   o Replace more deferred_cb names with event_callback (a4079aa)
618   o Give event_base_process_active a single exit path (581b5be)
619   o Restore our priority-inversion-prevention code with deferreds (c0e425a)
620   o Refactor event_persist_closure: raise and extract some common logic
621     (bec22b4)
622   o Remove the unused bits from EVLIST_ALL (9889a3d)
623||||||| merged common ancestors
624Changes in version 2.0.22-stable (?? Dec 2013)
625
626 (As of 3b77d62829c4393bda6f9105a5d3b73b48a64b71.)
627
628BUGFIXES (evhttp)
629 o fix #73 and fix http_connection_fail_test to catch it (crash fix) (b618204 Greg Hazel)
630 o Avoid racy bufferevent activation (5eb1788 Nate Rosenblum)
631
632BUGFIXES (compilation and portability)
633 o Fix compilation with WIN32_HAVE_CONDITION_VARIABLES enabled (7e45739)
634 o Fix missing AC_PROG_SED on older Autoconfs (9ab2b3f Tay Ray Chuan)
635 o Backport libevent to vanilla Autoconf 2.59 (as used in RHEL5) (74d4c44 Kevin Bowling)
636 o Use AC_CONFIG_HEADERS in place of AM_CONFIG_HEADERS for autmake 1.13 compat (817ea36)
637 o Rename configure.in to configure.ac to appease newer autoconfs (0c79787)
638 o Avoid using top_srcdir in TESTS: new automakes do not like this (a55514e)
639 o Use windows vsnprintf fixup logic on all windows environments (e826f19)
640 o Fix a compiler warning when checking for arc4random_buf linker breakage. (5cb3865)
641 o Fix another arc4random_buf-related warning (e64a2b0)
642
643BUGFIXES (resource leaks/lock errors on error)
644 o Avoid leaking fds on evconnlistener with no callback set (69db261)
645 o Avoid double-close on getsockname error in evutil_ersatz_socketpair (0a822a6)
646 o Fix a locking error in bufferevent_socket_get_dns_error. (0a5eb2e)
647 o libevent/win32_dealloc() : fix sizeof(pointer) vs sizeof(*pointer) (b8f5980 Frank Denis)
648
649BUGFIXES (miscellaneous)
650 o Avoid other RNG initialization FS reads when urandom file is specified (9695e9c, bb52471)
651 o Avoid redundant invocations of init_extension_functions for IOCP (3b77d62)
652
653BUFGIXES (evdns)
654 o Checking request nameserver for NULL, before using it. (5c710c0 Belobrov Andrey)
655 o Fix SEGFAULT after evdns_base_resume if no nameservers installed. (f8d7df8 Azat Khuzhin)
656
657BUGFIXES (evutil_secure_random)
658 o When we seed from /proc/sys/kernel/random/uuid, count it as success (e35b540)
659 o Document that arc4random is not a great cryptographic PRNG. (6e49696)
660 o Add evutil_secure_rng_set_urandom_device_file (2bbb5d7)
661 o Really remove RNG seeds from the stack (f5ced88)
662
663
664DOCUMENTATION FIXES
665 o Fix a mistake in evbuffer_remove() arguments in example http server code (c322c20 Gyepi Sam)
666 o Fix a typo in a comment in buffer.h. Spotted by Alt_F4 (773b0a5)
667
668
669
670Changes in version 2.0.21-stable (18 Nov 2012)
671BUGFIXES:
672 o ssl: Don't discard SSL read event when timeout and read come close together (576b29f)
673 o ssl: Stop looping in "consider_reading" if reading is suspended. (f719b8a Joachim Bauch)
674 o ssl: No need to reserve space if reading is suspended. (1acf2eb Joachim Bauch)
675 o dns: Avoid a memory-leak on OOM in evdns. (73e85dd, f2bff75 George Danchev)
676 o build: Use python2 rather than python (0eb0109 Ross Lagerwall)
677 o build: Compile without warnings on mingw64 (94866c2)
678 o build: Fix compilation on mingw64 with -DUSE_DEBUG (62bd2c4)
679 o build: Make rpcgen_wrapper.sh work on systems without a "python2" binary (f3009e4)
680 o iocp: Close IOCP listener socket on free when LEV_OPT_CLOSE_ON_FREE is set (cb853ea Juan Pablo Fernandez)
681 o core: Avoid crash when event_pending() called with no event_base set on event (e3cccf3)
682 o misc: remove stray 'x' so print_err will compile when uncommented (ac35650 Patrick Pelletier)
683 o tests: Fix renegotiation test to work around openssl 1.0.1 bug (c2f3086)
684 o tests: Warn when openssl version in unit test mismatches compiled version. (ac009f9)
685
686
687Changes in version 2.0.20-stable (23 Aug 2012)
688BUGFIXES:
689 o core: Make event_pending() threadsafe. (be7a95c Simon Liu)
690 o win32: avoid crash when waiting forever on zero fds. (160e58b)
691 o evhttp: Fix a memory leak on error in evhttp_uriencode (11c8b31)
692 o evbuffer: Avoid possible needless call to writev. Found by coverity. (6a4ec5c)
693 o evdns: memset sockaddr_in before using it. Found by coverity. (a1a0e67)
694 o evhttp: Check more setsockopt return values when binding sockets. Found by coverity (a0912e3)
695 o evdns: Avoid segfault on weird timeout during name lookup. (dc32077 Greg Hazel)
696 o bufferevent_ssl: Correctly invoke callbacks when a SSL bufferevent reads some and then blocks. (606ac43)
697
698
699PORTABILITY FIXES:
700 o check for arc4random_buf at runtime, on OS X (bff5f94 Greg Hazel)
701 o Correctly check for arc4random_buf (fcec3e8 Sebastian Hahn)
702 o Add explicit AC_PROG_SED to configure.in so all autoconfs will expose $(SED) (ca80ea6)
703
704BUILD FIXES:
705 o Add GCC annotations so that the vsprintf functions get checked properly (117e327)
706 o Fix an unused variable warning on *BSD. (c0720c1)
707
708UNIT TEST FIXES:
709 o Fix a couple of memory leaks (found with Valgrind). (3b2529a Ross Lagerwall)
710 o Remove deadcode in http regression tests. Found by coverity. (5553346)
711 o Fix possible uninitialized read in dns regression tests. Found by coverity. (2259777)
712 o Set umask before calling mkstemp in unit tests. Found by coverity (f1ce15d)
713 o Fix various check-after-dereference issues in unit tests: found by coverity (4f3732d)
714 o Fix resource leaks in the unit tests; found by coverity (270f279)
715 o Add some missing null checks to unit tests; found by coverity (f021c3d)
716 o Avoid more crashes/bad calls in unit tests; found by coverity (3cde5bf)
717 o Remove unused variable; spotted by coverity (6355b2a)
718 o Add checks to various return values in unit tests. Found by coverity (b9e7329)
719 o Move assignment outside tt_assert in ssl unit tests. Appeases coverity. (a2006c0)
720
721
722
723Changes in version 2.0.19-stable (3 May 2012)
724BUGFIXES (CORE):
725 o Refactor event_persist_closure: raise and extract some common logic (bec22b4)
726 o If time has jumped so we'd reschedule a periodic event in the past, schedule it for the future instead (dfd808c)
727 o If a higher-priority event becomes active, don't continue running events of the current priority. (2bfda40)
728
729BUGFIXES (SSL):
730 o Fixed potential double-readcb execution with openssl bufferevents. (4e62cd1 Mark Ellzey)
731
732BUGFIXES (DNS):
733 o Cancel a probe request when the server is freed, and ignore cancelled probe callbacks (94d2336 Greg Hazel)
734 o Remove redundant DNS_ERR_CANCEL check, move comment (46b8060 Greg Hazel)
735 o When retransmitting a timed-out DNS request, pick a fresh nameserver. (3d9e52a)
736
737DOCUMENTATION FIXES:
738 o Fix a typo in the bufferevent documentation (98e9119)
739 o Add missing ) to changelog; spotted by rransom (4c7ee6b)
740 o Fix the website URL in the readme (f775521)
741
742COMPILATION FIXES:
743 o Fix a compilation error with MSVC 2005 due to use of mode_t (336dcae)
744 o Configure with gcc older than 2.95 (4a6fd43 Sebastian Hahn)
745 o Generate event-config.h with a single sed script (30b6f88 Zack Weinberg)
746
747FORWARD-COMPATIBILITY:
748 o Backport: provide EVENT_LOG_* names, and deprecate _EVENT_LOG_* (d1a03b2)
749
750TESTING/DEBUGGING SUPPORT:
751 o dns-example.c can now take a resolv.conf file on the commandline (6610fa5)
752 o Make some evdns.c debug logs more verbose (d873d67)
753 o Work-around a stupid gcov-breaking bug in OSX 10.6 (b3887cd)
754
755
756
757Changes in version 2.0.18-stable (22 Mar 2012)
758BUGFIXES (core):
759 o Make uses of open() close-on-exec safe by introducing an internal evutil_open_closeonexec. (d2b5f72 Ross Lagerwall, 03dce42)
760
761BUGFIXES (kqueue):
762 o Properly zero the kevent in kq_setup_kevent() (c2c7b39 Sebastian Hahn)
763
764BUILD FIXES:
765 o Added OPENSSL_LDFLAGS env variable which is appended to SSL checks. (9278196 Mark Ellzey)
766 o Changed OPENSSL_LDFLAGS to OPENSSL_LIBADD (2d67b63 Mark Ellzey)
767 o Don't do clang version detection when disabling some flags (083296b Sebastian Hahn)
768
769BUGFIXES (dns):
770 o Stop crashing in evdns when nameserver probes give a weird error (bec5068)
771
772
773Changes in version 2.0.17-stable (10 Feb 2012)
774
775BUGFIXES (core):
776 o Be absolutely sure to clear pncalls before leaving event_signal_closure (11f36a5)
777 o check for sysctl before we use it (358c745 Mike Frysinger)
778 o Remove bogus casts of socket to int before calling ev_callback (f032516)
779 o Make evconnlistener work around bug in older Linux when getting nmapped (ecfc720)
780 o Fix a list corruption bug when using event_reinit() with signals present (6e41cdc)
781 o Fix a fd leak in event_reinit() (3f18ad1)
782 o Do a memberwise comparison of threading function tables (c94a5f2 Nate R)
783 o Use C-style comments in C source files (for compatibility with compilers such as xlc on AIX). (d84d917 Greg Hewgill)
784 o Avoid crash when freeing event_iocp and using event_set_mem_functions (19715a6)
785 o In the kqueue backend, do not report EBADF as an EV_READ (5d7bfa1 Nicholas Marriott)
786
787BUGFIXES (evbuffer and bufferevents):
788 o Fix behavior of evbuffer_peek(buf,-1,NULL,NULL,0) (c986f23 Zack Weinberg)
789 o Loop on filtering SSL reads until we are blocked or exhausted. (5b4b812)
790
791BUGFIXES (evhttp):
792 o Force strict validation of HTTP version in response. (790f6b3 Catalin Patulea)
793
794BUGFIXES (evdns):
795 o evdns: fix a bug in circular-queue implementation (d6094b1)
796
797BUILD FIXES:
798 o Fix a silly compilation error with the sun compiler (1927776 Colin Watt)
799 o Suppress a gcc warning from ignoring fwrite return in http-sample.c (7206e8c)
800
801DOCUMENTATION FIXES:
802 o Slightly clarify evbuffer_peek documentation (7bbf6ca)
803 o Update copyright notices to 2012 (e49e289)
804
805NEW APIS:
806 o Backport evhttp_connection_get_bufferevent to Libevent 2.0 (da70fa7 Arno Bakker)
807
808TESTS AND TEST FIXES:
809 o Fix a race condition in the dns/bufferevent_connect_hostname test. (cba48c7)
810 o Add function to check referential integrity of an event_base (27737d5)
811 o Check event_base correctness at end of each unit test (3312b02)
812 o Workaround in the unit tests for an apparent epoll bug in Linux 3.2 (dab9187)
813 o Better workaround for Linux 3.2 edge-triggered epoll bug (9f9e259)
814
815Changes in version 2.0.16-stable (18 Nov 2011)
816BUGFIXES (core):
817 o More detailed message in case of libevent self-debugging failure. (9e6a4ef Leonid Evdokimov)
818 o epoll: close fd on alloc fail at initialization (1aee718 Jamie Iles)
819 o Fix compile warning from saying event2/*.h inside a comment (447b0ba)
820 o Warn when unable to construct base because of failing make_base_notifiable (4e797f3)
821 o Don't try to make notifiable event_base when no threading fns are configured (e787413)
822
823BUGFIXES (evbuffer):
824 o unit test for remove_buffer bug (90bd620 Greg Hazel)
825 o Fix an evbuffer crash in evbuffer_remove_buffer() (c37069c)
826
827BUGFIXES (bufferevent_openssl):
828 o Refactor amount-to-read calculations in buffervent_ssl consider_reading() (a186e73 Mark Ellzey)
829 o Move SSL rate-limit enforcement into bytes_to_read() (96c562f)
830 o Avoid spinning on OpenSSL reads (2aa036f Mark Ellzey)
831
832BUGFIXES (dns)
833 o Empty DNS reply with OK status is another way to say NODATA. (21a08d6 Leonid Evdokimov)
834
835TESTING:
836 o Tests for 94fba5b and f72e8f6 (d58c15e Leonid Evdokimov)
837 o Test for commit aff6ba1 (f7841bf Leonid Evdokimov)
838 o Style and comment tweaks for dns/leak* tests (5e42202)
839 o improve test to remove at least one buffer from src (7eb52eb Greg Hazel)
840
841DOCUMENTATION:
842 o Add note about evhttp_send_reply_end to its doxygen (724bfb5)
843 o Update copyright dates to 2011. (3c824bd)
844 o Fix typo in whatsnew-2.0.txt (674bc6a Mansour Moufid)
845 o Improve win32 behavior of dns-sample.c code (a3f320e Gisle Vanem)
846
847
848
849Changes in version 2.0.15-stable (12 Oct 2011)
850BUGFIXES (DNS):
851 o DNS: add ttl for negative answers using RFC 2308 idea. (f72e8f6 Leonid Evdokimov)
852 o Add DNS_ERR_NODATA error code to handle empty replies. (94fba5b Leonid Evdokimov)
853
854BUFGIXES (bufferevents and evbuffers):
855 o Make evbuffer callbacks get the right n_added value after evbuffer_add (1ef1f68 Alex)
856 o Prefer mmap to sendfile unless a DRAINS_TO_FD flag is set. Allows add_file to work with SSL. (0ba0af9)
857
858BUGFIXES (event loop):
859 o When a signal callback is activated to run multiple times, allow event_base_loopbreak to work even before they all have run. (4e8eb6a)
860
861DOCUMENTATION FIXES:
862 o Fix docstring in dns.h (2b6eae5 Leonid Evdokimov)
863 o refer to non-deprecated evdns functions in comments (ba5c27d Greg Hazel)
864
865BUILD AND TESTING FIXES:
866 o le-proxy and regress depend on openssl directly (9ae061a Sergey Avseyev)
867 o Use _SOURCES, not _sources, in sample/Makefile.am (7f82382)
868 o Fixed compiler warnings for unchecked read/write calls. (c3b62fd Mark Ellzey)
869 o Make write-checking fixes use tt_fail_perror (2b76847)
870 o Fix some "value never used" warnings with gcc 4.6.1 (39c0cf7)
871
872
873
874Changes in version 2.0.14-stable (31 Aug 2011)
875BUGFIXES (bufferevents and evbuffers):
876 o Propagate errors on the underlying bufferevent to the user. (4a34394 Joachim Bauch)
877 o Ignore OpenSSL deprecation warnings on OS X (5d1b255 Sebastian Hahn)
878 o Fix handling of group rate limits under 64 bytes of burst (6d5440e)
879 o Solaris sendfile: correctly detect amount of data sent (643922e Michael Herf)
880 o Make rate limiting work with common_timeout logic (5b18f13)
881 o clear read watermark on underlying bufferevent when creating filtering bev to fix potentially failing fragmented ssl handshakes (54f7e61 Joachim Bauch)
882
883BUGFIXES (IOCP):
884 o IOCP: don't launch reads or writes on an unconnected socket (495c227)
885 o Make IOCP rate-limiting group support stricter and less surprising. (a98da7b)
886 o Have test-ratelim.c support IOCP (0ff2c5a)
887 o Make overlapped reads result in evbuffer callbacks getting invoked (6acfbdd)
888 o Correctly terminate IO on an async bufferevent on bufferevent_free (e6af35d)
889
890BUGFIXES (other):
891 o Fix evsig_dealloc memory leak with debugging turned on. (9b724b2 Leonid Evdokimov)
892 o Fix request_finished memory leak with debugging turned on. (aff6ba1 Leonid Evdokimov)
893
894BUILD AND TESTING FIXES:
895 o Allow OS-neutral builds for platforms where some versions have arc4random_buf (b442302 Mitchell Livingston)
896 o Try to fix 'make distcheck' errors when building out-of-tree (04656ea Dave Hart)
897 o Clean up some problems identified by Coverity. (7c11e51 Harlan Stenn)
898
899
900Changes in version 2.0.13-stable (18 Jul 2011)
901BUGFIXES
902 o Avoid race-condition when initializing global locks (b683cae)
903 o Fix bug in SSL bufferevents backed by a bev with a write high-watermarks (e050703 Joachim Bauch)
904 o Speed up invoke_callbacks on evbuffers when there are no callbacks (f87f568 Mark Ellzey)
905 o Avoid a segfault when all methods are disabled or broken (27ce38b)
906 o Fix incorrect results from evbuffer_search_eol(EOL_LF) (4461f1a)
907 o Add some missing checks for mm_calloc failures (89d5e09)
908 o Replace an assertion for event_base_free(NULL) with a check-and-warn (09fe97d)
909 o Report kqueue ebadf, epipe, and eperm as EV_READ events (1fd34ab)
910 o Check if the `evhttp_new_object' function in `http.c' returns NULL. (446cc7a Mansour Moufid)
911 o Use the correct printf args when formatting size_t (3203f88)
912 o Complain if the caller tries to change threading cbs after setting them (cb6ecee)
913
914DOCUMENTATION FIXES AND IMPROVEMENTS
915 o Revise the event/evbuffer/bufferevent doxygen for clarity and accuracy (2888fac)
916 o Update Doxyfile to produce more useful output (aea0555)
917
918TEST FIXES
919 o Fix up test_evutil_snprintf (caf695a)
920 o Fix tinytest invocation from windows shell (57def34 Ed Day)
921
922BUILD FIXES
923 o Use AM_CPPFLAGS in sample/Makefile.am, not AM_CFLAGS (4a5c82d)
924 o Fix select.c compilation on systems with no NFDBITS (49d1136)
925 o Fix a few warnings on OpenBSD (8ee9f9c Nicholas Marriott)
926 o Don't break when building tests from git without python installed (b031adf)
927 o Don't install event_rpcgen.py when --disable-libevent-install is used (e23cda3 Harlan Stenn)
928 o Fix AIX build issue with TAILQ_FOREACH definition (e934096)
929
930
931Changes in version 2.0.12-stable (4 Jun 2011)
932BUGFIXES
933 o Fix a warn-and-fail bug in kqueue by providing kevent() room to report errors (28317a0)
934 o Fix an assert-inducing fencepost bug in the select backend (d90149d)
935 o Fix failing http assertion introducd in commit 0d6622e (0848814 Kevin Ko)
936 o Fix a bug that prevented us from configuring IPv6 nameservers. (74760f1)
937 o Prevent size_t overflow in evhttp_htmlescape. (06c51cd Mansour Moufid)
938 o Added several checks for under/overflow conditions in evhttp_handle_chunked_read (a279272 Mark Ellzey)
939 o Added overflow checks in evhttp_read_body and evhttp_get_body (84560fc Mark Ellzey)
940
941DOCUMENTATION:
942 o Add missing words to EVLOOP_NONBLOCK documentation (9556a7d)
943
944BUILD FIXES
945 o libssl depends on libcrypto, not the other way around. (274dd03 Peter Rosin)
946 o Libtool brings in the dependencies of libevent_openssl.la automatically (7b819f2 Peter Rosin)
947 o Use OPENSSL_LIBS in Makefile.am (292092e Sebastian Hahn)
948 o Move the win32 detection in configure.in (ceb03b9 Sebastian Hahn)
949 o Correctly detect openssl on windows (6619385 Sebastian Hahn)
950 o Fix a compile warning with zlib 1.2.4 and 1.2.5 (5786b91 Sebastian Hahn)
951 o Fix compilation with GCC 2, which had no __builtin_expect (09d39a1 Dave Hart)
952 o Fix new warnings from GCC 4.6 (06a714f)
953 o Link with -lshell32 and -ladvapi32 on Win32. (86090ee Peter Rosin)
954 o Make the tests build when OpenSSL is not available. (07c41be Peter Rosin)
955 o Bring in the compile script from automake, if needed. (f3c7a4c Peter Rosin)
956 o MSVC does not provide S_ISDIR, so provide it manually. (70be7d1 Peter Rosin)
957 o unistd.h and sys/time.h might not exist. (fe93022 Peter Rosin)
958 o Make sure TINYTEST_LOCAL is defined when building tinytest.c (8fa030c Peter Rosin)
959 o Fix winsock2.h #include issues with MSVC (3d768dc Peter Rosin)
960 o Use evutil_gettimeofday instead of relying on the system gettimeofday. (0de87fe Peter Rosin)
961 o Always use evutil_snprintf, even if OS provides it (d1b2d11 Sebastian Hahn)
962 o InitializeCriticalSectionAndSpinCount requires _WIN32_WINNT >= 0x0403. (816115a Peter Rosin)
963 o cygwin: make it possible to build DLLs (d54d3fc)
964
965
966
967Changes in version 2.0.11-stable (27 Apr 2011)
968  [Autogenerated from the Git log, sorted and cleaned by hand.]
969BUGFIXES:
970 o Fix evport handling of POLLHUP and POLLERR (b42ce4b)
971 o Fix compilation on Windows with NDEBUG (cb8059d)
972 o Check for POLLERR, POLLHUP and POLLNVAL for Solaris event ports (0144886 Trond Norbye)
973 o Detect and handle more allocation failures. (666b096 Jardel Weyrich)
974 o Use event_err() only if the failure is truly unrecoverable. (3f8d22a Jardel Weyrich)
975 o Handle resize failures in the select backend better. (83e805a)
976 o Correctly free selectop fields when select_resize fails in select_init (0c0ec0b)
977 o Make --enable-gcc-warnings a no-op if not using gcc (3267703)
978 o Fix a type error in our (unused) arc4random_stir() (f736198)
979 o Correctly detect and stop non-chunked http requests when the body is too long (63a715e)
980 o Have event_base_gettimeofday_cached() always return wall-clock time (a459ef7)
981 o Workaround for http crash bug 3078187 (5dc5662 Tomash Brechko)
982 o Fix incorrect assertions and possible use-after-free in evrpc_free() (4b8f02f Christophe Fillot)
983 o Reset outgoing http connection when read data in idle state. (272823f Tomash Brechko)
984 o Fix subtle recursion in evhttp_connection_cb_cleanup(). (218cf19 Tomash Brechko)
985 o Fix the case when failed evhttp_make_request() leaved request in the queue. (0d6622e Tomash Brechko)
986 o Fix a crash bug in evdns server circular list code (00e91b3)
987 o Handle calloc failure in evdns. (Found by Dave Hart) (364291e)
988 o Fix a memory leak on win32 socket->event map. (b4f89f0)
989 o Add a forgotten NULL check to evhttp_parse_headers (12311ff Sebastian Hahn)
990 o Fix possible NULL-deref in evdns_cancel_request (5208544 Sebastian Hahn)
991
992PORTABILITY:
993 o Fall back to sscanf if we have no other way to implement strtoll (453317b)
994 o Build correctly on platforms without sockaddr_storage (9184563)
995 o Try to build correctly on platforms with no IPv6 support (713c254)
996 o Build on systems without AI_PASSIVE (cb92113)
997 o Fix http unit test on non-windows platforms without getaddrinfo (6092f12)
998 o Do not check for gethostbyname_r versions if we have getaddrinfo (c1260b0)
999 o Include arpa/inet.h as needed on HPUX (10c834c Harlan Stenn)
1000 o Include util-internal.h as needed to build on platforms with no sockaddr_storage (bbf5515 Harlan Stenn)
1001 o Check for getservbyname even if not on win32. (af08a94 Harlan Stenn)
1002 o Add -D_OSF_SOURCE to fix hpux builds (0b33479 Harlan Stenn)
1003 o Check for allocation failures in apply_socktype_protocol_hack (637d17a)
1004 o Fix the check for multicast or broadcast addresses in evutil_check_interfaces (1a21d7b)
1005 o Avoid a free(NULL) if out-of-memory in evdns_getaddrinfo. Found by Dave Hart (3417f68)
1006
1007DEFENSIVE PROGRAMMING:
1008 o Add compile-time check for AF_UNSPEC==PF_UNSPEC (3c8f4e7)
1009
1010BUGS IN TESTS:
1011 o Fix test.sh output on solaris (b4f89b6 Dave Hart)
1012 o Make test-eof fail with a timeout if we never get an eof. (05a2c22 Harlan Stenn)
1013 o Use %s with printf in test.sh (039b9bd)
1014 o Add an assert to appease clang's static analyzer (b0ff7eb Sebastian Hahn)
1015 o Add a forgotten return value check in the unit tests (3819b62 Sebastian Hahn)
1016 o Actually send NULL request in http_bad_request_test (b693c32 Sebastian Hahn)
1017 o add some (void) casts for unused variables (65707d7 Sebastian Hahn)
1018 o Refactor test_getaddrinfo_async_cancel_stress() (48c44a6 Sebastian Hahn)
1019 o Be nice and "handle" error return values in sample code (4bac793 Sebastian Hahn)
1020 o Check return value of evbuffer_add_cb in tests (93a1abb Sebastian Hahn)
1021 o Remote some dead code from dns-example.c (744c745 Sebastian Hahn)
1022 o Zero a struct sockaddr_in before using it (646f9fe Sebastian Hahn)
1023
1024BUILD FIXES:
1025 o Fix warnings about AC_LANG_PROGRAM usage (f663112 Sebastian Hahn)
1026 o Skip check for zlib if we have no zlib.h (a317c06 Harlan Stenn)
1027 o Fix autoconf bracket issues; make check for getaddrinfo include netdb.h (833e5e9 Harlan Stenn)
1028 o Correct an AM_CFLAGS to an AM_CPPFLAGS in test/Makefile.am (9c469db Dave Hart)
1029 o Fix make distcheck & installation of libevent 1 headers (b5a1f9f Dave Hart)
1030 o Fix compilation under LLVM/clang with --enable-gcc-warnings (ad9ff58 Sebastian Hahn)
1031
1032FEATURES:
1033 o Make URI parser able to tolerate nonconformant URIs. (95060b5)
1034
1035DOCUMENTATION:
1036 o Clarify event_set_mem_functions doc (926f816)
1037 o Correct evhttp_del_accept_socket documentation on whether socket is closed (f665924)
1038 o fix spelling mistake in whatsnew-2.0.txt (deb2f73)
1039 o Fix sample/http-server ipv6 fixes (eb692be)
1040 o Comment internal headers used in sample code. (4eb281c)
1041 o Be explicit about how long event loops run in event.h documentation (f95bafb)
1042 o Add comment to configure.in to explain gc-sections test logic (c621359)
1043 o Fix a couple of memory leaks in samples/http-server.c. Found by Dave Hart. (2e9f665)
1044
1045
1046
1047BUILD IMPROVEMENTS:
1048 Libevent 2.1.2-alpha modernizes Libevent's use of autotools, and makes
1049 numerous other build system. Parallel builds should be faster, and all
1050 builds should be quieter.
1051
1052   o Split long lists in Makefile.am into one-item-per-line (2711cda)
1053   o Remove unnecessary code in configure.in. (e65914f Ross Lagerwall)
1054   o attempt to support OpenSSL in Makefile.nmake (eba0eb2 Patrick Pelletier)
1055   o Use newer syntax for autoconf/automake init (7d60ba8)
1056   o Enable silent build rules by default. Override with V=1 (7b18e5c)
1057   o Switch to non-recursive makefiles (7092f3b)
1058   o Rename subordinate Makefile.ams to include.am (6cdfeeb)
1059   o Make quiet build even quieter (371a123)
1060   o New --quiet option for event_rpcgen.py (aa59c1e)
1061   o Be quiet when making regress.gen.[ch] (607a8ff)
1062   o Fix handling of no-python case for nonrecursive make (1e3123d)
1063   o We now require automake 1.9 or later. Modernize! (b7f6e89)
1064   o Rename configure.in to configure.ac. (b3fea67 Ross Lagerwall)
1065   o Use correct openssl libs and includes in pkgconfig file (d70af27)
1066   o Use the same CFLAGS for openssl when building unit tests as with
1067     libevent (1d9d511)
1068
1069DOCUMENTATION
1070   o Note that make_base_notifiable should not be necessary (26ee5f9)
1071   o Be more clear that LEV_OPT_DEFERRED_ACCEPT has tricky prereqs (371efeb)
1072   o Add caveat to docs about bufferevent_free() with data in outbuf (6fab9ee)
1073   o Make it more clear that NOLOCK means "I promise, no multithreading"
1074    (9444524)
1075   o Fix a comment in test-fdleak after 077c7e949. (3881d8f Ross Lagerwall)
1076   o Make the Makefile.nmake warning slightly less dire (e7bf4c8)
1077   o Fix typo : events instead of evets (05f1aca Azat Khuzhin)
1078   o Additional comments about OPENSSL_DIR variable, prompted by Dave Hart
1079     (6bde2ef Patrick Pelletier)
1080
1081EVHTTP:
1082   o ignore LWS after field-content in headers (370a2c0 Artem Germanov)
1083   o Clean up rtrim implementation (aa59d80)
1084   o Remove trailing tabs in HTTP headers as well. (ac42519)
1085   o Remove internal ws from multiline http headers correctly (c6ff381)
1086   o Move evutil_rtrim_lws_ to evutil.c where it belongs (61b93af)
1087   o add evhttp_request_get_response_code_line (4f4d0c9 Jay R. Wren)
1088   o Use EVUTIL_SOCKET_ERROR() wrapper to save/restore errno in
1089     evhttp_connection_fail_ (7afbd60)
1090   o preserve errno in evhttp_connection_fail_ for inspection by the
1091     callback (36d0ee5 Patrick Pelletier)
1092
1093BUGFIXES:
1094   o Correctly handle running on a system where accept4 doesn't work. (9fbfe9b)
1095   o Avoid double-free on error in evbuffer_add_file. Found by
1096     coverity. (6a81b1f)
1097   o Fix another possible uninitialized read in dns regression tests. Found
1098     by coverity. (13525c5)
1099   o Add checks for functions in test-ratelim.c; found by Coverity (aa501e1)
1100   o Avoid memory leak in test_event_calloc unit test; found by coverity
1101     (92817a1)
1102   o Fix a shadowed variable in addfile_test_readcb; found by coverity
1103     (225344c)
1104   o Check return value when using LEV_OPT_DEFERRED_ACCEPT. Found by
1105     coverity (6487f63)
1106   o Prevent reference leak of bufferevent if getaddrinfo fails. (b757786
1107     Joachim Bauch)
1108   o Make event_base_getnpriorities work with old "implicit base" code
1109     (c46cb9c)
1110   o Simplify and correct evutil_open_closeonexec_ (0de587f)
1111   o Fix event_dlist definition when sys/queue not included (81b6209
1112     Derrick Pallas)
1113
1114
1115
1116Changes in version 2.1.1-alpha (4 Apr 2012)
1117
1118 Libevent 2.1.1-alpha includes a number of new features and performance
1119 improvements.  The log below tries to organize them by rough area of
1120 effect.  It omits some commits which were pure bugfixes on other commits
1121 listed below.  For more detail, see the git changelogs.  For more
1122 insight, see the "whatsnew-2.1.txt" document included in the Libevent
1123 2.1.1-alpha distribution.
1124
1125 Performance: Core
1126   o Replace several TAILQ users with LIST. LIST can be a little faster than
1127     TAILQ for cases where we don't need queue-like behavior. (f9db33d,
1128     6494772, d313c29, 974d004)
1129   o Disabled code to optimize the case where we reinsert an existing
1130     timeout (e47042f, 09cbc3d)
1131   o Remove a needless base-notify when rescheduling the first timeout (77a96fd)
1132   o Save a needless comparison when removing/adjusting timeouts (dd5189b)
1133   o Possible optimization: split event_queue_insert/remove into
1134     separate functions. needs testing (efc4dc5)
1135   o Make event_count maintenance branchless at the expense of an
1136     extra shift. Needs benchmarking (d1cee3b)
1137   o In the 2.1 branch, let's try out lazy gettimeofday/clock_gettime
1138     comparison (2a83ecc)
1139   o Optimization in event_process_active(): ignore maxcb & endtime
1140     for highest priority events. (a9866aa Alexander Drozdov)
1141   o Bypass event_add when using event_base_once() for a 0-sec timeout (35c5c95)
1142   o Remove the eventqueue list and the ev_next pointers. (604569b 066775e)
1143
1144 Performance: Evbuffers
1145   o Roughly 20% speed increase when line-draining a buffer using
1146     EVBUFFER_EOL_CRLF (5dde0f0 Mina Naguib)
1147   o Try to squeeze a little more speed out of EVBUFFER_EOL_CRLF (7b9d139)
1148   o Fix a bug in the improved EOL_CRLF code (d927965)
1149   o Remove a needless branch in evbuffer_drain() (d19a326)
1150
1151 Performance: Linux
1152   o Infrastructure for using faster/fewer syscalls when creating
1153     sockets (a1c042b)
1154   o Minimize syscalls during socket creation in listener.c (7e9e289)
1155   o Use a wrapper function to create the notification
1156     pipe/socketpair/eventfd (ca76cd9)
1157   o Use pipes for telling signals to main thread when possible (a35f396)
1158   o Save syscalls when constructing listener sockets for evhttp (af6c9d8)
1159   o Save some syscalls when creating evdns sockets (713e570)
1160   o Save some syscalls when constructing a socket for a bufferevent (33fca62)
1161   o Prefer epoll_create1 on Linuxen that have it (bac906c)
1162
1163 Performance: Epoll backend
1164   o Use current event set rather than current pending change when
1165     deciding whether to no-op a del (04ba27e Mike Smellie)
1166   o Replace big chain of if/thens in epoll.c with a table lookup (8c83eb6)
1167   o Clean up error handling in epoll_apply_one_change() a little (2d55a19)
1168
1169 Performance: Evport backend
1170   o evport: use evmap_io to track fdinfo status. Should save time and
1171     RAM. (4687ce4)
1172   o evport: Remove a linear search over recent events when
1173     reactivating them (0f77efe)
1174   o evport: Use portev_user to remember fdinfo struct (276ec0e)
1175   o evport: don't scan more events in ed_pending than needed (849a5cf)
1176   o evport: Remove artificial low limit on max events per getn call (c04d927)
1177   o Reenable main/many_events_slow_add for evport in 2.1 (e903db3)
1178
1179 Performance: Windows
1180   o Use GetSystemTimeAsFileTime to implement gettimeofday on
1181     win32. It's faster and more accurate than our old
1182     approach. (b8b8aa5)
1183
1184 New functions and features: debugging
1185   o Add event_enable_debug_logging() to control use of debug logs (e30a82f)
1186
1187 New functions and features: core
1188   o Add event_config function to limit time/callbacks between calls
1189     to dispatch (fd4de1e, 9fa56bd, a37a0c0, 3c63edd)
1190   o New EVLOOP_NO_EXIT_ON_EMPTY option to keep looping even when no
1191     events are pending (084e68f)
1192   o Add event_base_get_npriorities() function. (ee3a4ee Alexander Drozdov)
1193   o Make evbase_priority_init() and evbase_get_npriorities()
1194     threadsafe (3c55b5e)
1195   o New event_base_update_cache_time() to set cached_tv to current
1196     time (212533e Abel Mathew)
1197   o Add event_self_cbarg() to be used in conjunction with
1198     event_new(). (ed36e6a Ross Lagerwall, fa931bb, 09a1906, 1338e6c,
1199     33e43ef)
1200   o Add a new libevent_global_shutdown() to free all globals before
1201     exiting. (041ca00 Mark Ellzey, f98c158, 15296d0, 55e991b)
1202   o Use getifaddrs to detect our interfaces if possible (7085a45)
1203   o Add event_base_get_running_event() to get the event* whose cb we
1204     are in (c5732fd, 13dad99)
1205
1206 New functions and features: building
1207   o Implement --enable-gcc-hardening configure option (7550267 Sebastian Hahn)
1208
1209 New functions and features: evbuffers
1210   o Add evbuffer_add_file_segment() so one fd can be used efficiently
1211     in more than one evbuffer_add_file at a time (e72afae, c2d9884,
1212     3f405d2, 0aad014)
1213   o Fix windows file segment mappings (8254de7)
1214   o Allow evbuffer_ptr_set to yield a point just after the end of the
1215     buffer. (e6fe1da)
1216   o Allow evbuffer_ptr to point to position 0 in an empty evbuffer
1217     (7aeb2fd Nir Soffer)
1218   o Set the special "not found" evbuffer_ptr consistently. (e3e97ae Nir Soffer)
1219   o support adding buffers to other buffers non-destructively
1220     (9d7368a Joachim Bauch)
1221   o prevent nested multicast references, reworked locking (26041a8
1222     Joachim Bauch)
1223   o New EVBUFFER_EOL_NUL to read NUL-terminated strings from an
1224     evbuffer (d7a8b36 Andrea Montefusco, 54142c9)
1225   o Make evbuffer_file_segment_types adaptable (c6bbbf1)
1226   o Added evbuffer_add_iovec and unit tests. (aaec5ac Mark Ellzey, 27b5398)
1227   o Add evbuffer_copyout_from to copy data from the middle of a
1228     buffer (27e2225)
1229
1230 New functions and features: bufferevents
1231   o Allow users to set allow_dirty_shutdown (099d27d Catalin Patulea)
1232   o Tweak allow_dirty_shutdown documentation (a44cd2b)
1233   o Fix two issues in the allow_dirty_shutdown code. (f3b89de)
1234   o Add a bufferevent_getcb() to find a bufferevent's current
1235     callbacks (a650394)
1236   o bufferevent: Add functions to set/get max_single_read/write
1237     values. (998c813 Alexander Drozdov)
1238   o bev_ssl: Be more specific in event callbacks. evhttp in particular gets
1239     confused without at least one of BEV_EVENT_{READING|WRITING}. (f7eb69a
1240     Catalin Patulea)
1241
1242 New functions and features: evconnlisteners
1243   o Support TCP_DEFER_ACCEPT sockopts for listeners (5880e4a Mark Ellzey,
1244     a270728)
1245   o Add another caveat to the TCP_DEFER_ACCEPT documentation (a270728)
1246   o Allow evconnlistener to be created in disabled state. (9593a33
1247     Alexander Drozdov)
1248   o The LEV_OPT_CLOSE_ON_EXEC flag now applies to accepted listener
1249     sockets too (4970329)
1250
1251 Evhttp:
1252   o Add new evhttp_{connection_}set_timeout_tv() functions to set
1253     finger-grained http timeouts (6350e6c Constantine Verutin)
1254   o Performance tweak to evhttp_parse_request_line. (aee1a97 Mark Ellzey)
1255   o Add missing break to evhttp_parse_request_line (0fcc536)
1256   o Add evhttp callback for bufferevent creation; this lets evhttp
1257     support SSL. (8d3a850)
1258   o Remove calls to deprecated bufferevent functions from evhttp.c (4d63758)
1259   o evhttp: Add evhttp_foreach_bound_socket. (a2c48e3 Samy Al Bahra)
1260
1261 Build improvements:
1262   o Add AC_USE_SYSTEM_EXTENSIONS to configure.in. Requires follow on
1263     patches for correctness and robustness. (1fa7dbe Kevin Bowling)
1264   o Filter '# define' statements from autoconf and generate
1265     event-private.h (321b558 Kevin Bowling)
1266   o Remove internal usage of _GNU_SOURCE (3b26541 Kevin Bowling)
1267   o Eliminate a couple more manual internal _GNU_SOURCE defines (c51ef93
1268     Kevin Bowling)
1269   o Add AC_GNU_SOURCE to the fallback case. (ea8fa4c Kevin Bowling)
1270   o Use a Configuration Header Template for evconfig-private.h (868f888
1271     Kevin Bowling)
1272   o Fix a comment warning and add evconfig-private.h to .gitignore
1273     (f6d66bc Kevin Bowling)
1274   o Include evconfig-private.h in internal files for great good. (0915ca0
1275     Kevin Bowling)
1276   o Backport libevent to vanilla Autoconf 2.59 (as used in RHEL5)
1277     (ad03952 Kevin Bowling)
1278   o Prefer the ./configure evconfig-private.h in MinGW, just in
1279     case. (f964b72 Kevin Bowling)
1280   o Shell hack for weird mkdir -p commands (fd7b5a8 Kevin Bowling)
1281   o Add evconfig-private to remaining files (ded0a09 Kevin Bowling)
1282   o Allow use of --enable-silent-rules for quieter compilation with
1283     automake 1.11 (f1f8514 Dave Hart)
1284   o Use "_WIN32", not WIN32: it's standard and we don't need to fake it
1285     (9f560b)
1286   o In configure, test for _WIN32 not WIN32. (85078b1 Peter Rosin)
1287   o Do not define WIN32 in Makefile.nmake (d41f3ea Peter Rosin)
1288   o Provide the autoconf m4 macros for the new OpenSSL via pkg-config
1289     stuff. (674dc3d Harlan Stenn)
1290   o Use pkg-config (if available) to handle OpenSSL. (1c63860 Harlan Stenn)
1291   o We need AM_CPPFLAGS when compiling bufferevent_openssl.c (6d2613b
1292     Harlan Stenn)
1293   o Fix OSX build: $(OPENSSL_INCS) needs to be after
1294     $(AM_CPPFLAGS). (46f1769 Zack Weinberg)
1295   o Make gcc warnings on by default, and --enable-gcc-warnings only add
1296     -Werror (d46517e Sebastian Hahn)
1297   o Split up extra-long AC_CHECK_FUNCS/HEADERS lines in configure.in (88a30ad)
1298   o Move libevent 1.x headers to include/, to put all public headers in
1299     one place. (bbea8d6)
1300   o Put #ifdef around some files to support alternate build
1301     systems. (76d4c92 Ross Lagerwall)
1302   o Also make win32select.c conditional for IDE users (bf2c5a7)
1303
1304 Debugging:
1305   o Add a magic number to debug_locks to better catch lock-coding
1306     errors. (b4a29c0 Dave Hart)
1307   o munge the debug_lock signature before freeing it: it might help us
1308     catch use-after-free (f28084d)
1309   o Added --enable-event-debugging in configure (bc7b4e4, a9c2c9a Mark Ellzey)
1310   o Debug addition for printing usec on TIMEOUT debugging. (ac43ce0 Mark Ellzey)
1311   o Added usec debug in another area for debug (3baab0d Mark Ellzey)
1312   o added timeout debug logs to include event ptr. (4b7d298 Mark Ellzey)
1313   o more event dbg updates (6727543 Mark Ellzey)
1314   o Clarify event_enable_debug_logging a little (6207826)
1315   o Make --enable-verbose-debug option match its help text (10c3450)
1316   o Add argument checks to some memory functions in `event.c'. (c8953d1
1317     Mansour Moufid)
1318
1319 Testing:
1320   o More abstraction in test.sh (cd74c4e)
1321   o Add failing test for evbuffer_search_range. (8e26154 Nir Soffer)
1322   o Tweaks to return types with end-of-buf ptrs (9ab8ab8)
1323   o Add an (internal) usleep function for use by unit tests (f25d9d3)
1324   o Synchronize with upstream tinytest (6c81be7)
1325   o Make test-changelist faster (7622d26)
1326   o Reduce the timeout in the main/fork test. (ab14f7c)
1327   o New evhttp function to adjust initial retry timeout (350a3c4)
1328   o Make regression tests run over 3x faster. (67a1763)
1329   o Use test_timeval_diff_eq more consistently (b77b43f)
1330   o Allow more slop in deferred_cb_skew test; freebsd needs it (b9f7e5f)
1331   o When including an -internal.h header outside the main tree, do so
1332     early (95e2455)
1333   o Add a new test: test-fdleak which tests for fd leaks by creating many
1334     sockets. (2ef9278 Ross Lagerwall, f7af194, 1c4288f, etc)
1335   o Add a unit test for event_base_dump_events() (7afe48a, 8d08cce)
1336   o Test more bufferevent_ratelim features (c24f91a)
1337
1338 Documentation:
1339   o Improve evbuffer_ptr documentation (261ba63)
1340   o added comments to describe refcounting of multicast chains (ba24f61
1341     Joachim Bauch)
1342   o Add doxygen for event_base_dump_events (cad5753)
1343
1344 OSX:
1345   o Use "unlimited select" on OSX so that we can have more than
1346     FD_SETSIZE fds (1fb5cc6)
1347
1348 KQueue:
1349   o Use SIG_IGN instead of a do-nothing handler for signal events with
1350     kqueue (148458e Zack Weinberg)
1351
1352 evprc:
1353   o event_rpcgen.py now prints status information to stdout and errors to
1354     stderr. (ffb0ba0 Ross Lagerwall)
1355
1356 Code improvement and refactoring:
1357   o Make event_reinit() more robust and maintainable (272033e)
1358   o Restore fast-path event_reinit() for slower backends (2c4b5de)
1359   o Check changelist as part of checking representational integrity (39b3f38)
1360   o Fix a compile warning in event_reinit (e4a56ed Sebastian Hahn)
1361   o Refactor the functions that run over every event. (c89b4e6)
1362   o Remove the last vestiges of _EVENT_USE_EVENTLIST (a3cec90)
1363   o Make event-config.h depend on Makefile.am (2958a5c)
1364
1365 Build fixes:
1366   o Don't do clang version detection when disabling some flags (083296b
1367     Sebastian Hahn)
1368
1369 C standards conformance:
1370   o Check for NULL return on win32 mm_calloc, and set ENOMEM. (af7ba69)
1371   o Convert event-config.h macros to avoid reserved identifiers (68120d9)
1372   o Generate event-config.h using the correct macros. (f82c57e)
1373   o Convert include-guard macro convention to avoid reserved identifiers
1374     (3f8c7cd)
1375   o Make event_rpcgen.py output conform to identifier conventions (372bff1)
1376   o Stop referring to an obsolete include guard in bench_http.h (5c0f7e0)
1377   o Make the generated event-config.h use correct include guards (639383a)
1378   o Fix all identifiers with names beginning with underscore. (cb9da0b)
1379   o Make event_rpcgen.py output conform to identifier conventions, more
1380     (bcefd24)
1381   o Fix some problems introduced by automated identifier cleanup script
1382     (c963534)
1383   o Have all visible internal function names end with an underscore. (8ac3c4c)
1384   o Apply the naming convention to our EVUTIL_IS* functions (c7848fa)
1385   o Clean up lingering _identifiers. (946b584)
1386   o Fix doxygen to use new macro conventions (da455e9)
1387
1388 Bugfixes:
1389   o Do not use system EAI/AI values if we are not using the system
1390     getaddrinfo. (7bcac07)
1391
1392 Sample Code:
1393   o Fix up sample/event-test.c to use newer interfaces and make it
1394     actually work. (19bab4f Ross Lagerwall)
1395   o On Unix, remove event.fifo left by sample/event-test.c. (c0dacd2 Ross
1396     Lagerwall)
1397   o Rename event-test.c to event-read-fifo.c. (a5b370a Ross Lagerwall)
1398   o event-read-fifo: Use EV_PERSIST appropriately (24dab0b)
1399
1400
1401
1402
1403