CVE 8.7 HIGH

BACnet Stack: Off-by-One Out-of-Bounds Read in ReadPropertyMultiple Object ID Decoder_CVE-2026-41502

8.7 / 10
HIGH
CVSS:4.0/AV:N/AC:L/AT:N/PR:N/UI:N/VC:N/VI:N/VA:H/SC:N/SI:N/SA:N

Description

BACnet Stack is a BACnet open source protocol stack C library for embedded systems. Prior to 1.4.3, an off-by-one out-of-bounds read vulnerability in bacnet-stack's ReadPropertyMultiple service decoder allows unauthenticated remote attackers to read one byte past an allocated buffer boundary by sending a crafted RPM request with a truncated object identifier. The vulnerability is in rpm_decode_object_id(), which checks apdu_len < 5 but then accesses all 6 byte positions (indices 0-5) — consuming 1 byte for the context tag, 4 bytes for the object ID, then reading apdu[5] for the opening tag check. A 5-byte input passes the length check but causes a 1-byte OOB read, leading to crashes on embedded BACnet devices. The vulnerability exists in src/bacnet/rpm.c and affects any deployment that enables the ReadPropertyMultiple confirmed service handler (enabled by default in the reference server). This vulnerability is fixed in 1.4.3.

AI Analysis

Off-by-one out-of-bounds read vulnerability in ReadPropertyMultiple service decoder

Basic Information

ID CVE-2026-41502
Source GitHub_M
Published Apr 24, 2026 at 19:40

Affected Product

Vendor bacnet-stack
Product bacnet-stack
Version >= 1.4.0, < 1.4.3
Affected Versions bacnet-stack bacnet-stack >= 1.4.0, < 1.4.3

CWE Classification

AI Assessment

AI Score 8.7 / 10
AI Severity High
Vendor BACnet Stack Project
Product BACnet Stack
Version 1.4.0 to 1.4.2

References

💭 Join the Security Discussion

🔒 Your email address will not be published. Required fields are marked *

⚠️ Please be respectful and constructive in your comments. Security discussions should remain professional.