]> git.ipfire.org Git - thirdparty/bind9.git/commitdiff
Tweak and reword release notes
authorAndoni Duarte Pintado <andoni@isc.org>
Fri, 8 May 2026 09:46:37 +0000 (11:46 +0200)
committerAndoni Duarte Pintado <andoni@isc.org>
Fri, 8 May 2026 13:32:06 +0000 (15:32 +0200)
doc/notes/notes-9.18.49.rst

index 545e028d0e122823cb00dd2b38bb4b5f4ceaccb4..3bd35d7bff7889229ba6784d993eac2666b44bce 100644 (file)
@@ -15,115 +15,121 @@ Notes for BIND 9.18.49
 Security Fixes
 ~~~~~~~~~~~~~~
 
-- Fix outgoing zone transfers' quota issue.
-
-  Unauthorized clients could consume outgoing zone transfers quota and
-  block authorized zone transfer clients. This has been fixed.
-  :gl:`#3589`
+- Limit resolver server list size. :cve:`2026-3592`
 
-- [CVE-2026-3592] Limit resolver server list size.
-
-  When resolving a domain with many nameservers that share overlapping
+  When resolving a domain with many nameservers that shared overlapping
   IP addresses (e.g., 10 NS records all pointing at the same set of
   addresses), BIND could previously waste time querying duplicate
-  addresses and build up excessively large server lists. Deduplicate
-  addresses in the resolver's server list so that each unique IP is only
+  addresses and build up excessively large server lists. Addresses in
+  the resolver's server list are now deduplicated so that each unique IP is only
   queried once per resolution attempt, regardless of how many NS records
-  point to it and cap the number of addresses stored per nameserver name
-  to 6 (combined A and AAAA), preventing memory and CPU overhead from
-  domains with unusually large NS/glue sets. :gl:`#5641`
+  point to it. The number of addresses stored per nameserver name
+  is also now capped at six (combined A and AAAA), preventing memory and CPU overhead from
+  domains with unusually large NS/glue sets.
+
+  ISC would like to thank Shuhan Zhang from Tsinghua University for
+  reporting this issue. :gl:`#5641`
 
-- [CVE-2026-3039] Fix GSS-API resource leak.
+- Fix GSS-API resource leak. :cve:`2026-3039`
 
-  Fixed a memory leak where each GSS-API TKEY negotiation leaked a
+  A memory leak was fixed where each GSS-API TKEY negotiation leaked a
   security context inside the GSS library. An unauthenticated attacker
   could exhaust server memory by sending repeated TKEY queries to a
-  server with tkey-gssapi-keytab configured. The leaked memory was
+  server with :any:`tkey-gssapi-keytab` configured. The leaked memory was
   allocated by the GSS library, bypassing BIND's memory accounting.
 
   Multi-round GSS-API negotiation (GSS_S_CONTINUE_NEEDED) is now
   rejected, as BIND never supported it correctly and Kerberos/SPNEGO
   completes in a single round.
 
-  Also implemented missing RFC 3645 requirement: the client now verifies
-  that mutual authentication and integrity flags are granted by the
-  GSS-API mechanism (Section 3.1.1). :gl:`#5752`
-
-- [CVE-2026-5950] Avoid unbounded recursion loop.
-
-  A bug during bad server handling could cause the resolver to enter an
-  infinite loop, continuously sending queries to an upstream server with
-  no exit condition, until the resolver query timeout was hit. This has
-  been fixed.
+  ISC would like to thank Vitaly Simonovich for bringing this
+  vulnerability to our attention. :gl:`#5752`
 
-  ISC would like to thank Billy Baraja (BielraX) for bringing this issue
-  to our attention. :gl:`#5804`
-
-- [CVE-2026-5946] Disable recursion, UPDATE, and NOTIFY for non-IN
-  views.
+- Disable recursion, UPDATE, and NOTIFY for non-IN views.
+  :cve:`2026-5946`
 
   Recursion, dynamic updates (UPDATE), and zone change notifications
   (NOTIFY) are now disabled for views with a class other than IN (such
   as CHAOS or HESIOD); authoritative service for non-IN zones (e.g.
   version.bind in class CHAOS) continues to work as before. Servers
-  configured with recursion yes in a non-IN view will log a warning at
-  startup, and named-checkconf flags the same condition. UPDATE and
+  configured with :namedconf:ref:`recursion yes; <recursion>`
+  in a non-IN view log a warning at
+  startup, and :iscman:`named-checkconf` flags the same condition. UPDATE and
   NOTIFY messages that specify the meta-classes ANY or NONE in the
   question section are now rejected with FORMERR.
 
   This addresses a set of closely related security issues collectively
   identified as CVE-2026-5946. ISC would like to thank Mcsky23 for
-  bringing these issues to our attention.
+  bringing these issues to our attention. :gl:`#5784`
+
+- Avoid unbounded recursion loop. :cve:`2026-5950`
+
+  A bug during bad server handling could cause the resolver to enter an
+  infinite loop, continuously sending queries to an upstream server with
+  no exit condition, until the resolver query timeout was hit. This has
+  been fixed.
+
+  ISC would like to thank Billy Baraja (BielraX) for bringing this issue
+  to our attention. :gl:`#5804`
+
+- Fix outgoing zone transfers' quota issue.
+
+  Unauthorized clients could consume the entire outgoing zone-transfer quota and
+  block authorized zone transfer clients. This has been fixed.
+  :gl:`#3589`
 
 Feature Changes
 ~~~~~~~~~~~~~~~
 
 - Fix CPU spikes and slow queries when cache approaches memory limit.
 
-  When the cache grew close to the configured max-cache-size, every
-  subsequent entry triggered all worker threads to run cache cleanup at
-  once, causing CPU spikes and a drop in query throughput. Cleanup is
-  now spread probabilistically across inserts as memory approaches the
-  limit, so the work is distributed evenly instead of piling up at the
-  threshold.
+  Cache cleanup is now spread probabilistically to avoid CPU usage spikes and a
+  drop in query throughput. :gl:`#5891`
 
 Bug Fixes
 ~~~~~~~~~
 
-- Fix named crash when processing SIG records in dynamic updates.
+- Fix :iscman:`named` crash when processing SIG records in dynamic updates.
 
   Previously, :iscman:`named` could abort if a client sent a dynamic
   update containing a SIG record (the legacy signature type) to a zone
   configured with an update-policy. The function `dns_db_findrdataset`
   had an incorrect requirements prerequisite that prevented SIG records
-  being looked up, which was triggered as part of processing an UPDATE
+  from being looked up, which was triggered as part of processing an UPDATE
   request and could be triggered remotely by any client permitted to
   send updates. This has been fixed by ensuring that SIG records are
   handled consistently with RRSIG records during update processing.
   :gl:`#5818`
 
+- Fix :option:`rndc modzone` behavior for a zone in named.conf.
+
+  If a zone was present in the configuration file and not originally
+  added by :option:`rndc addzone`, :option:`rndc modzone` for that zone would succeed
+  once but subsequent :option:`rndc modzone` attempts would fail. This has been
+  fixed. :gl:`#5826`
+
 - Fix zone verification of NSEC3 signed zones.
 
   Previously, when computing the compressed bitmap during verification
   of an NSEC3-signed zone, an undersized buffer was used that resulted
   in an out-of-bounds write if there were too many active windows in the
-  bitmap. This impacted mirror zones which are NSEC3-signed,
-  `dnssec-signzone` and `dnssec-verifyzone`. This has been fixed.
+  bitmap. This impacted the mirror zones which are NSEC3-signed,
+  :iscman:`dnssec-signzone` and :iscman:`dnssec-verify`. This has been fixed.
   :gl:`#5834`
 
-- Prevent a crash when using both dns64 and filter-aaaa.
+- Prevent a crash when using both :any:`dns64` and :any:`filter-aaaa`.
 
-  An assertion failure could be triggered if both `dns64` and the
-  `filter-aaaa` plugin were in use simultaneously. This happened if the
+  An assertion failure could be triggered if both :any:`dns64` and the
+  :any:`filter-aaaa` plugin were in use simultaneously. This happened if the
   plugin triggered a second recursion process, which then attempted to
   store DNS64 state information in a pointer that had already been set
   by the original recursion process. This has been fixed. :gl:`#5854`
 
-- Remove unnecessary dns_name_free call.
+- Fixed an assertion failure when processing catalog zones.
 
-  When processing a catalog zone member's primaries definition and there
-  is a TXT record containing an invalid name TSIG key name,
-  dns_name_free was incorrectly called triggering an assertion. This has
+  If a TXT record containing an invalid name TSIG key name was found
+  when processing a catalog zone member's primaries definition,
+  ``dns_name_free`` was incorrectly called, triggering an assertion. This has
   been fixed. :gl:`#5858`
 
 - Prevent malicious DNSSEC zones from exhausting validator CPU.
@@ -134,9 +140,10 @@ Bug Fixes
   validator now rejects such DNSKEYs, matching the limit already applied
   to keys read from files or HSMs. :gl:`#5881`
 
-- Fix rndc-confgen aborting on HMAC-SHA-384/512 keys above 512 bits.
+- Fix :iscman:`rndc-confgen` aborting on HMAC-SHA-384/512 keys above 512 bits.
 
-  `rndc-confgen -A hmac-sha384` and `-A hmac-sha512` documented a `-b`
+  :iscman:`rndc-confgen` (with either ``-A hmac-sha384`` or
+  ``-A hmac-sha512``) previously documented a ``-b``
   range of 1..1024, but any value above 512 aborted on hardened builds
   instead of producing a key. The full advertised range now works.
   :gl:`#5903`
@@ -150,35 +157,36 @@ Bug Fixes
   placement of entries cannot be predicted or influenced from the
   network. :gl:`#5906`
 
-- Fix a bug in allow-query/allow-transfer catalog zone custom
+- Fix a bug in :any:`allow-query`/:any:`allow-transfer` catalog zone custom
   properties.
 
   The :iscman:`named` process could terminate unexpectedly when
-  processing a catalog zone with an invalid ``allow-query`` or
-  ``allow-transfer`` custom property (i.e. having a non-APL type)
+  processing a catalog zone with an invalid :any:`allow-query` or
+  :any:`allow-transfer` custom property (i.e. having a non-APL type)
   coexisting with the valid property. This has been fixed. :gl:`#5941`
 
-- Fix a memory leak issue in the catalog zones.
+- Fix a memory leak issue in catalog zones.
 
   The :iscman:`named` process could leak small amounts of memory when
   processing a catalog zone entry which had defined custom primary
-  servers with TSIG keys using both the regular ``primaries`` custom
-  property syntax and the legacy alternative syntax (``masters``) at the
+  servers with TSIG keys, if both the regular ``primaries`` custom
+  property syntax and the legacy alternative syntax (``masters``) were used at the
   same time. This has been fixed. :gl:`#5943`
 
-- Fix suppressed missing-glue check in named-checkzone.
+- Fix suppressed missing-glue check in :iscman:`named-checkzone`.
 
-  named-checkzone and named-checkconf -z silently skipped the
-  missing-glue check for any NS name that had already triggered an
-  extra-AAAA-glue warning, so zones missing required A glue could pass
-  validation and be deployed with broken delegations.
+  :iscman:`named-checkzone` and :option:`named-checkconf -z` silently
+  skipped the missing-glue check for any NS name that had already
+  triggered an extra-AAAA-glue warning, so zones missing required A glue
+  could pass validation and be deployed with broken delegations.
+  :gl:`!11899`
 
 - Reject record sets too large to serve in DNS.
 
-  When BIND was asked to store a record set whose total size exceeds
-  what fits in a DNS message, it would allocate memory and build the
+  When BIND was asked to store a record set whose total size exceeded
+  what fit in a DNS message, it would allocate memory and build the
   structure, then fail later at response time. Such oversized record
   sets are now rejected at the time of storage with an error, avoiding
-  wasted work on data that can never be served.
+  wasted work on data that can never be served. :gl:`!11963`