MaraDNS is open-source software that implements the Domain Name System (DNS). In version 3.5.0024 and prior, a remotely exploitable integer underflow vulnerability in the DNS packet decompression function allows an attacker to cause a Denial of Service by triggering an abnormal program termination. The vulnerability exists in the decomp_get_rddata
function within the Decompress.c
file. When handling a DNS packet with an Answer RR of qtype 16 (TXT record) and any qclass, if the rdlength
is smaller than rdata
, the result of the line Decompress.c:886
is a negative number len = rdlength - total;
. This value is then passed to the decomp_append_bytes
function without proper validation, causing the program to attempt to allocate a massive chunk of memory that is impossible to allocate. Consequently, the program exits with an error code of 64, causing a Denial of Service. One proposed fix for this vulnerability is to patch Decompress.c:887
by breaking if(len <= 0)
, which has been incorporated in version 3.5.0036 via commit bab062bde40b2ae8a91eecd522e84d8b993bab58.
{ "availability": "Available with Ubuntu Pro: https://ubuntu.com/pro", "ubuntu_priority": "medium", "binaries": [ { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "duende" }, { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "duende-dbgsym" }, { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "maradns" }, { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "maradns-dbgsym" }, { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "maradns-deadwood" }, { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "maradns-deadwood-dbgsym" }, { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "maradns-docs" }, { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "maradns-zoneserver" }, { "binary_version": "2.0.13-1ubuntu0.1~esm1", "binary_name": "maradns-zoneserver-dbgsym" } ] }
{ "availability": "Available with Ubuntu Pro: https://ubuntu.com/pro", "ubuntu_priority": "medium", "binaries": [ { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "duende" }, { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "duende-dbgsym" }, { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "maradns" }, { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "maradns-dbgsym" }, { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "maradns-deadwood" }, { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "maradns-deadwood-dbgsym" }, { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "maradns-docs" }, { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "maradns-zoneserver" }, { "binary_version": "2.0.13-1.2ubuntu0.1~esm1", "binary_name": "maradns-zoneserver-dbgsym" } ] }
{ "availability": "No subscription required", "ubuntu_priority": "medium", "binaries": [ { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "duende" }, { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "duende-dbgsym" }, { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "maradns" }, { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "maradns-dbgsym" }, { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "maradns-deadwood" }, { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "maradns-deadwood-dbgsym" }, { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "maradns-docs" }, { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "maradns-zoneserver" }, { "binary_version": "2.0.13-1.4+deb11u1build0.20.04.1", "binary_name": "maradns-zoneserver-dbgsym" } ] }
{ "availability": "No subscription required", "ubuntu_priority": "medium", "binaries": [ { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "duende" }, { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "duende-dbgsym" }, { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "maradns" }, { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "maradns-dbgsym" }, { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "maradns-deadwood" }, { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "maradns-deadwood-dbgsym" }, { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "maradns-docs" }, { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "maradns-zoneserver" }, { "binary_version": "2.0.13-1.4+deb11u1build0.22.04.1", "binary_name": "maradns-zoneserver-dbgsym" } ] }