aboutsummaryrefslogtreecommitdiff
path: root/gnu/packages/patches/gst-plugins-ugly-fix-out-of-bound-reads.patch
diff options
context:
space:
mode:
Diffstat (limited to 'gnu/packages/patches/gst-plugins-ugly-fix-out-of-bound-reads.patch')
-rw-r--r--gnu/packages/patches/gst-plugins-ugly-fix-out-of-bound-reads.patch119
1 files changed, 119 insertions, 0 deletions
diff --git a/gnu/packages/patches/gst-plugins-ugly-fix-out-of-bound-reads.patch b/gnu/packages/patches/gst-plugins-ugly-fix-out-of-bound-reads.patch
new file mode 100644
index 0000000000..3c6a96f45d
--- /dev/null
+++ b/gnu/packages/patches/gst-plugins-ugly-fix-out-of-bound-reads.patch
@@ -0,0 +1,119 @@
+Fix out of bounds reads when parsing audio and video packets:
+
+https://security-tracker.debian.org/tracker/TEMP-0000000-4DAA44
+https://gitlab.freedesktop.org/gstreamer/gst-plugins-ugly/-/issues/37
+
+Patch copied from upstream source repository:
+
+https://gitlab.freedesktop.org/gstreamer/gst-plugins-ugly/-/commit/3aba7d1e625554b2407bc77b3d09b4928b937d5f
+From 3aba7d1e625554b2407bc77b3d09b4928b937d5f Mon Sep 17 00:00:00 2001
+From: =?UTF-8?q?Sebastian=20Dr=C3=B6ge?= <sebastian@centricular.com>
+Date: Wed, 3 Mar 2021 11:05:14 +0200
+Subject: [PATCH] rmdemux: Make sure we have enough data available when parsing
+ audio/video packets
+
+Otherwise there will be out-of-bounds reads and potential crashes.
+
+Thanks to Natalie Silvanovich for reporting.
+
+Fixes https://gitlab.freedesktop.org/gstreamer/gst-plugins-ugly/-/issues/37
+
+Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-ugly/-/merge_requests/74>
+---
+ gst/realmedia/rmdemux.c | 35 +++++++++++++++++++++++++++++++++++
+ 1 file changed, 35 insertions(+)
+
+diff --git a/gst/realmedia/rmdemux.c b/gst/realmedia/rmdemux.c
+index 6cc659a1..68b0736b 100644
+--- a/gst/realmedia/rmdemux.c
++++ b/gst/realmedia/rmdemux.c
+@@ -2223,6 +2223,9 @@ gst_rmdemux_parse_video_packet (GstRMDemux * rmdemux, GstRMDemuxStream * stream,
+
+ gst_buffer_map (in, &map, GST_MAP_READ);
+
++ if (map.size < offset)
++ goto not_enough_data;
++
+ data = map.data + offset;
+ size = map.size - offset;
+
+@@ -2289,6 +2292,9 @@ gst_rmdemux_parse_video_packet (GstRMDemux * rmdemux, GstRMDemuxStream * stream,
+ }
+ GST_DEBUG_OBJECT (rmdemux, "fragment size %d", fragment_size);
+
++ if (map.size < (data - map.data) + fragment_size)
++ goto not_enough_data;
++
+ /* get the fragment */
+ fragment =
+ gst_buffer_copy_region (in, GST_BUFFER_COPY_ALL, data - map.data,
+@@ -2437,6 +2443,9 @@ gst_rmdemux_parse_audio_packet (GstRMDemux * rmdemux, GstRMDemuxStream * stream,
+ GstFlowReturn ret;
+ GstBuffer *buffer;
+
++ if (gst_buffer_get_size (in) < offset)
++ goto not_enough_data;
++
+ buffer = gst_buffer_copy_region (in, GST_BUFFER_COPY_MEMORY, offset, -1);
+
+ if (rmdemux->first_ts != -1 && timestamp > rmdemux->first_ts)
+@@ -2467,9 +2476,19 @@ gst_rmdemux_parse_audio_packet (GstRMDemux * rmdemux, GstRMDemuxStream * stream,
+ ret = gst_pad_push (stream->pad, buffer);
+ }
+
++done:
+ gst_buffer_unref (in);
+
+ return ret;
++
++ /* ERRORS */
++not_enough_data:
++ {
++ GST_ELEMENT_WARNING (rmdemux, STREAM, DECODE, ("Skipping bad packet."),
++ (NULL));
++ ret = GST_FLOW_OK;
++ goto done;
++ }
+ }
+
+ static GstFlowReturn
+@@ -2490,6 +2509,9 @@ gst_rmdemux_parse_packet (GstRMDemux * rmdemux, GstBuffer * in, guint16 version)
+ data = map.data;
+ size = map.size;
+
++ if (size < 4 + 6 + 1 + 2)
++ goto not_enough_data;
++
+ /* stream number */
+ id = RMDEMUX_GUINT16_GET (data);
+
+@@ -2525,6 +2547,9 @@ gst_rmdemux_parse_packet (GstRMDemux * rmdemux, GstBuffer * in, guint16 version)
+
+ /* version 1 has an extra byte */
+ if (version == 1) {
++ if (size < 1)
++ goto not_enough_data;
++
+ data += 1;
+ size -= 1;
+ }
+@@ -2596,6 +2621,16 @@ unknown_stream:
+ gst_buffer_unref (in);
+ return GST_FLOW_OK;
+ }
++
++ /* ERRORS */
++not_enough_data:
++ {
++ GST_ELEMENT_WARNING (rmdemux, STREAM, DECODE, ("Skipping bad packet."),
++ (NULL));
++ gst_buffer_unmap (in, &map);
++ gst_buffer_unref (in);
++ return GST_FLOW_OK;
++ }
+ }
+
+ gboolean
+--
+2.31.1
+
p'>* gnu/packages/kde.scm (kopeninghours)[arguments]: Rewrite as G-expressions. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kopeninghours: Update to 23.04.3....* gnu/packages/kde.scm (kopeninghours): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kosmindoormap: Update to 23.04.3....* gnu/packages/kde.scm (kosmindoormap): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kpmcore: Use G-expressions....* gnu/packages/kde.scm (kpmcore)[arguments]: Rewrite as G-expressions. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kpmcore: Update to 23.04.3....* gnu/packages/kde.scm (kpmcore): Update to 23.04.3. [arguments]: enable tests. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kdeconnect: Use G-expressions....* gnu/packages/kde.scm (kdeconnect)[arguments]: Rewrite as G-expressions. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kdeconnect: Update to 23.04.3....* gnu/packages/kde.scm (kdeconnect): Update to 23.04.3. [native-inputs]: Add wayland-protocols. [inputs]: Add modemmanager-qt, libxkbcommon. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kirigami-addons: Update to 0.9.0....* gnu/packages/kde.scm (kirigami-addons): Update to 0.9.0. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: ktimer: Update to 23.04.3....* gnu/packages/kde.scm (ktimer): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kcachegrind: Update to 23.04.3....* gnu/packages/kde.scm (kcachegrind): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: libkdegames: Update to 23.04.3....* gnu/packages/kde.scm (libkdegames): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: libkexiv2: Update to 23.04.3....* gnu/packages/kde.scm (libkexiv2): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kdegraphics-mobipocket: Update to 23.04.3....* gnu/packages/kde.scm (kdegraphics-mobipocket): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: poxml: Update to 23.04.3....* gnu/packages/kde.scm (poxml): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: kdf: Update to 23.04.3....* gnu/packages/kde.scm (kdf): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: qca: Update to 2.3.6....* gnu/packages/kde.scm (qca): Update to 2.3.6. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: libkomparediff2: Update to 23.04.3....* gnu/packages/kde.scm (libkomparediff2): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: baloo-widgets: Update to 23.04.3....* gnu/packages/kde.scm (baloo-widgets): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-08-02gnu: grantleetheme: Update to 23.04.3....* gnu/packages/kde.scm (grantleetheme): Update to 23.04.3. Signed-off-by: 宋文武 <iyzsong@member.fsf.org> Zheng Junjie 2023-07-23gnu: fuse@3: Bind to default FUSE variable....* gnu/packages/linux.scm (fuse): Rename this… (fuse-2): …to this, and… (fuse-3): …rename this… (fuse): …to this! (fuse-static): Rename this… (fuse-2-static): …to this. Adjust all users. Tobias Geerinckx-Rice 2023-06-26gnu: kdenlive: Update to 23.04.2...* gnu/packages/kde.scm (kdenlive): Update to 23.04.2 Signed-off-by: Christopher Baines <mail@cbaines.net> Andy Tai 2023-06-06gnu: kirigami-addons: Update to 0.8.0....* gnu/packages/kde.scm (kirigami-addons): Update to 0.8.0. [source]: Download using git-fetch. Efraim Flashner 2023-04-07gnu: Purge pre-1.3.0 deprecated packages....* gnu/packages/bioinformatics.scm (deeptools): Remove variable. * gnu/packages/efi.scm (efi_analyzer): Ditto. * gnu/packages/guile.scm (guile-2.2/bug-fix, guile-json): Ditto. * gnu/packages/image.scm (libjpeg): Ditto. * gnu/packages/kde.scm (kdevplatform): Ditto * gnu/packages/linphone.scm (linphoneqt): Ditto. * gnu/packages/maths.scm (blis-sandybridge, blis-haswell, blis-knl): Ditto. * gnu/packages/mpi.scm (hwloc-2.0): Ditto. * gnu/packages/music.scm (python-abjad, zlfo): Ditto. * gnu/packages/perl.scm (perl-base, perl-parent): Ditto. * gnu/packages/tryton.scm (python-trytond): Ditto. * gnu/packages/video.scm (gnome-mpv): Ditto. * tests/graph.scm: Use guile-json-1. Signed-off-by: Ludovic Courtès <ludo@gnu.org> Bruno Victal 2023-04-03gnu: kdenlive: Update to 22.12.3....* gnu/packages/kde.scm (kdenlive): Update to 22.12.3. Vinicius Monego 2023-03-10gnu: krita: Update to 5.1.5....* gnu/packages/kde.scm (krita): Update to 5.1.5. Signed-off-by: Nicolas Goaziou <mail@nicolasgoaziou.fr> Z572 via Guix-patches via