A flaw was found in dnsmasq before 2.83. A buffer overflow vulnerability was discovered in the way dnsmasq extract names from DNS packets before validating them with DNSSEC data. An attacker on the network, who can create valid DNS replies, could use this flaw to cause an overflow with arbitrary data in a heap-allocated memory, possibly executing code on the machine. The flaw is in the rfc1035.c:extract_name() function, which writes data to the memory pointed by name assuming MAXDNAME*2 bytes are available in the buffer. However, in some code execution paths, it is possible extract_name() gets passed an offset from the base buffer, thus reducing, in practice, the number of available bytes that can be written in the buffer. The highest threat from this vulnerability is to data confidentiality and integrity as well as system availability.
A heap overflow condition is a buffer overflow, where the buffer that can be overwritten is allocated in the heap portion of memory, generally meaning that the buffer was allocated using a routine such as malloc().
Name | Vendor | Start Version | End Version |
---|---|---|---|
Dnsmasq | Thekelleys | * | 2.83 (excluding) |
Red Hat Enterprise Linux 8 | RedHat | dnsmasq-0:2.79-13.el8_3.1 | * |
Red Hat Enterprise Linux 8.1 Extended Update Support | RedHat | dnsmasq-0:2.79-6.el8_1.1 | * |
Red Hat Enterprise Linux 8.2 Extended Update Support | RedHat | dnsmasq-0:2.79-11.el8_2.2 | * |
Dnsmasq | Ubuntu | bionic | * |
Dnsmasq | Ubuntu | devel | * |
Dnsmasq | Ubuntu | focal | * |
Dnsmasq | Ubuntu | groovy | * |
Dnsmasq | Ubuntu | hirsute | * |
Dnsmasq | Ubuntu | impish | * |
Dnsmasq | Ubuntu | jammy | * |
Dnsmasq | Ubuntu | kinetic | * |
Dnsmasq | Ubuntu | lunar | * |
Dnsmasq | Ubuntu | mantic | * |
Dnsmasq | Ubuntu | noble | * |
Dnsmasq | Ubuntu | oracular | * |
Dnsmasq | Ubuntu | precise/esm | * |
Dnsmasq | Ubuntu | trusty | * |
Dnsmasq | Ubuntu | trusty/esm | * |
Dnsmasq | Ubuntu | upstream | * |
Dnsmasq | Ubuntu | xenial | * |