CVE-2024-47606
CVSS V2 None
CVSS V3 None
Description
GStreamer is a library for constructing graphs of media-handling components. An integer underflow has been detected in the function qtdemux_parse_theora_extension within qtdemux.c. The vulnerability occurs due to an underflow of the gint size variable, which causes size to hold a large unintended value when cast to an unsigned integer. This 32-bit negative value is then cast to a 64-bit unsigned integer (0xfffffffffffffffa) in a subsequent call to gst_buffer_new_and_alloc. The function gst_buffer_new_allocate then attempts to allocate memory, eventually calling _sysmem_new_block. The function _sysmem_new_block adds alignment and header size to the (unsigned) size, causing the overflow of the 'slice_size' variable. As a result, only 0x89 bytes are allocated, despite the large input size. When the following memcpy call occurs in gst_buffer_fill, the data from the input file will overwrite the content of the GstMapInfo info structure. Finally, during the call to gst_memory_unmap, the overwritten memory may cause a function pointer hijack, as the mem->allocator->mem_unmap_full function is called with a corrupted pointer. This function pointer overwrite could allow an attacker to alter the execution flow of the program, leading to arbitrary code execution. This vulnerability is fixed in 1.24.10.
Overview
- CVE ID
- CVE-2024-47606
- Assigner
- GitHub_M
- Vulnerability Status
- PUBLISHED
- Published Version
- 2024-12-11T19:12:40.186Z
- Last Modified Date
- 2024-12-11T20:44:29.587Z
Weakness Enumerations
References
Reference URL | Reference Tags |
---|---|
https://securitylab.github.com/advisories/GHSL-2024-166_Gstreamer/ | x_refsource_CONFIRM |
https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8032.patch | x_refsource_MISC |
https://gstreamer.freedesktop.org/security/sa-2024-0014.html | x_refsource_MISC |
Sources
Source Name | Source URL |
---|---|
NIST | https://nvd.nist.gov/vuln/detail/CVE-2024-47606 |
MITRE | https://cve.mitre.org/cgi-bin/cvename.cgi?name=CVE-2024-47606 |
History
Created | Old Value | New Value | Data Type | Notes |
---|---|---|---|---|
2024-12-12 13:24:05 | Added to TrackCVE |