8.5
/ 10
HIGH
CVSS:4.0/AV:L/AC:L/AT:N/PR:N/UI:P/VC:H/VI:H/VA:H/SC:N/SI:N/SA:N
Description
PJSIP is a free and open source multimedia communication library written in C. In 2.16 and earlier, there is a buffer overflow when decoding Opus audio frames due to insufficient buffer size validation in the Opus codec decode path. The FEC decode buffers (dec_frame[].buf) were allocated based on a PCM-derived formula: (sample_rate/1000) * 60 * channel_cnt * 2. At 8 kHz mono this yields only 960 bytes, but codec_parse() can output encoded frames up to MAX_ENCODED_PACKET_SIZE (1280) bytes via opus_repacketizer_out_range(). The three pj_memcpy() calls in codec_decode() copied input->size bytes without bounds checking, causing a heap buffer overflow.
AI Analysis
Heap buffer overflow in Opus codec decoding due to insufficient buffer size validation
Basic Information
ID
CVE-2026-40614
Source
GitHub_M
Published
Apr 21, 2026 at 18:04
Affected Product
Vendor
pjsip
Product
pjproject
Version
<= 2.16
Affected Versions
pjsip pjproject <= 2.16
CWE Classification
AI Assessment
AI Score
8.5 / 10
AI Severity
High
Vendor
pjsip
Product
PJSIP
Version
<= 2.16