]> git.ipfire.org Git - thirdparty/bind9.git/log
thirdparty/bind9.git
5 years agoDon't use 'rndc signing' with kasp
Matthijs Mekking [Tue, 13 Oct 2020 12:52:02 +0000 (14:52 +0200)] 
Don't use 'rndc signing' with kasp

The 'rndc signing' command allows you to manipulate the private
records that are used to store signing state. Don't use these with
'dnssec-policy' as such manipulations may violate the policy (if you
want to change the NSEC3 parameters, change the policy and reconfig).

5 years agoFix a reconfig bug wrt inline-signing
Matthijs Mekking [Tue, 13 Oct 2020 12:48:04 +0000 (14:48 +0200)] 
Fix a reconfig bug wrt inline-signing

When doing 'rndc reconfig', named may complain about a zone not being
reusable because it has a raw version of the zone, and the new
configuration has not set 'inline-signing'. However, 'inline-signing'
may be implicitly true if a 'dnssec-policy' is used for the zone, and
the zone is not dynamic.

Improve the check in 'named_zone_reusable'.  Create a new function for
checking 'inline-signing' configuration that matches existing code in
'bin/named/server.c'.

5 years agoSupport for NSEC3 in dnssec-policy
Matthijs Mekking [Tue, 13 Oct 2020 12:39:21 +0000 (14:39 +0200)] 
Support for NSEC3 in dnssec-policy

Implement support for NSEC3 in dnssec-policy.  Store the configuration
in kasp objects. When configuring a zone, call 'dns_zone_setnsec3param'
to queue an nsec3param event. This will ensure that any previous
chains will be removed and a chain according to the dnssec-policy is
created.

Add tests for dnssec-policy zones that uses the new 'nsec3param'
option, as well as changing to new values, changing to NSEC, and
changing from NSEC.

5 years agoAdd kasp nsec3param configuration
Matthijs Mekking [Fri, 9 Oct 2020 12:19:10 +0000 (14:19 +0200)] 
Add kasp nsec3param configuration

Add configuration and documentation on how to enable NSEC3 when
using dnssec-policy for signing your zones.

5 years agoMove generate_salt function to lib/dns/nsec3
Matthijs Mekking [Fri, 23 Oct 2020 12:56:04 +0000 (14:56 +0200)] 
Move generate_salt function to lib/dns/nsec3

We will be using this function also on reconfig, so it should have
a wider availability than just bin/named/server.

5 years agoMerge branch 'michal/fix-cppcheck-2.2-issues' into 'main'
Michał Kępień [Wed, 25 Nov 2020 12:16:53 +0000 (12:16 +0000)] 
Merge branch 'michal/fix-cppcheck-2.2-issues' into 'main'

Fix cppcheck 2.2 issues

See merge request isc-projects/bind9!4292

5 years agoConvert add_quota() to a function
Michał Kępień [Wed, 25 Nov 2020 11:45:47 +0000 (12:45 +0100)] 
Convert add_quota() to a function

cppcheck 2.2 reports the following false positive:

    lib/isc/tests/quota_test.c:71:21: error: Array 'quotas[101]' accessed at index 110, which is out of bounds. [arrayIndexOutOfBounds]
     isc_quota_t *quotas[110];
                        ^

The above is not even an array access, so this report is obviously
caused by a cppcheck bug.  Yet, it seems to be triggered by the presence
of the add_quota() macro, which should really be a function.  Convert
the add_quota() macro to a function in order to make the code cleaner
and to prevent the above cppcheck 2.2 false positive from being
triggered.

5 years agoSilence cppcheck 2.2 false positive in udp_recv()
Michał Kępień [Wed, 25 Nov 2020 11:45:47 +0000 (12:45 +0100)] 
Silence cppcheck 2.2 false positive in udp_recv()

cppcheck 2.2 reports the following false positive:

    lib/dns/dispatch.c:1239:14: warning: Either the condition 'resp==NULL' is redundant or there is possible null pointer dereference: resp. [nullPointerRedundantCheck]
     if (disp != resp->disp) {
                 ^
    lib/dns/dispatch.c:1210:11: note: Assuming that condition 'resp==NULL' is not redundant
     if (resp == NULL) {
              ^
    lib/dns/dispatch.c:1239:14: note: Null pointer dereference
     if (disp != resp->disp) {
                 ^

Apparently this version of cppcheck gets confused about conditional
"goto" statements because line 1239 can never be reached if 'resp' is
NULL.

Move a code block to prevent the above false positive from being
reported without affecting the processing logic.

5 years agoTeach cppcheck that fatal() does not return
Michał Kępień [Wed, 25 Nov 2020 11:45:47 +0000 (12:45 +0100)] 
Teach cppcheck that fatal() does not return

cppcheck is not aware that the bin/dnssec/dnssectool.c:fatal() function
does not return.  This triggers certain cppcheck 2.2 false positives,
for example:

    bin/dnssec/dnssec-signzone.c:3471:13: warning: Either the condition 'ndskeys==8' is redundant or the array 'dskeyfile[8]' is accessed at index 8, which is out of bounds. [arrayIndexOutOfBoundsCond]
       dskeyfile[ndskeys++] = isc_commandline_argument;
                ^
    bin/dnssec/dnssec-signzone.c:3468:16: note: Assuming that condition 'ndskeys==8' is not redundant
       if (ndskeys == MAXDSKEYS) {
                   ^
    bin/dnssec/dnssec-signzone.c:3471:13: note: Array index out of bounds
       dskeyfile[ndskeys++] = isc_commandline_argument;
                ^

    bin/dnssec/dnssec-signzone.c:772:20: warning: Either the condition 'l->hashbuf==NULL' is redundant or there is pointer arithmetic with NULL pointer. [nullPointerArithmeticRedundantCheck]
     memset(l->hashbuf + l->entries * l->length, 0, l->length);
                       ^
    bin/dnssec/dnssec-signzone.c:768:18: note: Assuming that condition 'l->hashbuf==NULL' is not redundant
      if (l->hashbuf == NULL) {
                     ^
    bin/dnssec/dnssec-signzone.c:772:20: note: Null pointer addition
     memset(l->hashbuf + l->entries * l->length, 0, l->length);
                       ^

Instead of suppressing all such warnings individually, conditionally
define a preprocessor macro which prevents them from being triggered.

5 years agoRemove cppcheck 2.0 false positive workarounds
Michał Kępień [Wed, 25 Nov 2020 11:45:47 +0000 (12:45 +0100)] 
Remove cppcheck 2.0 false positive workarounds

The cppcheck bug which commit 481fa34e50a6183273f71175adf93bfb12cad1e9
works around was fixed in cppcheck 2.2.  Drop the relevant hack from the
definition of the cppcheck GitLab CI job.

5 years agoMerge branch '2141-asynchrony-support-for-bind-9-query-plugins' into 'main'
Evan Hunt [Wed, 25 Nov 2020 00:59:19 +0000 (00:59 +0000)] 
Merge branch '2141-asynchrony-support-for-bind-9-query-plugins' into 'main'

Resolve "asynchrony support for BIND 9 query plugins"

Closes #2141

See merge request isc-projects/bind9!4407

5 years agoCHANGES
Evan Hunt [Fri, 20 Nov 2020 22:26:51 +0000 (14:26 -0800)] 
CHANGES

5 years agocreate system test with asynchronous plugin
Evan Hunt [Fri, 20 Nov 2020 01:58:45 +0000 (17:58 -0800)] 
create system test with asynchronous plugin

the test-async plugin uses ns_query_hookasync() at the
NS_QUERY_DONE_SEND hook point to call an asynchronous function.
the only effect is to change the query response code to "NOTIMP",
so we can confirm that the hook ran and resumed correctly.

5 years agoimplementation of hook-based asynchronous functionality
JINMEI Tatuya [Wed, 16 Sep 2020 22:26:22 +0000 (15:26 -0700)] 
implementation of hook-based asynchronous functionality

previously query plugins were strictly synchrounous - the query
process would be interrupted at some point, data would be looked
up or a change would be made, and then the query processing would
resume immediately.

this commit enables query plugins to initiate asynchronous processes
and resume on a completion event, as with recursion.

5 years agons_query refactoring for hook-based recursion
JINMEI Tatuya [Wed, 16 Sep 2020 20:19:03 +0000 (13:19 -0700)] 
ns_query refactoring for hook-based recursion

several small changes to query processing to make it easier to
use hook-based recursion (and other asynchronous functionlity)
later.

- recursion quota check is now a separate function,
  check_recursionquota(), which is called by ns_query_recurse().
- pass isc_result to query_nxdomain() instead of bool.
  the value of 'empty_wild' will be determined in the function
  based on the passed result.  this is similar to query_nodata(),
  and makes the signatures of the two functions more consistent.
- pass the current 'result' value into plugin hooks.

5 years agoMerge branch '1154-add-dns64-prefix-discover-support' into 'main'
Mark Andrews [Tue, 24 Nov 2020 21:45:56 +0000 (21:45 +0000)] 
Merge branch '1154-add-dns64-prefix-discover-support' into 'main'

Resolve "Add dns64 prefix discover support"

Closes #1154

See merge request isc-projects/bind9!2178

5 years agoAdd release note
Mark Andrews [Wed, 18 Nov 2020 23:50:46 +0000 (10:50 +1100)] 
Add release note

5 years agoadd CHANGES
Mark Andrews [Thu, 29 Aug 2019 07:01:51 +0000 (17:01 +1000)] 
add CHANGES

5 years agoadd +dns64prefix to dig to display any DNS64 prefixes at IPV4ONLY.ARPA
Mark Andrews [Thu, 25 Jul 2019 10:26:13 +0000 (20:26 +1000)] 
add +dns64prefix to dig to display any DNS64 prefixes at IPV4ONLY.ARPA

5 years agoadd dns_dns64_findprefix
Mark Andrews [Mon, 22 Jul 2019 17:44:30 +0000 (03:44 +1000)] 
add dns_dns64_findprefix

5 years agoMerge branch '1730-clean-up-no-op-ac_subst-calls' into 'main'
Michal Nowak [Tue, 24 Nov 2020 17:33:51 +0000 (17:33 +0000)] 
Merge branch '1730-clean-up-no-op-ac_subst-calls' into 'main'

Remove unused Autoconf variables

See merge request isc-projects/bind9!4402

5 years agoRefactor libidn2 detection code
Michał Kępień [Tue, 24 Nov 2020 13:51:51 +0000 (14:51 +0100)] 
Refactor libidn2 detection code

Make the code block handling the --with-libidn2=/path/to/libidn2 form of
the --with-libidn2 build-time option behave more similarly to the
PKG_CHECK_MODULES() macro.

5 years agoRemove unused DLZ_DRIVER_MYSQL_* build variables
Michal Nowak [Mon, 23 Nov 2020 14:07:56 +0000 (15:07 +0100)] 
Remove unused DLZ_DRIVER_MYSQL_* build variables

The DLZ_DRIVER_MYSQL_INCLUDES and DLZ_DRIVER_MYSQL_LIBS build variables
are not used anywhere.  Remove their definitions and the associated
AC_SUBST() calls.

5 years agoRemove AC_SUBST() calls from AX_LIB_LMDB()
Michal Nowak [Mon, 23 Nov 2020 13:59:12 +0000 (14:59 +0100)] 
Remove AC_SUBST() calls from AX_LIB_LMDB()

LMDB build variables are already substituted by AC_SUBST() calls in
configure.ac and therefore the latter should not be duplicated in the
AX_LIB_LMDB() helper macro.

5 years agoMerge branch 'michal/update-release-checklist' into 'main'
Michał Kępień [Tue, 24 Nov 2020 12:57:47 +0000 (12:57 +0000)] 
Merge branch 'michal/update-release-checklist' into 'main'

Update release checklist

See merge request isc-projects/bind9!4406

5 years agoUpdate release checklist
Michał Kępień [Tue, 24 Nov 2020 12:50:57 +0000 (13:50 +0100)] 
Update release checklist

Apply a number of tweaks to the release checklist in order to make it
better reflect the current release process.

5 years agoMerge branch '2288-dig-interrupt-crash' into 'main'
Evan Hunt [Mon, 23 Nov 2020 20:28:46 +0000 (20:28 +0000)] 
Merge branch '2288-dig-interrupt-crash' into 'main'

Resolve ""dig" crashes when interrupted while waiting for a TCP connection"

Closes #2288

See merge request isc-projects/bind9!4397

5 years agodig could crash on interrupt
Evan Hunt [Wed, 18 Nov 2020 21:08:03 +0000 (13:08 -0800)] 
dig could crash on interrupt

dig could crash if it was shut down by an interrupt while a connection
was pending.

5 years agoMerge branch 'michal/enable-stress-tests-to-be-run-on-demand' into 'main'
Michał Kępień [Mon, 23 Nov 2020 10:51:32 +0000 (10:51 +0000)] 
Merge branch 'michal/enable-stress-tests-to-be-run-on-demand' into 'main'

Enable "stress" tests to be run on demand

See merge request isc-projects/bind9!4313

5 years agoEnable "stress" tests to be run on demand
Michał Kępień [Mon, 23 Nov 2020 10:46:50 +0000 (11:46 +0100)] 
Enable "stress" tests to be run on demand

The "stress" test can be run in different ways, depending on:

  - the tested scenario (authoritative, recursive),
  - the operating system used (Linux, FreeBSD),
  - the architecture used (amd64, arm64).

Currently, all supported "stress" test variants are automatically
launched for all scheduled pipelines and for pipelines started for tags;
there is no possibility of running these tests on demand, which could be
useful in certain circumstances.

Employ the "only:variables" key to enable fine-grained control over the
list of "stress" test jobs to be run for a given pipeline.  Three CI
variables are used to specify the list of "stress" test jobs to create:

  - BIND_STRESS_TEST_MODE: specifies the test mode to use; must be
    explicitly set in order for any "stress" test job to be created;
    allowed values are: "authoritative", "recursive",

  - BIND_STRESS_TEST_OS: specifies the operating system to run the test
    on; allowed values are: "linux", "freebsd"; defaults to "linux", may
    be overridden at pipeline creation time,

  - BIND_STRESS_TEST_ARCH: specifies the architecture to run the test
    on; allowed values are: "amd64", "arm64"; defaults to "amd64", may
    be overridden at pipeline creation time.

Since case-insensitive regular expressions are used for determining
which jobs to run, every variable described above may contain multiple
values.  For example, setting the BIND_STRESS_TEST_MODE variable to
"authoritative,recursive" will cause the "stress" test to be run in both
supported scenarios (either on the default OS/architecture combination,
i.e. Linux/amd64, or, if the relevant variables are explicitly
specified, the requested OS/architecture combinations).

5 years agoMerge branch 'matthijs-fix-echo_i-in-auth-test' into 'main'
Mark Andrews [Thu, 19 Nov 2020 23:41:22 +0000 (23:41 +0000)] 
Merge branch 'matthijs-fix-echo_i-in-auth-test' into 'main'

Fix syntax in echo_i messages

See merge request isc-projects/bind9!4400

5 years agoFix syntax in echo_i messages
Matthijs Mekking [Thu, 19 Nov 2020 10:40:19 +0000 (11:40 +0100)] 
Fix syntax in echo_i messages

It's either "record returns" or "records return".

5 years agoMerge branch 'marka-fix-stop.sh' into 'main'
Mark Andrews [Thu, 19 Nov 2020 05:19:56 +0000 (05:19 +0000)] 
Merge branch 'marka-fix-stop.sh' into 'main'

bin/tests/system/stop.sh was not working

See merge request isc-projects/bind9!4399

5 years agobin/tests/system/stop.sh was not working
Mark Andrews [Thu, 19 Nov 2020 03:43:06 +0000 (14:43 +1100)] 
bin/tests/system/stop.sh was not working

It failed to export builddir srcdir resulting in stop.pl failing
when these where looked for in the environment.

5 years agoMerge branch '2280-check-dname-handling-when-qtype-is-cname-any' into 'main'
Mark Andrews [Wed, 18 Nov 2020 23:48:30 +0000 (23:48 +0000)] 
Merge branch '2280-check-dname-handling-when-qtype-is-cname-any' into 'main'

Resolve "Check DNAME handling when QTYPE is CNAME/ANY"

Closes #2280

See merge request isc-projects/bind9!4393

5 years agoFix DNAME when QTYPE is CNAME or ANY
Mark Andrews [Tue, 17 Nov 2020 00:03:21 +0000 (11:03 +1100)] 
Fix DNAME when QTYPE is CNAME or ANY

The synthesised CNAME is not supposed to be followed when the
QTYPE is CNAME or ANY as the lookup is satisfied by the CNAME
record.

5 years agoMerge branch '2255-dig-crashed-in-tcp_connected-on-openbsd' into 'main'
Ondřej Surý [Wed, 11 Nov 2020 21:48:13 +0000 (21:48 +0000)] 
Merge branch '2255-dig-crashed-in-tcp_connected-on-openbsd' into 'main'

Turn all the callback to be always asynchronous

Closes #2255

See merge request isc-projects/bind9!4386

5 years agoTurn all the callback to be always asynchronous
Ondřej Surý [Wed, 11 Nov 2020 09:46:33 +0000 (10:46 +0100)] 
Turn all the callback to be always asynchronous

When calling the high level netmgr functions, the callback would be
sometimes called synchronously if we catch the failure directly, or
asynchronously if it happens later.  The synchronous call to the
callback could create deadlocks as the caller would not expect the
failed callback to be executed directly.

5 years agoMerge branch '2066-fix-serve-stale' into 'main'
Diego dos Santos Fronza [Wed, 11 Nov 2020 16:19:10 +0000 (16:19 +0000)] 
Merge branch '2066-fix-serve-stale' into 'main'

Resolve "Fix serve-stale so that it is usable when needed"

Closes #2066

See merge request isc-projects/bind9!4273

5 years agoUpdate ARM and other documents
Diego Fronza [Wed, 4 Nov 2020 23:02:58 +0000 (20:02 -0300)] 
Update ARM and other documents

5 years agoAdd CHANGES and release notes entry
Diego Fronza [Wed, 4 Nov 2020 23:02:34 +0000 (20:02 -0300)] 
Add CHANGES and release notes entry

5 years agoAdjusted test to match new rndc serve-stale status output
Diego Fronza [Tue, 10 Nov 2020 21:08:23 +0000 (18:08 -0300)] 
Adjusted test to match new rndc serve-stale status output

5 years agoOutput 'stale-refresh-time' value on rndc serve-stale status
Diego Fronza [Tue, 10 Nov 2020 17:30:01 +0000 (14:30 -0300)] 
Output 'stale-refresh-time' value on rndc serve-stale status

5 years agoCheck 'stale-refresh-time' when sharing cache between views
Diego Fronza [Tue, 10 Nov 2020 16:50:54 +0000 (13:50 -0300)] 
Check 'stale-refresh-time' when sharing cache between views

This commit ensures that, along with previous restrictions, a cache is
shareable between views only if their 'stale-refresh-time' value are
equal.

5 years agoAdd two more system tests for stale-refresh-time
Matthijs Mekking [Tue, 10 Nov 2020 13:55:18 +0000 (14:55 +0100)] 
Add two more system tests for stale-refresh-time

Add one test that checks the behavior when serve-stale is enabled
via configuration (as opposed to enabled via rndc).

Add one test that checks the behavior when stale-refresh-time is
disabled (set to 0).

5 years agoChange serve-stale test stale-answer-ttl
Matthijs Mekking [Tue, 10 Nov 2020 13:48:24 +0000 (14:48 +0100)] 
Change serve-stale test stale-answer-ttl

Using a 'stale-answer-ttl' the same value as the authoritative ttl
value makes it hard to differentiate between a response from the
stale cache and a response from the authoritative server.

Change the stale-answer-ttl from 2 to 4, so that it differs from the
authoritative ttl.

5 years agoWait for multiple parallel dig commands to fully finish
Diego Fronza [Tue, 20 Oct 2020 19:07:56 +0000 (16:07 -0300)] 
Wait for multiple parallel dig commands to fully finish

The strategy of running many dig commands in parallel and
waiting for the respective output files to be non empty was
resulting in random test failures, hard to reproduce, where
it was possible that the subsequent reading of the files could
have been failing due to the file's content not being fully flushed.

Instead of checking if output files are non empty, we now wait
for the dig processes to finish.

5 years agoAdded system test for stale-refresh-time
Diego Fronza [Tue, 20 Oct 2020 00:25:34 +0000 (21:25 -0300)] 
Added system test for stale-refresh-time

This test works as follow:
- Query for data.example rrset.
- Sleep until its TTL expires (2 secs).
- Disable authoritative server.
- Query for data.example again.
- Since server is down, answer come from stale cache, which has
  a configured stale-answer-ttl of 3 seconds.
- Enable authoritative server.
- Query for data.example again
- Since last query before activating authoritative server failed, and
  since 'stale-refresh-time' seconds hasn't elapsed yet, answer should
  come from stale cache and not from the authoritative server.

5 years agoAdjusted ancient rrset system test
Diego Fronza [Tue, 20 Oct 2020 00:24:38 +0000 (21:24 -0300)] 
Adjusted ancient rrset system test

Before the stale-refresh-time feature, the system test for ancient rrset
was somewhat based on the average time the previous tests and queries
were taking, thus not very precise.

After the addition of stale-refresh-time the system test for ancient
rrset started to fail since the queries for stale records (low
max-stale-ttl) were not taking the time to do a full resolution
anymore, since the answers now were coming from the cache (because the
rrset were stale and within stale-refresh-time window after the
previous resolution failure).

To handle this, the correct time to wait before rrset become ancient is
calculated from max-stale-ttl configuration plus the TTL set in the
rrset used in the tests (ans2/ans.pl).

Then before sending queries for ancient rrset, we check if we need to
sleep enough to ensure those rrset will be marked as ancient.

5 years agoWarn if 'stale-refresh-time' < 30 (default)
Diego Fronza [Thu, 5 Nov 2020 16:07:47 +0000 (13:07 -0300)] 
Warn if 'stale-refresh-time' < 30 (default)

RFC 8767 recommends that attempts to refresh to be done no more
frequently than every 30 seconds.

Added check into named-checkconf, which will warn if values below the
default are found in configuration.

BIND will also log the warning during loading of configuration in the
same fashion.

5 years agoAdd stale-refresh-time option
Diego Fronza [Mon, 19 Oct 2020 20:02:03 +0000 (17:02 -0300)] 
Add stale-refresh-time option

Before this update, BIND would attempt to do a full recursive resolution
process for each query received if the requested rrset had its ttl
expired. If the resolution fails for any reason, only then BIND would
check for stale rrset in cache (if 'stale-cache-enable' and
'stale-answer-enable' is on).

The problem with this approach is that if an authoritative server is
unreachable or is failing to respond, it is very unlikely that the
problem will be fixed in the next seconds.

A better approach to improve performance in those cases, is to mark the
moment in which a resolution failed, and if new queries arrive for that
same rrset, try to respond directly from the stale cache, and do that
for a window of time configured via 'stale-refresh-time'.

Only when this interval expires we then try to do a normal refresh of
the rrset.

The logic behind this commit is as following:

- In query.c / query_gotanswer(), if the test of 'result' variable falls
  to the default case, an error is assumed to have happened, and a call
  to 'query_usestale()' is made to check if serving of stale rrset is
  enabled in configuration.

- If serving of stale answers is enabled, a flag will be turned on in
  the query context to look for stale records:
  query.c:6839
  qctx->client->query.dboptions |= DNS_DBFIND_STALEOK;

- A call to query_lookup() will be made again, inside it a call to
  'dns_db_findext()' is made, which in turn will invoke rbdb.c /
  cache_find().

- In rbtdb.c / cache_find() the important bits of this change is the
  call to 'check_stale_header()', which is a function that yields true
  if we should skip the stale entry, or false if we should consider it.

- In check_stale_header() we now check if the DNS_DBFIND_STALEOK option
  is set, if that is the case we know that this new search for stale
  records was made due to a failure in a normal resolution, so we keep
  track of the time in which the failured occured in rbtdb.c:4559:
  header->last_refresh_fail_ts = search->now;

- In check_stale_header(), if DNS_DBFIND_STALEOK is not set, then we
  know this is a normal lookup, if the record is stale and the query
  time is between last failure time + stale-refresh-time window, then
  we return false so cache_find() knows it can consider this stale
  rrset entry to return as a response.

The last additions are two new methods to the database interface:
- setservestale_refresh
- getservestale_refresh

Those were added so rbtdb can be aware of the value set in configuration
option, since in that level we have no access to the view object.

5 years agoMerge branch '1913-remove-unused-leftovers' into 'main'
Michal Nowak [Wed, 11 Nov 2020 09:26:09 +0000 (09:26 +0000)] 
Merge branch '1913-remove-unused-leftovers' into 'main'

Resolve "Remove unused leftovers"

Closes #1913

See merge request isc-projects/bind9!4366

5 years agoAdd CHANGES entry
Michal Nowak [Fri, 6 Nov 2020 13:42:20 +0000 (14:42 +0100)] 
Add CHANGES entry

5 years agoAdd unused headers check to CI
Michal Nowak [Fri, 6 Nov 2020 11:28:26 +0000 (12:28 +0100)] 
Add unused headers check to CI

5 years agoDrop unused headers
Michal Nowak [Fri, 6 Nov 2020 11:27:41 +0000 (12:27 +0100)] 
Drop unused headers

5 years agoMerge branch 'mnowak/drop-OPENSSL_LIB' into 'main'
Michal Nowak [Wed, 11 Nov 2020 08:52:01 +0000 (08:52 +0000)] 
Merge branch 'mnowak/drop-OPENSSL_LIB' into 'main'

Drop @OPENSSL_LIB@ in bigkey

See merge request isc-projects/bind9!4383

5 years agoDrop @OPENSSL_LIB@ in bigkey
Michal Nowak [Tue, 10 Nov 2020 19:17:41 +0000 (20:17 +0100)] 
Drop @OPENSSL_LIB@ in bigkey

@OPENSSL_LIB@ was brought back with the
2f9f6f1fac6047afe93c4a9e89b8ed2fe3fefdde revert.

5 years agoMerge branch '2211-tsan-error-previous_closest_nsec-dns_rbt_findnode-vs-subtractrdata...
Mark Andrews [Tue, 10 Nov 2020 21:16:05 +0000 (21:16 +0000)] 
Merge branch '2211-tsan-error-previous_closest_nsec-dns_rbt_findnode-vs-subtractrdataset' into 'main'

Resolve "tsan error previous_closest_nsec(dns_rbt_findnode) vs subtractrdataset"

Closes #2211

See merge request isc-projects/bind9!4259

5 years agoAddress TSAN error between dns_rbt_findnode() and subtractrdataset().
Mark Andrews [Tue, 13 Oct 2020 02:00:36 +0000 (13:00 +1100)] 
Address TSAN error between dns_rbt_findnode() and subtractrdataset().

Having dns_rbt_findnode() in previous_closest_nsec() check of
node->data is a optimisation that triggers a TSAN error with
subtractrdataset().  find_closest_nsec() still needs to check if
the NSEC record are active or not and look for a earlier NSEC records
if it isn't.  Set DNS_RBTFIND_EMPTYDATA so node->data isn't referenced
without the node lock being held.

    WARNING: ThreadSanitizer: data race
    Read of size 8 at 0x000000000001 by thread T1 (mutexes: read M1, read M2):
    #0 dns_rbt_findnode lib/dns/rbt.c:1708
    #1 previous_closest_nsec lib/dns/rbtdb.c:3760
    #2 find_closest_nsec lib/dns/rbtdb.c:3942
    #3 zone_find lib/dns/rbtdb.c:4091
    #4 dns_db_findext lib/dns/db.c:536
    #5 query_lookup lib/ns/query.c:5582
    #6 ns__query_start lib/ns/query.c:5505
    #7 query_setup lib/ns/query.c:5229
    #8 ns_query_start lib/ns/query.c:11380
    #9 ns__client_request lib/ns/client.c:2166
    #10 processbuffer netmgr/tcpdns.c:230
    #11 dnslisten_readcb netmgr/tcpdns.c:309
    #12 read_cb netmgr/tcp.c:832
    #13 <null> <null>
    #14 <null> <null>

    Previous write of size 8 at 0x000000000001 by thread T2 (mutexes: write M3):
    #0 subtractrdataset lib/dns/rbtdb.c:7133
    #1 dns_db_subtractrdataset lib/dns/db.c:742
    #2 diff_apply lib/dns/diff.c:368
    #3 dns_diff_apply lib/dns/diff.c:459
    #4 do_one_tuple lib/dns/update.c:247
    #5 update_one_rr lib/dns/update.c:275
    #6 delete_if_action lib/dns/update.c:689
    #7 foreach_rr lib/dns/update.c:471
    #8 delete_if lib/dns/update.c:716
    #9 dns_update_signaturesinc lib/dns/update.c:1948
    #10 receive_secure_serial lib/dns/zone.c:15637
    #11 dispatch lib/isc/task.c:1152
    #12 run lib/isc/task.c:1344
    #13 <null> <null>

    Location is heap block of size 130 at 0x000000000028 allocated by thread T3:
    #0 malloc <null>
    #1 default_memalloc lib/isc/mem.c:713
    #2 mem_get lib/isc/mem.c:622
    #3 mem_allocateunlocked lib/isc/mem.c:1268
    #4 isc___mem_allocate lib/isc/mem.c:1288
    #5 isc__mem_allocate lib/isc/mem.c:2453
    #6 isc___mem_get lib/isc/mem.c:1037
    #7 isc__mem_get lib/isc/mem.c:2432
    #8 create_node lib/dns/rbt.c:2239
    #9 dns_rbt_addnode lib/dns/rbt.c:1202
    #10 dns_rbtdb_create lib/dns/rbtdb.c:8668
    #11 dns_db_create lib/dns/db.c:118
    #12 receive_secure_db lib/dns/zone.c:16154
    #13 dispatch lib/isc/task.c:1152
    #14 run lib/isc/task.c:1344
    #15 <null> <null>

    Mutex M1 (0x000000000040) created at:
    #0 pthread_rwlock_init <null>
    #1 isc_rwlock_init lib/isc/rwlock.c:39
    #2 dns_rbtdb_create lib/dns/rbtdb.c:8527
    #3 dns_db_create lib/dns/db.c:118
    #4 receive_secure_db lib/dns/zone.c:16154
    #5 dispatch lib/isc/task.c:1152
    #6 run lib/isc/task.c:1344
    #7 <null> <null>

    Mutex M2 (0x000000000044) created at:
    #0 pthread_rwlock_init <null>
    #1 isc_rwlock_init lib/isc/rwlock.c:39
    #2 dns_rbtdb_create lib/dns/rbtdb.c:8600
    #3 dns_db_create lib/dns/db.c:118
    #4 receive_secure_db lib/dns/zone.c:16154
    #5 dispatch lib/isc/task.c:1152
    #6 run lib/isc/task.c:1344
    #7 <null> <null>

    Mutex M3 (0x000000000046) created at:
    #0 pthread_rwlock_init <null>
    #1 isc_rwlock_init lib/isc/rwlock.c:39
    #2 dns_rbtdb_create lib/dns/rbtdb.c:8600
    #3 dns_db_create lib/dns/db.c:118
    #4 receive_secure_db lib/dns/zone.c:16154
    #5 dispatch lib/isc/task.c:1152
    #6 run lib/isc/task.c:1344
    #7 <null> <null>

    Thread T1 (running) created by main thread at:
    #0 pthread_create <null>
    #1 isc_thread_create pthreads/thread.c:73
    #2 isc_nm_start netmgr/netmgr.c:232
    #3 create_managers bin/named/main.c:909
    #4 setup bin/named/main.c:1223
    #5 main bin/named/main.c:1523

    Thread T2 (running) created by main thread at:
    #0 pthread_create <null>
    #1 isc_thread_create pthreads/thread.c:73
    #2 isc_taskmgr_create lib/isc/task.c:1434
    #3 create_managers bin/named/main.c:915
    #4 setup bin/named/main.c:1223
    #5 main bin/named/main.c:1523

    Thread T3 (running) created by main thread at:
    #0 pthread_create <null>
    #1 isc_thread_create pthreads/thread.c:73
    #2 isc_taskmgr_create lib/isc/task.c:1434
    #3 create_managers bin/named/main.c:915
    #4 setup bin/named/main.c:1223
    #5 main bin/named/main.c:1523

    SUMMARY: ThreadSanitizer: data race lib/dns/rbt.c:1708 in dns_rbt_findnode

5 years agoMerge branch 'mnowak/revert-4350' into 'main'
Michal Nowak [Tue, 10 Nov 2020 16:51:47 +0000 (16:51 +0000)] 
Merge branch 'mnowak/revert-4350' into 'main'

Revert "Drop bigkey"

See merge request isc-projects/bind9!4369

5 years agoRevert "Drop bigkey"
Michal Nowak [Mon, 9 Nov 2020 10:49:05 +0000 (11:49 +0100)] 
Revert "Drop bigkey"

This reverts commit ef6703351a726eb9a8d8305075f1ee0f5be83516.

It is believed that the bigkey test is still useful.

5 years agoMerge branch 'matthijs-query-header-cleanup' into 'main'
Matthijs Mekking [Tue, 10 Nov 2020 15:01:42 +0000 (15:01 +0000)] 
Merge branch 'matthijs-query-header-cleanup' into 'main'

Cleanup query.h duplicate definitions

See merge request isc-projects/bind9!4381

5 years agoCleanup duplicate definitions in query.h
Matthijs Mekking [Tue, 10 Nov 2020 14:23:12 +0000 (15:23 +0100)] 
Cleanup duplicate definitions in query.h

5 years agoMerge branch '1840-netmgr-tls-layer' into 'main'
Ondřej Surý [Tue, 10 Nov 2020 14:12:53 +0000 (14:12 +0000)] 
Merge branch '1840-netmgr-tls-layer' into 'main'

Server-side TLS support in netmgr

Closes #1840

See merge request isc-projects/bind9!3532

5 years agoCHANGES note
Witold Kręcicki [Wed, 13 May 2020 09:43:46 +0000 (11:43 +0200)] 
CHANGES note

5 years agonetmgr: Add additional safeguards to netmgr/tls.c
Ondřej Surý [Tue, 10 Nov 2020 10:23:05 +0000 (11:23 +0100)] 
netmgr: Add additional safeguards to netmgr/tls.c

This commit adds couple of additional safeguards against running
sends/reads on inactive sockets.  The changes was modeled after the
changes we made to netmgr/tcpdns.c

5 years agoDoT test
Witold Kręcicki [Mon, 12 Oct 2020 21:06:55 +0000 (23:06 +0200)] 
DoT test

Preliminary test for DNSoverTLS - add the dot-port template to system
tests, test a simple query to an authoritative.

5 years agoAdd 'ephemeral' keyword to 'tls' option in listen-on directive.
Witold Kręcicki [Fri, 9 Oct 2020 20:13:45 +0000 (22:13 +0200)] 
Add 'ephemeral' keyword to 'tls' option in listen-on directive.

listen-on tls ephemeral will cause named to create an ephemeral
TLS self-signed certificate and key, stored only in memory.

5 years agoShutdown interface if we can't listen on it to avoid shutdown hang
Witold Kręcicki [Fri, 9 Oct 2020 20:06:41 +0000 (22:06 +0200)] 
Shutdown interface if we can't listen on it to avoid shutdown hang

5 years agoFix a startup/shutdown crash in ns_clientmgr_create
Witold Kręcicki [Fri, 9 Oct 2020 19:24:03 +0000 (21:24 +0200)] 
Fix a startup/shutdown crash in ns_clientmgr_create

5 years agoisc_nm_tls_create_server_ctx can create ephemeral certs
Witold Kręcicki [Fri, 9 Oct 2020 18:57:51 +0000 (20:57 +0200)] 
isc_nm_tls_create_server_ctx can create ephemeral certs

In-memory ephemeral certs creation for easy DoT/DoH deployment.

5 years agoAdd DoT support to bind
Witold Kręcicki [Thu, 1 Oct 2020 11:18:47 +0000 (13:18 +0200)] 
Add DoT support to bind

Parse the configuration of tls objects into SSL_CTX* objects.  Listen on
DoT if 'tls' option is setup in listen-on directive.  Use DoT/DoH ports
for DoT/DoH.

5 years agoadd parser support for TLS configuration options
Evan Hunt [Wed, 16 Sep 2020 19:21:32 +0000 (12:21 -0700)] 
add parser support for TLS configuration options

This commit adds stub parser support and tests for:
- "tls" statement, specifying key and cert.
- an optional "tls" keyvalue in listen-on statements for DoT
  configuration.

Documentation for these options has also been added to the ARM, but
needs further work.

5 years agoreport peer address in TLS mode, and specify protocol
Evan Hunt [Fri, 18 Sep 2020 01:28:37 +0000 (18:28 -0700)] 
report peer address in TLS mode, and specify protocol

- peer address was not being reported correctly by "dig +tls"
- the protocol used is now reported in the dig output: UDP, TCP, or TLS.

5 years agoadd "dig +tls"
Witold Kręcicki [Wed, 22 Jul 2020 06:59:42 +0000 (08:59 +0200)] 
add "dig +tls"

- add "+[no]tls" option to dig to enable TLS mode
- override the default port number in dig from 53 to 853 when using TLS

5 years agonetmgr: server-side TLS support
Witold Kręcicki [Wed, 13 May 2020 15:37:51 +0000 (17:37 +0200)] 
netmgr: server-side TLS support

Add server-side TLS support to netmgr - that includes moving some of the
isc_nm_ functions from tcp.c to a wrapper in netmgr.c calling a proper
tcp or tls function, and a new isc_nm_listentls() function.

Add DoT support to tcpdns - isc_nm_listentlsdns().

5 years agoMerge branch '2252-ns_client_sendraw-is-missing-dnstap-support' into 'main'
Mark Andrews [Tue, 10 Nov 2020 06:41:08 +0000 (06:41 +0000)] 
Merge branch '2252-ns_client_sendraw-is-missing-dnstap-support' into 'main'

Resolve "ns_client_sendraw() is missing DNSTAP support."

Closes #2252

See merge request isc-projects/bind9!4368

5 years agoAdd CHANGES not for [GL #2252]
Mark Andrews [Mon, 9 Nov 2020 05:32:42 +0000 (16:32 +1100)] 
Add CHANGES not for [GL #2252]

5 years agoCheck that DNSTAP captures forwarded UPDATE responses
Mark Andrews [Mon, 9 Nov 2020 05:26:56 +0000 (16:26 +1100)] 
Check that DNSTAP captures forwarded UPDATE responses

5 years agoImplement DNSTAP support in ns_client_sendraw()
Mark Andrews [Mon, 9 Nov 2020 02:44:22 +0000 (13:44 +1100)] 
Implement DNSTAP support in ns_client_sendraw()

ns_client_sendraw() is currently only used to relay UPDATE
responses back to the client.  dns_dt_send() is called with
this assumption.

5 years agoMerge branch '2259-zone_namerd_tostr-called-w-o-lock-being-held' into 'main'
Mark Andrews [Tue, 10 Nov 2020 06:14:21 +0000 (06:14 +0000)] 
Merge branch '2259-zone_namerd_tostr-called-w-o-lock-being-held' into 'main'

Resolve "zone_namerd_tostr called w/o lock being held"

Closes #2259

See merge request isc-projects/bind9!4376

5 years agoLock zone before calling zone_namerd_tostr()
Mark Andrews [Tue, 10 Nov 2020 04:53:06 +0000 (15:53 +1100)] 
Lock zone before calling zone_namerd_tostr()

    WARNING: ThreadSanitizer: data race
    Read of size 8 at 0x000000000001 by thread T1:
    #0 inline_raw lib/dns/zone.c:1375
    #1 zone_namerd_tostr lib/dns/zone.c:15316
    #2 dns_zone_name lib/dns/zone.c:15391
    #3 xfrin_log lib/dns/xfrin.c:1605
    #4 xfrin_destroy lib/dns/xfrin.c:1477
    #5 dns_xfrin_detach lib/dns/xfrin.c:739
    #6 xfrin_connect_done lib/dns/xfrin.c:970
    #7 tcpdnsconnect_cb netmgr/tcpdns.c:786
    #8 tcp_connect_cb netmgr/tcp.c:292
    #9 <null> <null>
    #10 <null> <null>

    Previous write of size 8 at 0x000000000001 by thread T2 (mutexes: write M1):
    #0 zone_shutdown lib/dns/zone.c:14462
    #1 dispatch lib/isc/task.c:1152
    #2 run lib/isc/task.c:1344
    #3 <null> <null>

    Location is heap block of size 2769 at 0x000000000013 allocated by thread T3:
    #0 malloc <null>
    #1 default_memalloc lib/isc/mem.c:713
    #2 mem_get lib/isc/mem.c:622
    #3 mem_allocateunlocked lib/isc/mem.c:1268
    #4 isc___mem_allocate lib/isc/mem.c:1288
    #5 isc__mem_allocate lib/isc/mem.c:2453
    #6 isc___mem_get lib/isc/mem.c:1037
    #7 isc__mem_get lib/isc/mem.c:2432
    #8 dns_zone_create lib/dns/zone.c:984
    #9 configure_zone bin/named/server.c:6502
    #10 do_addzone bin/named/server.c:13391
    #11 named_server_changezone bin/named/server.c:13788
    #12 named_control_docommand bin/named/control.c:207
    #13 control_command bin/named/controlconf.c:392
    #14 dispatch lib/isc/task.c:1152
    #15 run lib/isc/task.c:1344
    #16 <null> <null>

5 years agoMerge branch '2230-legacy-system-test-fails-intermittently' into 'main'
Mark Andrews [Mon, 9 Nov 2020 22:18:29 +0000 (22:18 +0000)] 
Merge branch '2230-legacy-system-test-fails-intermittently' into 'main'

Resolve "legacy system test fails intermittently"

Closes #2207

See merge request isc-projects/bind9!4295

5 years agoRetry edns512 multiple times to trigger fallback to edns at 512
Mark Andrews [Fri, 23 Oct 2020 22:36:33 +0000 (09:36 +1100)] 
Retry edns512 multiple times to trigger fallback to edns at 512

We want named to have slow resolving (multiple retries) when
there is a very small working MTU

5 years agoFixup legacy test to account for not falling back to EDNS 512 lookups.
Mark Andrews [Fri, 23 Oct 2020 02:33:34 +0000 (13:33 +1100)] 
Fixup legacy test to account for not falling back to EDNS 512 lookups.

The SOA lookup for edns512 could succeed if the negative response
for ns.edns512/AAAA completed before all the edns512/SOA query
attempts are made.  The ns.edns512/AAAA lookup returns tc=1 and
the SOA record is cached after processing the NODATA response.
Lookup a TXT record at edns512 and look it up instead of the
SOA record.

Removed 'checking that TCP failures do not influence EDNS statistics
in the ADB' as it is no longer appropriate.

5 years agoMerge branch '2258-xfrin-shutdown-race' into 'main'
Evan Hunt [Mon, 9 Nov 2020 21:45:14 +0000 (21:45 +0000)] 
Merge branch '2258-xfrin-shutdown-race' into 'main'

address some possible shutdown races in xfrin

Closes #2258

See merge request isc-projects/bind9!4374

5 years agoaddress some possible shutdown races in xfrin
Evan Hunt [Mon, 9 Nov 2020 20:33:37 +0000 (12:33 -0800)] 
address some possible shutdown races in xfrin

there were two failures during observed in testing, both occurring
when 'rndc halt' was run rather than 'rndc stop' - the latter dumps
zone contents to disk and presumably introduced enough delay to
prevent the races:

- a failure when the zone was shut down and called dns_xfrin_detach()
  before the xfrin had finished connecting; the connect timeout
  terminated without detaching its handle
- a failure when the tcpdns socket timer fired after the outerhandle
  had already been cleared.

this commit incidentally addresses a failure observed in mutexatomic
due to a variable having been initialized incorrectly.

5 years agoMerge branch '1840-netmgr-tls-layer-link-with-libssl' into 'main'
Ondřej Surý [Mon, 9 Nov 2020 15:38:22 +0000 (15:38 +0000)] 
Merge branch '1840-netmgr-tls-layer-link-with-libssl' into 'main'

Add support to link with libssl

See merge request isc-projects/bind9!4373

5 years agoAdd libssl libraries to Windows build
Ondřej Surý [Sat, 10 Oct 2020 05:26:18 +0000 (07:26 +0200)] 
Add libssl libraries to Windows build

This commit extends the perl Configure script to also check for libssl
in addition to libcrypto and change the vcxproj source files to link
with both libcrypto and libssl.

5 years agoautoconf: link with libssl
Witold Kręcicki [Wed, 13 May 2020 15:37:51 +0000 (17:37 +0200)] 
autoconf: link with libssl

This is prerequisite to adding DoT and DoH support to BIND 9.

5 years agoMerge branch '2016-xfrin-netmgr' into 'main'
Ondřej Surý [Mon, 9 Nov 2020 14:45:17 +0000 (14:45 +0000)] 
Merge branch '2016-xfrin-netmgr' into 'main'

use netmgr for xfrin

Closes #2016

See merge request isc-projects/bind9!4246

5 years agoCHANGES and release notes
Evan Hunt [Wed, 7 Oct 2020 21:07:36 +0000 (14:07 -0700)] 
CHANGES and release notes

5 years agoRefactor the xfrin reference counting
Ondřej Surý [Mon, 9 Nov 2020 10:32:55 +0000 (11:32 +0100)] 
Refactor the xfrin reference counting

Previously, the xfrin object relied on four different reference counters
(`refs`, `connects`, `sends`, `recvs`) and destroyed the xfrin object
only if all of them were zero.  This commit reduces the reference
counting only to the `references` (renamed from `refs`) counter.  We
keep the existing `connects`, `sends` and `recvs` as safe guards, but
they are not formally needed.

5 years agoremove isc_task from xfrin
Evan Hunt [Fri, 9 Oct 2020 23:38:30 +0000 (16:38 -0700)] 
remove isc_task from xfrin

since the network manager is now handling timeouts, xfrin doesn't
need an isc_task object.

it may be necessary to revert this later if we find that it's
important for zone_xfrdone() to be executed in the zone task context.
currently things seem to be working well without that, though.

5 years agoremove isc_timer from xfrin
Evan Hunt [Fri, 9 Oct 2020 23:34:22 +0000 (16:34 -0700)] 
remove isc_timer from xfrin

the network manager can now handle timeouts, so it isn't
necessary for xfrin to use isc_timer for the purpose any
longer.

5 years agouse netmgr for xfrin
Evan Hunt [Sun, 6 Sep 2020 07:38:50 +0000 (00:38 -0700)] 
use netmgr for xfrin

Use isc_nm_tcpdnsconnect() in xfrin.c for zone transfers.

5 years agoMerge branch 'mnowak/test-with-DDEBUG' into 'main'
Michal Nowak [Mon, 9 Nov 2020 12:36:24 +0000 (12:36 +0000)] 
Merge branch 'mnowak/test-with-DDEBUG' into 'main'

Enable debug build on Tumbleweed in CI

See merge request isc-projects/bind9!4367

5 years agoEnable debug build on Tumbleweed in CI
Michal Nowak [Fri, 6 Nov 2020 14:41:33 +0000 (15:41 +0100)] 
Enable debug build on Tumbleweed in CI

5 years agoMerge branch '2140-dig-netmgr' into 'main'
Evan Hunt [Sun, 8 Nov 2020 22:06:04 +0000 (22:06 +0000)] 
Merge branch '2140-dig-netmgr' into 'main'

Resolve "convert dig and friends to use the netmgr"

Closes #2140

See merge request isc-projects/bind9!4115

5 years agoCHANGES and release note
Evan Hunt [Fri, 11 Sep 2020 20:47:27 +0000 (13:47 -0700)] 
CHANGES and release note