Tim-Philipp Müller [Mon, 6 Jan 2025 19:48:08 +0000 (19:48 +0000)]
Release 1.24.11
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
Tim-Philipp Müller [Tue, 3 Dec 2024 23:39:54 +0000 (23:39 +0000)]
Back to development after 1.24.10
Tim-Philipp Müller [Tue, 3 Dec 2024 23:29:07 +0000 (23:29 +0000)]
Release 1.24.10
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>
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>