CVE Vulnerabilities

CVE-2024-47834

Use After Free

Published: Dec 12, 2024 | Modified: Dec 18, 2024
CVSS 3.x
9.1
CRITICAL
Source:
NVD
CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:H
CVSS 2.x
RedHat/V2
RedHat/V3
5.1 MODERATE
CVSS:3.1/AV:L/AC:L/PR:N/UI:N/S:U/C:L/I:N/A:L
Ubuntu
MEDIUM

GStreamer is a library for constructing graphs of media-handling components. An Use-After-Free read vulnerability has been discovered affecting the processing of CodecPrivate elements in Matroska streams. In the GST_MATROSKA_ID_CODECPRIVATE case within the gst_matroska_demux_parse_stream function, a data chunk is allocated using gst_ebml_read_binary. Later, the allocated memory is freed in the gst_matroska_track_free function, by the call to g_free (track->codec_priv). Finally, the freed memory is accessed in the caps_serialize function through gst_value_serialize_buffer. The freed memory will be accessed in the gst_value_serialize_buffer function. This results in a UAF read vulnerability, as the function tries to process memory that has already been freed. This vulnerability is fixed in 1.24.10.

Weakness

The product reuses or references memory after it has been freed. At some point afterward, the memory may be allocated again and saved in another pointer, while the original pointer references a location somewhere within the new allocation. Any operations using the original pointer are no longer valid because the memory “belongs” to the code that operates on the new pointer.

Affected Software

Name Vendor Start Version End Version
Gstreamer Gstreamer_project * 1.24.10 (excluding)
Red Hat Enterprise Linux 9 RedHat gstreamer1-plugins-good-0:1.22.12-4.el9 *
Gst-plugins-good1.0 Ubuntu esm-infra/focal *
Gst-plugins-good1.0 Ubuntu focal *
Gst-plugins-good1.0 Ubuntu jammy *
Gst-plugins-good1.0 Ubuntu noble *
Gst-plugins-good1.0 Ubuntu oracular *
Gst-plugins-good1.0 Ubuntu upstream *

Potential Mitigations

References