platform/upstream/gstreamer.git
2 months agoRelease 1.24.11 upstream/1.24.11 1.24.11
Tim-Philipp Müller [Mon, 6 Jan 2025 19:48:08 +0000 (19:48 +0000)]
Release 1.24.11

2 months agov4l2videodec: release decode only frame in input list
Dean Zhang (张安迪) [Mon, 6 Jan 2025 12:30:51 +0000 (20:30 +0800)]
v4l2videodec: release decode only frame in input list

For some frames with decode-only flag, the v4l2 decoder will not
put them in output list. The corresponding decode-only frames will
be still kept in input list, which may cause potential performance
issue when the input list is full. So release the decode-only frames
according to the decode-only flag after they are processed by decoder
driver.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8247>

2 months agomatroskamux: Consider audio buffers as keyframes when writing out simpleblocks
Sebastian Dröge [Tue, 31 Dec 2024 09:49:21 +0000 (11:49 +0200)]
matroskamux: Consider audio buffers as keyframes when writing out simpleblocks

Otherwise mpv complains and considers the file broken.

Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/4142

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8246>

2 months agomatroskamux: Fix audio-only stream conditions
Sebastian Dröge [Tue, 31 Dec 2024 09:42:04 +0000 (11:42 +0200)]
matroskamux: Fix audio-only stream conditions

The num_a_streams and related counters are used for pad numbers and don't give
the absolute number of streams in this run of the muxer.

Also, consider the output audio-only if there are more than 1 audio stream too.

Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/4142

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8246>

2 months agoqtdemux: fix accumulated base offset in segment seeks
Christian Meissl [Tue, 17 Dec 2024 19:08:24 +0000 (20:08 +0100)]
qtdemux: fix accumulated base offset in segment seeks

analog to fix for matroska-demux
commit f3c126d07c8a85e76bf5abdfa7f140bbf20545ea

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8244>

2 months agomeson: Re-added required: lines accidentally removed
Nirbheek Chauhan [Fri, 13 Sep 2024 09:07:10 +0000 (14:37 +0530)]
meson: Re-added required: lines accidentally removed

Broke in e3f086c648171c3c993f5dd73e2d025480c3729e

Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3801

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8243>

2 months agov4l2: object: Add P010 format
Robert Mader [Sat, 21 Dec 2024 13:39:58 +0000 (14:39 +0100)]
v4l2: object: Add P010 format

For 10bit content. Tested with HEVC on a Pixel3a (qcom).

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8197>

2 months agoges-launcher: return early on 'project-loaded' signal on error
Thibault Saunier [Fri, 13 Dec 2024 12:17:32 +0000 (09:17 -0300)]
ges-launcher: return early on 'project-loaded' signal on error

Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/4102

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8161>

2 months agoges: project: Add missing API guards
Thibault Saunier [Fri, 13 Dec 2024 12:11:05 +0000 (09:11 -0300)]
ges: project: Add missing API guards

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8161>

2 months agoges: formatter: Keep a reference on the timelines
Thibault Saunier [Fri, 13 Dec 2024 12:09:15 +0000 (09:09 -0300)]
ges: formatter: Keep a reference on the timelines

We will be using it in an async way so we need to keep our own
reference to it.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8161>

2 months agodecklink: Add missing video modes to gst_decklink_mode_get_type()
Armin Begovic [Fri, 6 Dec 2024 14:15:45 +0000 (15:15 +0100)]
decklink: Add missing video modes to gst_decklink_mode_get_type()

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8122>

2 months agodecklink: Fix copy-paste errors regarding 8K modes
Armin Begovic [Fri, 6 Dec 2024 14:15:34 +0000 (15:15 +0100)]
decklink: Fix copy-paste errors regarding 8K modes

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8122>

2 months agodecklink: Add support for all modes of Quad HDMI recorder
Benjamin Gräf [Thu, 8 Aug 2024 12:36:19 +0000 (14:36 +0200)]
decklink: Add support for all modes of Quad HDMI recorder

By extending the GstDecklinkModeEnum with the additional modes supported by the Quad HDMI recorder,
we avoid using mode = 0 in case any of these resolutions is returned by the card.

Fixes #3713

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8122>

2 months agodecodebin3: Free main input even if it is not part of the list of inputs
Sebastian Dröge [Fri, 27 Dec 2024 12:27:54 +0000 (14:27 +0200)]
decodebin3: Free main input even if it is not part of the list of inputs

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8232>

3 months agomeson: Also disable drm on GNU/Hurd
Samuel Thibault [Mon, 30 Dec 2024 21:53:02 +0000 (22:53 +0100)]
meson: Also disable drm on GNU/Hurd

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8228>

3 months agosrtpdec: fix build when libsrtp1 is being used
Tim-Philipp Müller [Mon, 23 Dec 2024 14:17:57 +0000 (15:17 +0100)]
srtpdec: fix build when libsrtp1 is being used

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8207>

3 months agovideodecoder: Gracefully handle missing data without prior input segment
Philippe Normand [Mon, 23 Dec 2024 08:49:51 +0000 (09:49 +0100)]
videodecoder: Gracefully handle missing data without prior input segment

Exit early in case the decoder has been resetted and hasn't received a new
segment event yet.

This was detected with netsim dropping buffers in a WebRTC pipeline.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8206>

3 months agosrtpdec: Fix a use-after-free buffer issue
Philippe Normand [Sun, 22 Dec 2024 14:00:07 +0000 (15:00 +0100)]
srtpdec: Fix a use-after-free buffer issue

The gst_srtp_dec_decode_buffer() function modifies the input buffer after making
it writable, so the pointer might change as well, depending on the refcount of
the buffer.

This issue was detected using a netsim element upstream of the decoder in a
WebRTC pipeline.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8201>

3 months agourisourcebin: Avoid deadlock on shutdown
Edward Hervey [Mon, 16 Dec 2024 15:36:06 +0000 (16:36 +0100)]
urisourcebin: Avoid deadlock on shutdown

The reason why the STATE lock was taken was to avoid issues where we would be
adding (and activating) elements at the same time as urisourcebin would be
brought down to READY. That would cause those new elements to potentially return
ERRORS because of not-negotiated/flushing-pads

But that creates a really bad deadlock (state lock is taken to deactivate the
streaming thread which .. is currently grabbing the state lock).

Instead, we can just ignore the warning/error messages that might occur when
shutting down.

Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/4075

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8187>

3 months agovp9parse: Add video codec tag to the tag list
Sebastian Dröge [Mon, 16 Dec 2024 09:39:10 +0000 (11:39 +0200)]
vp9parse: Add video codec tag to the tag list

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8186>

3 months agoav1parse: Add video codec tag to the tag list
Sebastian Dröge [Mon, 16 Dec 2024 09:38:52 +0000 (11:38 +0200)]
av1parse: Add video codec tag to the tag list

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8186>

3 months agova: display: Optimize out some property indirection
Nicolas Dufresne [Wed, 18 Dec 2024 18:35:53 +0000 (13:35 -0500)]
va: display: Optimize out some property indirection

Because it was visible during some profiling, I thought it cost nothing
to optimize out the uneeded property get roundtrip.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8181>

3 months agoavcodecmap: Add some more channel position mappings
Sebastian Dröge [Wed, 18 Dec 2024 10:21:15 +0000 (12:21 +0200)]
avcodecmap: Add some more channel position mappings

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8175>

3 months agowebrtcbin: Tear down src and sink bins before removing them from webrtc
Emil Ljungdahl [Mon, 18 Nov 2024 06:54:55 +0000 (07:54 +0100)]
webrtcbin: Tear down src and sink bins before removing them from webrtc

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8165>

3 months agowebrtcbin: Fix potential deadlock on bin elements cleanup
Emil Ljungdahl [Fri, 15 Nov 2024 14:00:00 +0000 (15:00 +0100)]
webrtcbin: Fix potential deadlock on bin elements cleanup

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8165>

3 months agoappsrc: Decrease log level for item drop
Max Romanov [Fri, 13 Dec 2024 12:51:20 +0000 (15:51 +0300)]
appsrc: Decrease log level for item drop

Leaky appsrc feature was implemented similar to queue. Dropping item
is a normal case because it is configured so. Warning messages
is too severe for this event.

Level changed to DEBUG just like in queue.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8151>

3 months agoges-meta-container: Fix the GET_INTERFACE macro
Thibault Saunier [Fri, 13 Dec 2024 13:14:32 +0000 (10:14 -0300)]
ges-meta-container: Fix the GET_INTERFACE macro

It had a synthax issue

Fixes https://gitlab.freedesktop.org/gstreamer/gst-editing-services/-/issues/141

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8150>

3 months agovideodecoder: set decode only flag by decode only buffer
Dean Zhang (张安迪) [Fri, 13 Dec 2024 02:07:58 +0000 (10:07 +0800)]
videodecoder: set decode only flag by decode only buffer

This is used for optimize frame drop issue. Some video streams such as av1
contains decode-only frames. These frames are handled by decoder but not show
by display, which will cause input frame count unmatch the output frame count.
After collecting more decoder only frame, it will cause error report "so many
frame droped". So attach the flag GST_BUFFER_FLAG_DECODE_ONLY with the input
buffer, the v4l2videodecoder can further handle the decode-only buffer in
output list.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8148>

3 months agogl: raise WARNING instead of ERROR when no connector is connected
Guillaume Desmottes [Thu, 12 Dec 2024 09:43:26 +0000 (10:43 +0100)]
gl: raise WARNING instead of ERROR when no connector is connected

This is a valid and working use case when rendering on a headless
server.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8139>

3 months agourisourcebin: Only rewrite stream-start event once
Edward Hervey [Thu, 12 Dec 2024 04:51:09 +0000 (05:51 +0100)]
urisourcebin: Only rewrite stream-start event once

If the custom field is already present, we don't want to rewrite the event
again. Otherwise it would cause downstream into believing that a *new*
stream-start event has arrived ... which isn't the case.

Fixes #4097

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8144>

3 months agortppassthroughpay: ensure buffer is writable before mapping writable
Matthew Waters [Thu, 12 Dec 2024 01:05:04 +0000 (12:05 +1100)]
rtppassthroughpay: ensure buffer is writable before mapping writable

It is entirely possible that the incoming buffer into _chain() is not writable
and will result in a critical when trying to map().

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8137>

3 months agowebrtc: Simplify fmtp handling in codec stats
Philippe Normand [Tue, 10 Dec 2024 16:15:09 +0000 (16:15 +0000)]
webrtc: Simplify fmtp handling in codec stats

Parsing the whole caps as SDP media only to retrieve the fmtp field afterwards
seems a bit superfluous. By looking up the a-fmtp attribute directly the number
of allocations in this function gets down a bit.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8130>

3 months agouridecodebin3: Don't use decodebin3 static sink pad
Edward Hervey [Thu, 28 Nov 2024 10:57:57 +0000 (11:57 +0100)]
uridecodebin3: Don't use decodebin3 static sink pad

Makes the code leaner, and fixes the issue which would happen when the
urisourcebin stream that was linked to the sink pad goes away (without any
replacement).

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8119>

3 months agodecodebin3: Make usage of static sink pad optional
Edward Hervey [Thu, 28 Nov 2024 10:55:36 +0000 (11:55 +0100)]
decodebin3: Make usage of static sink pad optional

There is no reason why we should mandate people to "at least" use the static
sink pad. This caused issues, like mandating that it should always have valid
content linked to it (problematic in case of upstream stream changes).

Instead we only use it if it's actually linked to, in which case it gets added
to the list of inputs.

This actually simplifies the code too.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8119>

3 months agourisourcebin: Fix issue re-using outputs
Edward Hervey [Mon, 25 Nov 2024 09:50:34 +0000 (10:50 +0100)]
urisourcebin: Fix issue re-using outputs

When checking whether a no-longer used output could be re-used for another slot,
we only want to do that for streams which are not still used.

Otherwise we end up potentially re-assigning a demuxer stream to a completely
different one

Furthermore, if we *are* re-using an output slot, indicate what the replacement
GstStream will be so slot matching can work properly (which can happen in the
case of demuxers which add/remove all pads even if only a single one changed)

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8119>

3 months agortpsession: Fix twcc stats structure leaks
Philippe Normand [Wed, 4 Dec 2024 16:10:46 +0000 (16:10 +0000)]
rtpsession: Fix twcc stats structure leaks

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8115>

3 months agoonnx: disable onnxruntime telemetry
Daniel Morin [Sat, 7 Dec 2024 05:23:33 +0000 (00:23 -0500)]
onnx: disable onnxruntime telemetry

Disable the telemetry feautre on onnxruntime.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8106>

3 months agovideo: fix AV12 format lacking the GST_VIDEO_FORMAT_FLAG_ALPHA flag
Cheung Yik Pang [Wed, 4 Dec 2024 10:45:30 +0000 (18:45 +0800)]
video: fix AV12 format lacking the GST_VIDEO_FORMAT_FLAG_ALPHA flag

The GST_VIDEO_FORMAT_FLAG_ALPHA indicates whether a video format has an
alpha channel.  AV12 does have an alpha plane.  Switching from
MAKE_YUV_FORMAT to MAKE_YUVA_FORMAT to generate GST_VIDEO_FORMAT_AV12.

Fixes #4081

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8084>

3 months agozxing: Update decode hints usage for compatibility with ZXing >= 2.2
Francisco Javier Velázquez-García [Thu, 5 Dec 2024 12:39:38 +0000 (13:39 +0100)]
zxing: Update decode hints usage for compatibility with ZXing >= 2.2

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8085>

3 months agourisourcebin: Fix collection leak
Edward Hervey [Thu, 5 Dec 2024 08:21:04 +0000 (09:21 +0100)]
urisourcebin: Fix collection leak

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8081>

3 months agolibav: free protocol info in gst_ffmpeg_pipe_close
Stéphane Cerveau [Wed, 4 Dec 2024 15:27:54 +0000 (16:27 +0100)]
libav: free protocol info in gst_ffmpeg_pipe_close

When the media is not seekable, we are calling gst_ffmpeg_pipe_close
which does free the info.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8078>

3 months agoh264parse: Free SEI if parsing succeeds but alignment afterwards fails
Sebastian Dröge [Tue, 3 Dec 2024 11:14:33 +0000 (13:14 +0200)]
h264parse: Free SEI if parsing succeeds but alignment afterwards fails

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8077>

3 months agoh265parse: Free SEI if parsing succeeds but alignment afterwards fails
Sebastian Dröge [Tue, 3 Dec 2024 11:10:04 +0000 (13:10 +0200)]
h265parse: Free SEI if parsing succeeds but alignment afterwards fails

Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/4076

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8077>

3 months agomeson: Drop max version bound from neon
Jan Alexander Steffens (heftig) [Fri, 29 Nov 2024 13:41:12 +0000 (14:41 +0100)]
meson: Drop max version bound from neon

Neon 0.34.0 broke the build again, but the API+ABI has been stable since
0.27 and the library is so-versioned.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8072>

3 months agoh265parse: parse unregistered SEI without user data
Guillaume Desmottes [Tue, 3 Dec 2024 13:44:30 +0000 (14:44 +0100)]
h265parse: parse unregistered SEI without user data

Same change as in h264parse.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8071>

3 months agoh264parse: parse unregistered SEI without user data
Guillaume Desmottes [Wed, 20 Nov 2024 13:16:23 +0000 (14:16 +0100)]
h264parse: parse unregistered SEI without user data

We get loads of warnings when parsing videos from users:

gsth264parser.c:1115:gst_h264_parser_parse_user_data_unregistered: No more remaining payload data to store
gsth264parse.c:646:gst_h264_parse_process_sei:<h264parse0> failed to parse one or more SEI message

Those are raised because of unregistered SEI without user data.

The spec does not explicitly state that unregistered SEI needs to have
data and I suppose the UUID by itself can carry valuable information.
FFmpeg also parses and exposes such SEI so there is no reason for us no
too as well.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8071>

3 months agotsdemux: Lower a GST_FIXME to a GST_DEBUG
Sebastian Dröge [Fri, 15 Nov 2024 14:44:10 +0000 (16:44 +0200)]
tsdemux: Lower a GST_FIXME to a GST_DEBUG

This is not really a refcounting issue and can happen if a new program is in the
process of being activated that contains streams with the same PIDs.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8066>

3 months agoBack to development after 1.24.10
Tim-Philipp Müller [Tue, 3 Dec 2024 23:39:54 +0000 (23:39 +0000)]
Back to development after 1.24.10

3 months agoRelease 1.24.10 upstream/1.24.10 1.24.10
Tim-Philipp Müller [Tue, 3 Dec 2024 23:29:07 +0000 (23:29 +0000)]
Release 1.24.10

3 months agoqtdemux: Add size check for parsing SMI / SEQH atom
Sebastian Dröge [Thu, 26 Sep 2024 21:31:36 +0000 (00:31 +0300)]
qtdemux: Add size check for parsing SMI / SEQH atom

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-244
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3853

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Check for invalid atom length when extracting Closed Caption data
Sebastian Dröge [Thu, 26 Sep 2024 16:16:19 +0000 (19:16 +0300)]
qtdemux: Check for invalid atom length when extracting Closed Caption data

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-243
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3849

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Actually handle errors returns from various functions instead of ignoring...
Sebastian Dröge [Fri, 27 Sep 2024 07:39:30 +0000 (10:39 +0300)]
qtdemux: Actually handle errors returns from various functions instead of ignoring them

Ignoring them might cause the element to continue as if all is fine despite the
internal state being inconsistent. This can lead to all kinds of follow-up
issues, including memory safety issues.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-245
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3847

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Make sure there are enough offsets to read when parsing samples
Sebastian Dröge [Fri, 27 Sep 2024 07:38:50 +0000 (10:38 +0300)]
qtdemux: Make sure there are enough offsets to read when parsing samples

While this specific case is also caught when initializing co_chunk, the error
is ignored in various places and calling into the function would lead to out of
bounds reads if the error message doesn't cause the pipeline to be shut down
fast enough.

To avoid this, no matter what, make sure enough offsets are available when
parsing them. While this is potentially slower, the same is already done in the
non-chunks_are_samples case.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-245
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3847

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Fix error handling when parsing cenc sample groups fails
Sebastian Dröge [Fri, 27 Sep 2024 06:47:50 +0000 (09:47 +0300)]
qtdemux: Fix error handling when parsing cenc sample groups fails

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-238, GHSL-2024-239, GHSL-2024-240
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3846

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Fix length checks and offsets in stsd entry parsing
Sebastian Dröge [Thu, 26 Sep 2024 21:12:57 +0000 (00:12 +0300)]
qtdemux: Fix length checks and offsets in stsd entry parsing

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-242
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3845

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Make sure enough data is available before reading wave header node
Sebastian Dröge [Thu, 26 Sep 2024 11:17:02 +0000 (14:17 +0300)]
qtdemux: Make sure enough data is available before reading wave header node

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-236
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3843

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Make sure only an even number of bytes is processed when handling CEA608...
Sebastian Dröge [Thu, 26 Sep 2024 06:20:28 +0000 (09:20 +0300)]
qtdemux: Make sure only an even number of bytes is processed when handling CEA608 data

An odd number of bytes would lead to out of bound reads and writes, and doesn't
make any sense as CEA608 comes in byte pairs.

Strip off any leftover bytes and assume everything before that is valid.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-195
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3841

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Check sizes of stsc/stco/stts before trying to merge entries
Sebastian Dröge [Fri, 27 Sep 2024 12:50:54 +0000 (15:50 +0300)]
qtdemux: Check sizes of stsc/stco/stts before trying to merge entries

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-246
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3854

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Don't iterate over all trun entries if none of the flags are set
Sebastian Dröge [Thu, 26 Sep 2024 15:41:39 +0000 (18:41 +0300)]
qtdemux: Don't iterate over all trun entries if none of the flags are set

Nothing would be printed anyway.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Fix debug output during trun parsing
Sebastian Dröge [Thu, 26 Sep 2024 15:40:56 +0000 (18:40 +0300)]
qtdemux: Fix debug output during trun parsing

Various integers are unsigned so print them as such. Also print the actual
allocation size if allocation fails, not only parts of it.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoqtdemux: Fix integer overflow when allocating the samples table for fragmented MP4
Antonio Morales [Thu, 26 Sep 2024 15:39:37 +0000 (18:39 +0300)]
qtdemux: Fix integer overflow when allocating the samples table for fragmented MP4

This can lead to out of bounds writes and NULL pointer dereferences.

Fixes GHSL-2024-094, GHSL-2024-237, GHSL-2024-241
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3839

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8060>

3 months agoh265parser/bitwriter: add some comments for ceil_log2 use
Stéphane Cerveau [Wed, 9 Oct 2024 17:47:41 +0000 (13:47 -0400)]
h265parser/bitwriter: add some comments for ceil_log2 use

Validate that the length of field must be calculate with
ceil_logs2 and not bit storage.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7905>

3 months agoh264parse: use of ceil_log2 instead of bit_storage
Stéphane Cerveau [Wed, 9 Oct 2024 17:46:17 +0000 (13:46 -0400)]
h264parse: use of ceil_log2 instead of bit_storage

According to the specification:
The length of the slice_group_id[ i ] syntax element is Ceil( Log2(
num_slice_groups_minus1 + 1 ) ) bits

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7905>

3 months agoutils: improve gst_util_ceil_log2
Stéphane Cerveau [Fri, 30 Aug 2024 11:21:30 +0000 (13:21 +0200)]
utils: improve gst_util_ceil_log2

According to the following comparison of algorithms, the value
for 0 and 1 was giving an incorrect result.

https://gist.github.com/ceyusa/6061b33ac109a68bcd222f6919968c9a

More information here:
https://github.com/rofrol/codeforces/blob/master/ceil_log2.c

Use a different algorithm which offers better result and keep the
performance.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/7905>

3 months agomatroskademux: Put a copy of the codec data into the A_MS/ACM caps
Sebastian Dröge [Wed, 9 Oct 2024 15:52:52 +0000 (11:52 -0400)]
matroskademux: Put a copy of the codec data into the A_MS/ACM caps

The original codec data buffer is owned by matroskademux and does not
necessarily live as long as the caps.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-280
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3894

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8058>

3 months agomatroskademux: Skip over zero-sized Xiph stream headers
Sebastian Dröge [Mon, 30 Sep 2024 16:19:42 +0000 (19:19 +0300)]
matroskademux: Skip over zero-sized Xiph stream headers

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-251
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3867

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8058>

3 months agomatroskademux: Skip over laces directly when postprocessing the frame fails
Sebastian Dröge [Mon, 30 Sep 2024 16:06:03 +0000 (19:06 +0300)]
matroskademux: Skip over laces directly when postprocessing the frame fails

Otherwise NULL buffers might be handled afterwards.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-249
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3865

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8058>

3 months agomatroskademux: Don't take data out of an empty adapter when processing WavPack frames
Sebastian Dröge [Mon, 30 Sep 2024 16:04:51 +0000 (19:04 +0300)]
matroskademux: Don't take data out of an empty adapter when processing WavPack frames

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-249
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3865

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8058>

3 months agomatroskademux: Check for big enough WavPack codec private data before accessing it
Sebastian Dröge [Mon, 30 Sep 2024 15:25:53 +0000 (18:25 +0300)]
matroskademux: Check for big enough WavPack codec private data before accessing it

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-250
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3866

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8058>

3 months agomatroskademux: Fix off-by-one when parsing multi-channel WavPack
Sebastian Dröge [Mon, 30 Sep 2024 13:33:39 +0000 (16:33 +0300)]
matroskademux: Fix off-by-one when parsing multi-channel WavPack

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8058>

3 months agomatroskademux: Only unmap GstMapInfo in WavPack header extraction error paths if...
Sebastian Dröge [Mon, 30 Sep 2024 13:32:48 +0000 (16:32 +0300)]
matroskademux: Only unmap GstMapInfo in WavPack header extraction error paths if previously mapped

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-197
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3863

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8058>

3 months agoavisubtitle: Fix size checks and avoid overflows when checking sizes
Sebastian Dröge [Fri, 4 Oct 2024 11:04:03 +0000 (14:04 +0300)]
avisubtitle: Fix size checks and avoid overflows when checking sizes

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-262
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3890

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8055>

3 months agowavparse: Check size before reading ds64 chunk
Sebastian Dröge [Fri, 4 Oct 2024 10:51:00 +0000 (13:51 +0300)]
wavparse: Check size before reading ds64 chunk

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-261
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3889

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8054>

3 months agowavparse: Fix clipping of size to the file size
Sebastian Dröge [Fri, 4 Oct 2024 10:27:27 +0000 (13:27 +0300)]
wavparse: Fix clipping of size to the file size

The size does not include the 8 bytes tag and length, so an additional 8 bytes
must be removed here. 8 bytes are always available at this point because
otherwise the parsing of the tag and length right above would've failed.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-260
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3888

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8054>

3 months agowavparse: Check that at least 32 bytes are available before parsing smpl chunks
Sebastian Dröge [Fri, 4 Oct 2024 10:22:02 +0000 (13:22 +0300)]
wavparse: Check that at least 32 bytes are available before parsing smpl chunks

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-259
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3887

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8054>

3 months agowavparse: Check that at least 4 bytes are available before parsing cue chunks
Sebastian Dröge [Fri, 4 Oct 2024 10:21:44 +0000 (13:21 +0300)]
wavparse: Check that at least 4 bytes are available before parsing cue chunks

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8054>

3 months agowavparse: Fix parsing of acid chunk
Sebastian Dröge [Fri, 4 Oct 2024 10:15:27 +0000 (13:15 +0300)]
wavparse: Fix parsing of acid chunk

Simply casting the bytes to a struct can lead to crashes because of unaligned
reads, and is also missing the endianness swapping that is necessary on big
endian architectures.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8054>

3 months agowavparse: Make sure enough data for the tag list tag is available before parsing
Sebastian Dröge [Fri, 4 Oct 2024 10:09:43 +0000 (13:09 +0300)]
wavparse: Make sure enough data for the tag list tag is available before parsing

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-258
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3886

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8054>

3 months agowavparse: Check for short reads when parsing headers in pull mode
Sebastian Dröge [Fri, 4 Oct 2024 10:00:57 +0000 (13:00 +0300)]
wavparse: Check for short reads when parsing headers in pull mode

And also return the actual flow return to the caller instead of always returning
GST_FLOW_ERROR.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-258, GHSL-2024-260
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3886
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3888

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8054>

3 months agogdkpixbufdec: Check if initializing the video info actually succeeded
Sebastian Dröge [Wed, 2 Oct 2024 11:44:21 +0000 (14:44 +0300)]
gdkpixbufdec: Check if initializing the video info actually succeeded

Otherwise a 0-byte buffer would be allocated, which gives NULL memory when
mapped.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-118
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3876

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8053>

3 months agooggstream: review and fix per-format min_packet_size
Mathieu Duponchelle [Wed, 2 Oct 2024 14:52:51 +0000 (16:52 +0200)]
oggstream: review and fix per-format min_packet_size

This addresses all manually detected invalid reads in setup functions.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8050>

3 months agovorbis_parse: check writes to GstOggStream.vorbis_mode_sizes
Mathieu Duponchelle [Wed, 2 Oct 2024 13:16:30 +0000 (15:16 +0200)]
vorbis_parse: check writes to GstOggStream.vorbis_mode_sizes

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-117 Fixes gstreamer#3875

Also perform out-of-bounds check for accesses to op->packet

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8050>

3 months agodiscoverer: Don't print channel layout for more than 64 channels
Sebastian Dröge [Mon, 30 Sep 2024 15:19:30 +0000 (18:19 +0300)]
discoverer: Don't print channel layout for more than 64 channels

64+ channels are always unpositioned / unknown layout.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-248
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3864

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8046>

3 months agojpegdec: Directly error out on negotiation failures
Sebastian Dröge [Mon, 30 Sep 2024 13:22:19 +0000 (16:22 +0300)]
jpegdec: Directly error out on negotiation failures

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-247
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3862

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8052>

3 months agosubparse: Check for NULL return of strchr() when parsing LRC subtitles
Sebastian Dröge [Wed, 9 Oct 2024 15:23:47 +0000 (11:23 -0400)]
subparse: Check for NULL return of strchr() when parsing LRC subtitles

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-263
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3892

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8051>

4 months agoopusdec: Set at most 64 channels to NONE position
Sebastian Dröge [Tue, 1 Oct 2024 10:22:50 +0000 (13:22 +0300)]
opusdec: Set at most 64 channels to NONE position

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-116
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3871

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8049>

4 months agossaparse: Don't use strstr() on strings that are potentially not NULL-terminated
Sebastian Dröge [Mon, 30 Sep 2024 15:36:19 +0000 (18:36 +0300)]
ssaparse: Don't use strstr() on strings that are potentially not NULL-terminated

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8048>

4 months agossaparse: Search for closing brace after opening brace
Sebastian Dröge [Mon, 30 Sep 2024 18:40:44 +0000 (21:40 +0300)]
ssaparse: Search for closing brace after opening brace

Otherwise removing anything between the braces leads to out of bound writes if
there is a closing brace before the first opening brace.

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-228
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3870

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8048>

4 months agovorbisdec: Set at most 64 channels to NONE position
Sebastian Dröge [Mon, 30 Sep 2024 18:35:07 +0000 (21:35 +0300)]
vorbisdec: Set at most 64 channels to NONE position

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-115
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3869

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8047>

4 months agoid3v2: Don't try parsing extended header if not enough data is available
Sebastian Dröge [Thu, 26 Sep 2024 10:43:06 +0000 (13:43 +0300)]
id3v2: Don't try parsing extended header if not enough data is available

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-235
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3842

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8045>

4 months agoqtdemux: Avoid integer overflow when parsing Theora extension
Sebastian Dröge [Thu, 26 Sep 2024 19:16:06 +0000 (22:16 +0300)]
qtdemux: Avoid integer overflow when parsing Theora extension

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-166
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3851

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8044>

4 months agoallocator: Avoid integer overflow when allocating sysmem
Sebastian Dröge [Thu, 26 Sep 2024 19:07:22 +0000 (22:07 +0300)]
allocator: Avoid integer overflow when allocating sysmem

Thanks to Antonio Morales for finding and reporting the issue.

Fixes GHSL-2024-166
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3851

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8044>

4 months agolevel: Fix integer overflow when filling LevelMeta
Nicolas Dufresne [Fri, 29 Nov 2024 18:41:54 +0000 (13:41 -0500)]
level: Fix integer overflow when filling LevelMeta

The level in GstAudioLevelMeta is represented as a signed 8bit value from 0 to
127 (with 127 meaning silence). When converting from double, make sure to clip
the value, this also prevent integer overflow in the conversion. This fixes an
issue where a lower then -127db is reported and random level with near silent
streams (due to integer overflow).

Fixes #4068

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8029>

4 months agokmssink: Add mediatek auto-detection
Pablo Sun [Mon, 2 Dec 2024 11:34:14 +0000 (19:34 +0800)]
kmssink: Add mediatek auto-detection

Add MediaTek display controller into list of
auto-detected modules.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8027>

4 months agortp: Fix precision loss in gst_rtcp_ntp_to_unix()
Philippe Normand [Fri, 29 Nov 2024 17:33:29 +0000 (17:33 +0000)]
rtp: Fix precision loss in gst_rtcp_ntp_to_unix()

Without this patch the UNIX timestamp resulting from the translation from NTP
would be off by one nano-second.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8022>

4 months agosystemclock: Don't keep the clock entry locked while getting the time from the clock
Sebastian Dröge [Thu, 28 Nov 2024 14:06:17 +0000 (16:06 +0200)]
systemclock: Don't keep the clock entry locked while getting the time from the clock

gst_clock_get_time() will take the clock mutex, which would then result in a lock
order violation and possible deadlocks. If both mutexes are to be locked, the
clock must always be locked first.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8019>

4 months agosystemclock: Get rid of conditional unlocking of the clock entries
Sebastian Dröge [Thu, 28 Nov 2024 13:49:24 +0000 (15:49 +0200)]
systemclock: Get rid of conditional unlocking of the clock entries

At every point it is known whether the entry needs to be unlocked or not.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8019>

4 months agosystemclock: Remove confusing conditional unlock
Sebastian Dröge [Thu, 28 Nov 2024 13:43:08 +0000 (15:43 +0200)]
systemclock: Remove confusing conditional unlock

At this point the entry is always locked and needs to be unlocked.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8019>

4 months agosystemclock: Use a flag while waiting for the async thread to start
Sebastian Dröge [Thu, 28 Nov 2024 13:25:47 +0000 (15:25 +0200)]
systemclock: Use a flag while waiting for the async thread to start

Otherwise there can be spurious wakeups.

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8019>

4 months agomxfmux: Fix off-by-one in the month when generating a timestamp for now
Sebastian Dröge [Sun, 1 Dec 2024 09:45:34 +0000 (11:45 +0200)]
mxfmux: Fix off-by-one in the month when generating a timestamp for now

Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/8018>