]> git.ipfire.org Git - thirdparty/bind9.git/log
thirdparty/bind9.git
5 years agoUnify whitespace in bin/tests/system/run.sh.in
Mark Andrews [Tue, 20 Oct 2020 23:11:39 +0000 (10:11 +1100)] 
Unify whitespace in bin/tests/system/run.sh.in

Replace tabs with spaces to make whitespace consistent across the entire
bin/tests/system/run.sh.in script.

5 years agoMerge branch '2281-cid-313104-error-handling-issues-in-lib-ns-query-c' into 'main'
Diego dos Santos Fronza [Thu, 26 Nov 2020 14:57:02 +0000 (14:57 +0000)] 
Merge branch '2281-cid-313104-error-handling-issues-in-lib-ns-query-c' into 'main'

Resolve "CID 313104: Error handling issues in lib/ns/query.c"

Closes #2281

See merge request isc-projects/bind9!4416

5 years agoSilence coverity warnings in query.c
Diego Fronza [Wed, 25 Nov 2020 19:01:06 +0000 (16:01 -0300)] 
Silence coverity warnings in query.c

Return value of dns_db_getservestalerefresh() and
dns_db_getservestalettl() functions were previously unhandled.

This commit purposefully ignore those return values since there is
no side effect if those results are != ISC_R_SUCCESS, it also supress
Coverity warnings.

5 years agoMerge branch '1620-dnssec-policy-nsec3-saltlen-followup' into 'main'
Matthijs Mekking [Thu, 26 Nov 2020 14:40:34 +0000 (14:40 +0000)] 
Merge branch '1620-dnssec-policy-nsec3-saltlen-followup' into 'main'

Add one missing check to nsec3param unit test

See merge request isc-projects/bind9!4432

5 years agoAdd one missing check to nsec3param unit test
Matthijs Mekking [Thu, 26 Nov 2020 12:37:24 +0000 (13:37 +0100)] 
Add one missing check to nsec3param unit test

Caught this missing check with clang-build while backporting #1620
to the v9_16 branch.

5 years agoMerge branch 'michal/use-proper-cmocka-macros-for-pointer-checks' into 'main'
Michał Kępień [Thu, 26 Nov 2020 12:12:02 +0000 (12:12 +0000)] 
Merge branch 'michal/use-proper-cmocka-macros-for-pointer-checks' into 'main'

Use proper cmocka macros for pointer checks

See merge request isc-projects/bind9!4415

5 years agoUse proper cmocka macros for pointer checks
Michał Kępień [Thu, 26 Nov 2020 12:10:40 +0000 (13:10 +0100)] 
Use proper cmocka macros for pointer checks

Make sure pointer checks in unit tests use cmocka assertion macros
dedicated for use with pointers instead of those dedicated for use with
integers or booleans.

5 years agoMerge branch '2310-update-release-checklist' into 'main'
Michał Kępień [Thu, 26 Nov 2020 12:08:09 +0000 (12:08 +0000)] 
Merge branch '2310-update-release-checklist' into 'main'

Update release checklist

See merge request isc-projects/bind9!4425

5 years agoUpdate release checklist
Michał Kępień [Thu, 26 Nov 2020 12:07:19 +0000 (13:07 +0100)] 
Update release checklist

Add an item to the release checklist to make sure the man pages
generated during release preparation are formatted correctly.

5 years agoMerge branch 'v9_17_7-release' into 'main'
Michał Kępień [Thu, 26 Nov 2020 11:19:45 +0000 (11:19 +0000)] 
Merge branch 'v9_17_7-release' into 'main'

Merge 9.17.7 release branch

See merge request isc-projects/bind9!4426

5 years agoSet up release notes for BIND 9.17.8
Michał Kępień [Thu, 26 Nov 2020 11:16:49 +0000 (12:16 +0100)] 
Set up release notes for BIND 9.17.8

5 years agoBump BIND_BASELINE_VERSION for ABI checks
Michał Kępień [Thu, 26 Nov 2020 11:16:49 +0000 (12:16 +0100)] 
Bump BIND_BASELINE_VERSION for ABI checks

5 years agoUpdate BIND version to 9.17.7
Michał Kępień [Mon, 16 Nov 2020 11:40:34 +0000 (12:40 +0100)] 
Update BIND version to 9.17.7

5 years agoAdd a CHANGES marker
Michał Kępień [Mon, 16 Nov 2020 11:40:34 +0000 (12:40 +0100)] 
Add a CHANGES marker

5 years agoUpdate library API versions
Michał Kępień [Mon, 16 Nov 2020 11:40:34 +0000 (12:40 +0100)] 
Update library API versions

5 years agoMerge branch 'michal/prepare-release-notes-for-bind-9.17.7' into 'v9_17_7-release'
Michał Kępień [Mon, 16 Nov 2020 11:30:59 +0000 (11:30 +0000)] 
Merge branch 'michal/prepare-release-notes-for-bind-9.17.7' into 'v9_17_7-release'

Prepare release notes for BIND 9.17.7

See merge request isc-private/bind9!220

5 years agoPrepare release notes for BIND 9.17.7
Michał Kępień [Mon, 16 Nov 2020 10:00:50 +0000 (11:00 +0100)] 
Prepare release notes for BIND 9.17.7

5 years agoAdd release note for GL #2244
Michał Kępień [Mon, 16 Nov 2020 10:00:50 +0000 (11:00 +0100)] 
Add release note for GL #2244

5 years agoAdd release note for GL #2236
Michał Kępień [Mon, 16 Nov 2020 10:00:50 +0000 (11:00 +0100)] 
Add release note for GL #2236

5 years agoAdd release note for GL #1736
Michał Kępień [Mon, 16 Nov 2020 10:00:50 +0000 (11:00 +0100)] 
Add release note for GL #1736

5 years agoReorder release notes
Michał Kępień [Mon, 16 Nov 2020 10:00:50 +0000 (11:00 +0100)] 
Reorder release notes

5 years agoTweak and reword release notes
Michał Kępień [Mon, 16 Nov 2020 10:00:50 +0000 (11:00 +0100)] 
Tweak and reword release notes

5 years agoTweak and reword recent CHANGES entries
Michał Kępień [Mon, 16 Nov 2020 10:00:50 +0000 (11:00 +0100)] 
Tweak and reword recent CHANGES entries

5 years agoRemove any mention of "make depend" from README.md
Michał Kępień [Mon, 16 Nov 2020 10:00:50 +0000 (11:00 +0100)] 
Remove any mention of "make depend" from README.md

5 years agoMerge branch '1620-dnssec-policy-nsec3-saltlen' into 'main'
Matthijs Mekking [Thu, 26 Nov 2020 10:12:26 +0000 (10:12 +0000)] 
Merge branch '1620-dnssec-policy-nsec3-saltlen' into 'main'

Resolve "dnssec-policy NSEC3 support"

Closes #1620

See merge request isc-projects/bind9!4299

5 years agoAdd NSEC3PARAM unit test, refactor zone.c
Matthijs Mekking [Fri, 13 Nov 2020 11:26:05 +0000 (12:26 +0100)] 
Add NSEC3PARAM unit test, refactor zone.c

Add unit test to ensure the right NSEC3PARAM event is scheduled in
'dns_zone_setnsec3param()'.  To avoid scheduling and managing actual
tasks, split up the 'dns_zone_setnsec3param()' function in two parts:

1. 'dns__zone_lookup_nsec3param()' that will check if the requested
   NSEC3 parameters already exist, and if a new salt needs to be
   generated.

2. The actual scheduling of the new NSEC3PARAM event (if needed).

5 years agoDetect NSEC3 salt collisions
Matthijs Mekking [Thu, 5 Nov 2020 10:12:24 +0000 (11:12 +0100)] 
Detect NSEC3 salt collisions

When generating a new salt, compare it with the previous NSEC3
paremeters to ensure the new parameters are different from the
previous ones.

This moves the salt generation call from 'bin/named/*.s' to
'lib/dns/zone.c'. When setting new NSEC3 parameters, you can set a new
function parameter 'resalt' to enforce a new salt to be generated. A
new salt will also be generated if 'salt' is set to NULL.

Logging salt with zone context can now be done with 'dnssec_log',
removing the need for 'dns_nsec3_log_salt'.

5 years agoAdd zone context to "generated salt" logs
Matthijs Mekking [Wed, 4 Nov 2020 15:30:19 +0000 (16:30 +0100)] 
Add zone context to "generated salt" logs

5 years agoMove logging of salt in separate function
Matthijs Mekking [Tue, 27 Oct 2020 09:23:16 +0000 (10:23 +0100)] 
Move logging of salt in separate function

There may be a desire to log the salt without losing the context
of log module, level, and category.

5 years agoChange nsec3param salt config to saltlen
Matthijs Mekking [Fri, 23 Oct 2020 13:02:19 +0000 (15:02 +0200)] 
Change nsec3param salt config to saltlen

Upon request from Mark, change the configuration of salt to salt
length.

Introduce a new function 'dns_zone_checknsec3aram' that can be used
upon reconfiguration to check if the existing NSEC3 parameters are
in sync with the configuration. If a salt is used that matches the
configured salt length, don't change the NSEC3 parameters.

5 years agoAdd check for NSEC3 and key algorithms
Matthijs Mekking [Mon, 19 Oct 2020 08:19:52 +0000 (10:19 +0200)] 
Add check for NSEC3 and key algorithms

NSEC3 is not backwards compatible with key algorithms that existed
before the RFC 5155 specification was published.

5 years agoDisable one nsec3 test due to GL #2216
Matthijs Mekking [Wed, 14 Oct 2020 14:56:22 +0000 (16:56 +0200)] 
Disable one nsec3 test due to GL #2216

This known bug makes the test fail. There is no trivial fix so disable
test case for now.

5 years agoAdd changes and notes for kasp NSEC3 support
Matthijs Mekking [Wed, 14 Oct 2020 08:10:01 +0000 (10:10 +0200)] 
Add changes and notes for kasp NSEC3 support

This feature is news worthy.

5 years agoAdd some NSEC3 optout tests
Matthijs Mekking [Wed, 14 Oct 2020 08:03:13 +0000 (10:03 +0200)] 
Add some NSEC3 optout tests

Make sure that just changing the optout value recreates the chain.

5 years agoCheck nsec3param configuration values
Matthijs Mekking [Tue, 13 Oct 2020 15:48:22 +0000 (17:48 +0200)] 
Check nsec3param configuration values

Check 'nsec3param' configuration for the number of iterations.  The
maximum number of iterations that are allowed are based on the key
size (see https://tools.ietf.org/html/rfc5155#section-10.3).

Check 'nsec3param' configuration for correct salt. If the string is
not "-" or hex-based, this is a bad salt.

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