chiark / gitweb /
SECURITY: Do not hang, eating CPU, if we encounter a compression pointer loop
[adns.git] / changelog
1 adns (1.5.2~) UPSTREAM; urgency=medium
2
3   * 
4
5  --
6
7 adns (1.5.1) UPSTREAM; urgency=medium
8
9   * Portability fix for systems where socklen_t is bigger than int.
10   * Fix for malicious optimisation of memcpy in test suite, which
11     causes failure with gcc-4.1.9 -O3.  See Debian bug #772718.
12   * Fix TCP async connect handling.  The bug is hidden on Linux and on most
13     systems where the nameserver is on localhost.  If it is not hidden,
14     adns's TCP support is broken unless adns_if_noautosys is used.
15   * Fix addr queries (including subqueries, ie including deferencing MX
16     lookups etc.) not to crash when one of the address queries returns
17     tempfail.  Also, do not return a spurious pointer to the application
18     when one of the address queries returns a permanent error (although,
19     the application almost certainly won't use this pointer because the
20     associated count is zero).
21   * adnsresfilter: Fix addrtextbuf buffer size.  This is not actually a
22     problem in real compiled code but should be corrected.
23   * Properly include harness.h in adnstest.c in regress/.  Suppresses
24     a couple of compiler warnings (implicit declaration of Texit, etc.)
25
26  -- Ian Jackson <ijackson@chiark.greenend.org.uk>  Fri, 12 Aug 2016 22:53:59 +0100
27
28 adns (1.5.0) UPSTREAM; urgency=low
29
30   * Release 1.5.0.  No changes since 1.5.0~rc1.
31
32  -- Ian Jackson <ijackson@chiark.greenend.org.uk>  Sun, 26 Oct 2014 14:57:10 +0000
33
34 adns (1.5.0~rc1) UPSTREAM; urgency=low
35
36   ABI/API changes:
37   * Provide adns_qf_cname_strict flag, currently ignored because it's the
38     default.  This will allow us to make this not the default in the future
39     while retaining forward and backward API and ABI compatibility.
40   * Add `sizeforce' enum member value to force enum types in the APIs to be
41     big (which will avoids theoretical future ABI-incompatibility).
42   * Reject unknown flags passed by our caller.  This will make it ABI-safe
43     (although not ABI-backward-compatible) to add new flags in the future,
44     as newer clients running against this old library will get ENOSYS.
45
46   resolv.conf parsing:
47   * Support `adns_ignoreunkcfg' resolv.conf option to ignore unknown
48     options and keywords in resolv.conf.
49   * Ignore various BIND9 resolv.conf keywords and options.
50   * Fix resolv.conf option word splitting.
51
52   Tests, build system, coding style, etc.:
53   * Test cases show rrtype flag values in hex.
54   * Parallelise `make check'.
55   * Make vbuf__append_quoted1035 no longer extern (there are no out-of-file
56     callers).
57   * Remove all RCSids.
58   * When releasing, check that the `make dist' tarball is identical to git.
59     And provide a test mode for the RELEASE-CHECKLIST doc/script.
60   * Add `make dist' tarball signature to .gitignore.
61   * More correctly and effectively work around bugs in make (Debian #4073,
62     #756123) affecting regress.
63
64  -- Ian Jackson <ijackson@chiark.greenend.org.uk>  Sun, 26 Oct 2014 13:24:00 +0000
65
66 adns (1.5.0~rc0) UPSTREAM; urgency=low
67
68   New features:
69   * Support for queries about IPv6 data in all applicable adns
70     query types (including AAAA, PTR, and adns_r_addr queries).
71     (Thanks very much to Mark Wooding.)
72   * Support for transport over IPv6.  (Thanks to Mark Wooding again.)
73   * adns_addr2text and adns_text2addr: Convenient functions for
74     converting between addresses and address literals.
75
76   Bugfixes:
77   * Fix a crashing bug in adnslogres.  (Debian#392102.)
78   * Do all checks of checked PTR owner name before actually sending the
79     query, and reject IPv4 PTR owner names whose labels have leading zero
80     digits or values >255.
81
82   Build system fixes and improvements:
83   * `make clean' removes the pipes.
84   * Work around bugs in make (Debian #4073, #756123) affecting regress.
85   * Do not include Makefile and src/config.h in distribution tarball.
86
87   Regression test debugging improvements:
88   * Provide gdbwrap convenience script.
89   * Honour ADNS_TEST_DEBUG env. var.  (Mark Wooding.)
90
91   Other improvements:
92   * Licence changed to GPLv3 (still LGPLv2 for adns.h).
93   * Source code cleanups.  (Some from Mark Wooding.)
94   * Now in git.
95   * Documentation and webpage updates.
96
97  -- Ian Jackson <ijackson@chiark.greenend.org.uk>  Mon, 20 Oct 2014 01:29:50 +0100
98
99 adns (1.4); urgency=low
100
101   Improvements for multithreaded programs:
102   * New documentation comment in adns.h explaining thread guarantees
103     (or lack of them), replaces `single-threaded' note at the top.
104   * Fix string conversion of adns_r_addr not to use a static buffer
105     (function csp_addr) so as to make thread promise true.
106   * Make an internal variable const-correct (expectdomain in pa_ptr).
107
108  -- Ian Jackson <ian@davenant.greenend.org.uk>  Tue, 17 Oct 2006 17:05:08 +0100
109
110 adns (1.3); urgency=low
111
112   Portability fixes:
113   * Cast ptrdiff_t to int for %.*s length in adnsheloex and adnslogres,
114     as is required.  (Report from Jim Meyering.)
115   * In configure.in, quote macro name argument to define() to
116     suppress spurious autoconf error.  (Report from Mihai Ibanescu.)
117   * Use autoconf's values for {bin,lib,include}dir rather than inventing
118     our own from @exec_prefix@, making configure --libdir work.
119     (Patch from Mihai Ibanescu.)
120   * Remove spurious `_' from {bin,lib,include}dir Makefile variables.
121     (Report from Mihai Ibanescu.)
122   * Do away with `mismatch' variable in parse.c:adns__findrr_anychk so that
123     overzealous GCC cannot complain about members of eo_fls being
124     uninitialised.  (Report from Jim Meyering.)
125
126  -- Ian Jackson <ian@davenant.greenend.org.uk>  Tue,  6 Jun 2006 20:22:30 +0100
127
128 adns (1.2); urgency=medium
129
130   New features:
131   * Support for SRV RRs.
132   * Support for unknown RR types (according to RFC3597) via adns_r_unknown.
133   * Allow `;'-comments in resolv.conf (report from Colin Charles).    
134   * New adnsheloex client courtesy of Tony Finch.
135   * New adns_init_logfn etc. for having logging use a callback function.
136
137   Bugfixes:
138   * Fix error in prototype in definition of adns__parse_domain.
139   * Add missing ENOTSOCK to hcommon.c.m4 (was already in hcommon.c!)
140
141   Portability fixes prompted by Bernd Eckenfels, the Debian maintainer:
142   * Correct type of various printf arguments: ptrdiff_t != int.
143   * Do not print size of leaked blocks of memory (this causes
144     a spurious regression test failure on some platforms).
145   * Provide adns_if_none and adns_qf_none (which will help with compilers
146     which complain about plain `0' being passed where an enum is wanted).
147   * adnstest converts some errno values to EFOOBAR: all of the ones
148     mentioned in adns.h, at least.  This makes the regression test
149     more portable (fixes problem noticed by Bernd Eckenfels).
150   * Add -Wno-pointer-sign if GCC has that option.
151
152   Documentation improvements:
153   * Add documentation comment by definition of adns_r_ptr_raw type enum.
154   * Document in adns.h EINVAL from adns_init meaning bad configuration.
155   * Include several new references to related programs to README.html.
156   * Redacted the TODO list.
157   * New LICENCE.WAIVERS file for GPL-incompatility workarounds.
158   * Clarified GPL-vs-LGPL: a bit less hostile and a bit more mercenary.
159   * Copyright notices updated.
160
161   Packaging changes:
162   * Update MINOR to 2 and DISTVERSION and ADNS_VERSION_STRING to 1.2.
163   * Reran autoconf/autoheader (autoconf Debian 2.13-54).
164   * Create $(bin_dir) and $(lib_dir) on `make install', and also
165     make a libadns.so.1 -> libadns.so.1.<minor> link.  (Suggestions
166     and patch from Nix of esperi.org.uk.)
167   * Add .PHONY: install to Makefile, to help people with demented fs's.
168   * Darwin listed in INSTALL.
169
170   Minor test harness improvements:
171   * Hgettimeofday calls Tensurerecordfile (was Tensureinput/outputfile).
172   * Add bind(2) and listen(2) wrappers (for epithet, but harmless in adns).
173
174  -- Ian Jackson <ian@davenant.greenend.org.uk>  Sat,  8 Apr 2006 15:41:28 +0100
175
176 adns (1.1); urgency=medium
177
178   Major bugfixes:
179   * Do not spin if connect() fails immediately (!)
180   * Stop searching on a CNAME (even if it's broken).
181   * When search list runs out, _qf_owner sets owner to query domain.
182   * Fix bogus multiple updates to p in transmit.c (!)
183
184   Portability improvements:
185   * Fix up spurious #undef's in hredirect.h.
186   * Don't use <sys/select.h> any more, it was a mistake made in pre-1.0
187     (and there doesn't seem to be much explanation why).
188   * Understand and sort of check OpenBSD `lookup' resolv.conf directive.
189   * #include <stdlib.h> in internal.h (for abort etc).
190   * Always #include <sys/types.h> before <sys/socket.h> (for FreeBSD 4.6).
191
192   Cosmetic and documentation improvements:
193   * Added wishlist entry re configurable port no.
194   * Problem with SERVFAIL in TODO.
195   * README.html: mentioned Jarle Aase's Windows port, and other fixes.
196   * Some better source code formatting/wrapping.
197
198  -- Ian Jackson <ian@davenant.greenend.org.uk>  Tue,  1 Jul 2003 22:55:29 +0100
199
200 adns (1.0); urgency=medium
201
202   Bugfixes:
203   * Treat 8-bit characters in email addrs as RFC822 `special' (=> quote).
204   * Fix incorrect `compressed datagram contains loop' error.
205   * Actually compile shared libraries by default !
206   * Fix adnsresfilter usage message to include correct default timeout.
207
208   General improvements:
209   * adnshost, adnslogres, adnsresfilter have options for config override. 
210   * adnsresfilter has --debug option.
211   * Improvements to adnslogres (incl. new -c option) from Tony Finch.
212   * adnslogres has --help option, all utilities support --version.
213   * Documentation improved somewhat, including new GPL-vs-LGPL file.
214
215   Changes for non-BETA release:
216   * Change shared library soname to 1.0.
217   * Do not install adnstest test utility.
218
219   Regression test improvements:
220   * Tests now include adnshost, adnslogres and adnsresfilter.
221   * Test cancellation both before and after query completion.
222
223   Portability fixes and cleanups:
224   * adnstest: setvbuf(stdout,...) before we do first output.
225   * Cope with compilers that don't do `inline'.
226   * Add and fix various missing system #includes.
227   * Find install-sh properly when we need to use it, and chmod it +x.
228   * Do not use variadic macro, use stdarg instead (adnslogres.c).
229   * Regression tests work even if some syscalls are already macros.
230   * #include "config.h" before "adns.h".
231   * Cast a sizeof(...) in src/event.c to unsigned long before printing.
232   * Add pre-generated versions of m4-generated files in regress/.
233   * Kill bogus warning, adh-main.c: `arg2' might be used uninitialized ...
234   * Add extra {...} near adnslogres.c:167 to kill spurious warning.
235   * Use `printf' instead of `echo -n'.
236   * Add list of tested platforms in INSTALL file.
237
238  -- Ian Jackson <ian@davenant.greenend.org.uk>  Sun, 17 Sep 2000 15:15:58 +0100
239
240 adns (0.9) BETA; urgency=high
241
242   Bug fixes:
243   * Don't make _processany always kill the TCP connection with the message
244     `TCP connection failed: poll/select: exceptional condition detected'.
245   * Call MEM_ROUND in __transfer_interim (avoids assert fail
246     `qu->interim_allocd>=0' on some platforms eg 64 bit).
247   * adnsresfilter doesn't resolve textual prefixes of addresses (eg,
248     10.0.0.1 out of 10.0.0.123) if input happens to block at that point.
249   * Do not spin if TCP connection blocks for writing (and add test case).
250   * Fail queries if TCP dies repeatedly, rather than retrying many times.
251   * Do not abort in a couple of places if TCP unexpectedly broken.
252   * Do not free something twice if query fails and is then cancelled.
253
254   Portability/compilation fixes:
255   * Move `extern "C" {' to after #include <...>'s.
256   * Pass LDFLAGS from configure on to ld via settings.make.in.
257   * make clean deletes *.so and *.so.* files.
258   * New --disable-dynamic configure option for non-ELF systems.
259   * Use AC_PROG_INSTALL (=> perhaps install-sh), to avoid bad `install'.
260
261   Minor improvements:
262   * Do not print warning if sendto() gives EAGAIN.
263   * adnsresfilter default timeout changed to 1000ms.
264   * m1test script can invoke `hrecord' differently.
265   * regress/output-<case>.report file contains more useful info.
266   * TODO list and other docs updated slightly.
267   * Referrals with RD+RA set, or RCODE=Refused, don't generate warnings,
268     just debug messages.  BIND does this kind of thing all the time.
269
270  -- Ian Jackson <ian@davenant.greenend.org.uk>  Wed,  9 Aug 2000 16:59:28 +0100
271
272 adns (0.8) BETA; urgency=medium
273
274   Bugfixes:
275   * Race near adns_beforeselect which could cause infinite timeout fixed
276     (it's now less agressive, and will more often return a zero timeout.)
277   * Fixed infrequent race causing assertion failure in adns__tcp_broken
278     `ads->tcpstate == server_connecting || ads->tcpstate == server_ok'.
279   * Spurious `server failure on unidentifiable query' warning suppressed.
280   * If we get a referral, don't also always complain falsely about RD==0.
281   * adnslogres: cast chars to unsigned char before using ctype.h macros.
282   * In _beforeselect, global failure now means zero timeout, and in
283     tcp_events, really never try to do anything with the TCP connection if
284     act is zero.  This might possibly cause an infinite delay (ie, lockup)
285     if things go badly wrong *and* a really unlikely race happens.
286   * Test suite `lines of syscall left' value is correct; !0 is failure.
287
288   Portability fixes:
289   * install-sh (from autoconf 2.12 Debian r13) included.
290   * adnslogres: do not call equivalent of printf("%.*s",0,(char*)0).
291
292   Documentation improvements:
293   * Security/performance note added, about local nameservers and DNSSEC.
294   * Documented that adns_rr_info _rr_hostaddr ( ) for address list
295     means permanent failure, and ? means temporary failure.
296   * Typo (*now for now in _beforeselect description) in adns.h fixed.
297   * Copyright notices updated.
298   
299   Changes to produce more defensive code:
300   * In adns_wait, assert that the timeout is not infinite.
301   * Make qu->id start out as -2 when initially allocated.
302
303  -- Ian Jackson <ian@davenant.greenend.org.uk>  Sun,  7 May 2000 23:37:13 +0100
304
305 adns (0.7) BETA; urgency=medium
306
307   * New adns_submit_reverse_any for eg RBL lookups, and corresponding
308     option to adnshost.
309   * README updated (from www home page).
310
311   * In answers, quote all except alphanums and - _ / + (and document).
312   * Don't reject specials in cnames even without adns_qf_quotefail_cname.
313   * Better checking of long domain names and labels in queries.
314   * answer->owner may be null on error.  Documented, and adnshost copes.
315   * Better reporting of unexpected or weird replies from nameserver.
316   * Add test case for recursion (infinite loop) domain compression.
317
318  -- Ian Jackson <ian@davenant.greenend.org.uk>  Thu,  2 Mar 2000 01:55:53 +0000
319
320 adns (0.6) BETA; urgency=high
321
322   Core library bugfixes:
323   * Avoid infinite timeouts, causing lockup, when they should be zero !
324   * TCP handling revamped (avoids undefined behaviour due to reentrancy).
325   * Do not fail assertion if _qf_owner, _qf_search, domain ends in `.'.
326   * Many memory leaks fixed.
327
328   Cool new utility:
329   * adnsresfilter is like `cat' but converts addresses to names without
330     delaying the output.  Pipe `netstat -n', `tcpdump -ln', etc. into it.
331
332   Test and client program bug and portability fixes:
333   * Dynamic library building works properly.
334   * adnshost prints somewhat better messages about some wrong usages.
335   * Include <stdlib.h> and <sys/types.h> in adnshost.h.
336   * adnslogres: parsing and error checking improved (Tony Finch).
337   * Regression tests can cope with zero-length reads.
338   * Regression tests check for memory leaks.
339   * adnstest copes with empty query type list.
340   * adnstest uninitialised memory bug fixed.
341
342   General improvements
343   * Better control of adnshost output and error messages (new -F options).
344   * New adns_if_logpid option (functionality suggested by Tony Finch).
345   * New fanftest test program from Tony Finch (ignored by `make install').
346   * Reads /etc/resolv-adns.conf if it exists.
347   * Declare flags parameters as enums again, not ints.
348
349  -- Ian Jackson <ian@davenant.greenend.org.uk>  Wed, 24 Nov 1999 17:13:03 +0000
350
351 adns (0.5) unstable; urgency=high
352
353   New features:
354   * adnslogres, ~100x faster replacement for Apache logresolve;
355     Thanks to Tony Finch for the program and the performance figure.
356   * Internal consistency checking with assert if right options set.
357   * adns_wait_poll function like adns_wait but uses poll, not select.
358   * adns_reverse_submit function for easy in-addr queries.
359   * adns_errtypeabbrev funcion for getting eg "permfail" from _s_nodata.
360   * adnshost utility for scripts and the like (rather alpha).
361
362   Incompatible changes:
363   * RRs with mailboxes never rejected due to strange chars if _raw.
364   * Lack of a mailbox produces `.' not `<>'.
365   * Better usage messages (and no default query domain) for adnstest.
366   * Return EAGAIN from _check instead of EWOULDBLOCK.
367   * adns_rr_info on _r_mx etc. shows status type abbrev and status number.
368   
369   Bugfixes:
370   * Do not invoke __autosys indirectly from __procdgram (result: coredump
371     usually in memmove, unless adns_if_noautosys was used).
372   * Do not scramble innards when a query on the output queue is cancelled.
373   * Do not close tcp socket twice.
374   * Mailboxes containing spaces in their names are quoted.
375   * Give ESRCH, not EAGAIN, if _check called with no queries outstanding.
376   * adns_rr_hostaddr naddrs is -1 on temporary failure (as documented).
377   * Reject TXT RRs with no strings.
378   * Correct error messages for qname CNAME foo, foo CNAME bar.
379   * adns_processany actually does something.
380   * Fixed typos in adns.h.
381
382   General improvements:
383   * Promise not to change fds in adns_beforepoll (if now is specified).
384   * Improved textual error string for _s_prohibitedcname.
385   * New comment in adns_processany and return 0 (not r which is 0).
386   * Documentation of resolv.conf directives and options, and of environment
387     variables understood, in adns.h
388   * Regression test scripts set EF_DISABLE_BANNER (for Electric Fence).
389
390   Portability and build improvements:
391   * Give install the '-c' flag (otherwise some delete the original !).
392   * Do not remove top-level Makefile on `make clean'.
393   * Don't complain so much about poll(2) tests if not available.
394   * Do not give -u 0 -g 0 options to install.
395   * Remove trailing , from some enums in adns.h.
396   * Dynamically linked clients now made with -l, so as to avoid rpath.
397   * Do not use $^ in make rules (should help with non-GNU make).
398   * Declare flags parameters as ints not enums because C++ is crap.
399
400  -- Ian Jackson <ian@davenant.greenend.org.uk>  Wed, 13 Oct 1999 02:24:35 +0100
401
402 adns (0.4) unstable; urgency=high
403
404   General important bugfixes:
405   * make _qf_owner work if _qf_search not specified, and test it (oops!)
406   * ads->configerrno now initialised (in setup.c).
407   * timercmp(,,<=) doesn't work - use !timercmp(,,>).
408   * Changed memory semantics of internal queries to fix bugs.
409   * Restarting a TCP-using query (eg due to CNAME) doesn't abort.
410   
411   Fixes for handling of broken kinds of reply:
412   * Only accept a reply from the subset of servers we sent the query.
413   * Ignore CNAME(s) in answer after RR(s) (and test).
414
415   Other bugfixes and improvements:
416   * adns_s_systemfail is in table of errors (for eg adns_strerror).
417   * Do not ship config.cache, Makefile, etc.
418   * Improvements to install instructions, TODO, etc.
419   * Regression tests compile on systems without poll(2).
420   * Do not install adnstest_s.
421   * _submit returns ENOSYS, not adns_s_unknownquery; documented, tested.
422   * <adns.h> includes <sys/types.h>, <sys/time.h>, <unistd.h>.
423
424  -- Ian Jackson <ian@davenant.greenend.org.uk>  Thu, 5 Aug 1999 01:17:38 +0100
425
426 adns (0.3) unstable; urgency=low
427
428   Incompatible changes:
429   * Low adns_status values (below adns_s_max_tempfail) renumbered to make
430     room for future locally-induced and locally-detected errors.
431   * Event loop functions for use by select(2) renamed and tidied up.
432   
433   Features / improvements:
434   * New adns_errabbrev() for getting status abbreviation strings.
435   * regress/checkall prints summary list of failed tests, if any.
436   * Event loop functions for poll(2), and some raw variants.
437   * adnstest has ability to use poll(2), and user can set initflags.
438   * checkall prints passed list as well as failed list, if any failed.
439   * You can iterate over outstanding queries (but only once at a time).
440   
441   Bugfixes:
442   * Non-RFC822 mailbox `domain' formatting now works, and clarified.
443   * Rejection of bad characters in domains (without quoteok) works.
444   * Clean up parents from adns->childw (otherwise would abort/segfault).
445   * In adnstest, allocate enough space for, and terminate, query types.
446   * In adnstest, don't print errno values as adns_status values.
447  
448   * Added TODO file.
449   * Made adnstest.c test context pointers.
450
451  -- Ian Jackson <ian@davenant.greenend.org.uk>  Thu, 15 Jul 1999 00:23:12 +0100
452
453 adns (0.2) experimental; urgency=low
454
455   Portability fixes for compilation on various platforms:
456   * Include <sys/socket.h> and <netinet/in.h> in files with <arpa/inet.h>.
457   * Don't use GCC union assignment feature (.rrs=0 => .rrs.untyped=0).
458   * Explictly cast things to [const] struct sockaddr* in syscall args.
459   * Check whether we need -lsocket.
460   * Include <sys/times.h> in a few more files.
461   * Include <unistd.h> and <sys/time.h> for select.
462   * Look for inet_aton and inet_ntoa (in -lnsl and -lsocket).
463   * LDLIBS removed from dependency lists (some makes don't support this).
464   * An `ambiguous else' warning from some compilers in types.c is removed.
465
466   Other changes:
467   * Added COPYING (copy of the GPL).
468   * Regression test failure output improved.
469   * Missing targets in regress/Makefile.in added.
470   * Regression test doesn't rely on value of fcntl flags eg O_NONBLOCK.
471
472  -- Ian Jackson <ian@davenant.greenend.org.uk>  Thu, 20 May 1999 00:27:32 +0100
473
474 adns (0.1) experimental; urgency=low
475
476   * Initial public alpha release.
477
478  -- Ian Jackson <ian@davenant.greenend.org.uk>  Sat, 17 April 1999 17:42:19
479
480 Local variables:
481 mode: debian-changelog
482 fill-column: 75
483 End: