OpenWrt Project has Stack-based Buffer Overflow in DNS PTR Query
OpenWrt Project is a Linux operating system targeting embedded devices. In versions prior to 24.10.6 and 25.12.1, the mdns daemon has a Stack-based Buffer Overflow vulnerability in the parse_question function. The issue is triggered by PTR queries for reverse DNS domains (.in-addr.arpa and .ip6.arpa). DNS packets received on UDP port 5353 are expanded by dn_expand into an 8096-byte global buffer (name_buffer), which is then copied via an unbounded strcpy into a fixed 256-byte stack buffer when handling TYPE_PTR queries. The overflow is possible because dn_expand converts non-printable ASCII bytes (e.g., 0x01) into multi-character octal representations (e.g., \001), significantly inflating the expanded name beyond the stack buffer's capacity. A crafted DNS packet can exploit this expansion behavior to overflow the stack buffer, making the vulnerability reachable through normal multicast DNS packet processing. This issue has been fixed in versions 24.10.6 and 25.12.1.
References
- https://github.com/openwrt/openwrt/security/advisories/GHSA-7c3j-f7w2-p8f6 x_refsource_CONFIRM
- https://github.com/openwrt/openwrt/releases/tag/v24.10.6 x_refsource_MISC
- https://github.com/openwrt/openwrt/releases/tag/v25.12.1 x_refsource_MISC
Affected products
- ==>= 25.12.0-rc1, < 25.12.1
- ==< 24.10.6
Matching in nixpkgs
pkgs.terraform-providers.openwrt
None
pkgs.python312Packages.openwrt-luci-rpc
Python module for interacting with the OpenWrt Luci RPC interface
pkgs.python312Packages.openwrt-ubus-rpc
Python API for OpenWrt ubus RPC
pkgs.python313Packages.openwrt-luci-rpc
Python module for interacting with the OpenWrt Luci RPC interface
pkgs.python313Packages.openwrt-ubus-rpc
Python API for OpenWrt ubus RPC
pkgs.python314Packages.openwrt-luci-rpc
Python module for interacting with the OpenWrt Luci RPC interface
pkgs.python314Packages.openwrt-ubus-rpc
Python API for OpenWrt ubus RPC
Package maintainers
-
@matt-snider Matt Snider <matt.snider@protonmail.com>
-
@fabaff Fabian Affolter <mail@fabian-affolter.ch>