d3d11convert: protect 'add-borders' with mutex
[platform/upstream/gstreamer.git] / subprojects / gst-plugins-bad / NEWS
1 GStreamer 1.22 Release Notes
2
3 GStreamer 1.22.0 was originally released on 23 January 2023.
4
5 The latest bug-fix release in the stable 1.22 series is 1.22.2 and was
6 released on 11 April 2023.
7
8 See https://gstreamer.freedesktop.org/releases/1.22/ for the latest
9 version of this document.
10
11 Last updated: Tuesday 11 April 2023, 16:45 UTC (log)
12
13 Introduction
14
15 The GStreamer team is proud to announce a new major feature release in
16 the stable 1.x API series of your favourite cross-platform multimedia
17 framework!
18
19 As always, this release is again packed with many new features, bug
20 fixes and other improvements.
21
22 Highlights
23
24 -   AV1 video codec support improvements
25 -   New HLS, DASH and Microsoft Smooth Streaming adaptive streaming
26     clients
27 -   Qt6 support for rendering video inside a QML scene
28 -   Minimal builds optimised for binary size, including only the
29     individual elements needed
30 -   Playbin3, Decodebin3, UriDecodebin3, Parsebin enhancements and
31     stabilisation
32 -   WebRTC simulcast support and support for Google Congestion Control
33 -   WebRTC-based media server ingestion/egress (WHIP/WHEP) support
34 -   New easy to use batteries-included WebRTC sender plugin
35 -   Easy RTP sender timestamp reconstruction for RTP and RTSP
36 -   ONVIF timed metadata support
37 -   New fragmented MP4 muxer and non-fragmented MP4 muxer
38 -   New plugins for Amazon AWS storage and audio transcription services
39 -   New gtk4paintablesink and gtkwaylandsink renderers
40 -   New videocolorscale element that can convert and scale in one go for
41     better performance
42 -   High bit-depth video improvements
43 -   Touchscreen event support in navigation API
44 -   Rust plugins now shipped in macOS and Windows/MSVC binary packages
45 -   H.264/H.265 timestamp correction elements for PTS/DTS reconstruction
46     before muxers
47 -   Improved design for DMA buffer sharing and modifier handling for
48     hardware-accelerated video decoders/encoders/filters and
49     capturing/rendering on Linux
50 -   Video4Linux2 hardware accelerated decoder improvements
51 -   CUDA integration and Direct3D11 integration and plugin improvements
52 -   New H.264 / AVC, H.265 / HEVC and AV1 hardware-accelerated video
53     encoders for AMD GPUs using the Advanced Media Framework (AMF) SDK
54 -   applemedia: H.265 / HEVC video encoding + decoding support
55 -   androidmedia: H.265 / HEVC video encoding support
56 -   New “force-live” property for audiomixer, compositor, glvideomixer,
57     d3d11compositor etc.
58 -   Lots of new plugins, features, performance improvements and bug
59     fixes
60
61 Major new features and changes
62
63 AV1 video codec support improvements
64
65 AV1 is a royalty free next-generation video codec by AOMedia and a free
66 alternative to H.265/HEVC.
67
68 While supported in earlier versions of GStreamer already, this release
69 saw a lot of improvements across the board:
70
71 -   Support for hardware encoding and decoding via VAAPI/VA, AMF, D3D11,
72     NVCODEC, QSV and Intel MediaSDK. Hardware codecs for AV1 are slowly
73     becoming available in embedded systems and desktop GPUs (AMD, Intel,
74     NVIDIA), and these can now be used via GStreamer.
75
76 -   New AV1 RTP payloader and depayloader elements.
77
78 -   New encoder settings in the AOM reference encoder-based av1enc
79     element.
80
81 -   Various improvements in the AV1 parser and in the MP4/Matroska/WebM
82     muxers/demuxers.
83
84 -   dav1d and rav1e based software decoder/encoder elements shipped as
85     part of the binaries.
86
87 -   AV1 parser improvements and various bugfixes all over the place.
88
89 Touchscreen event support in Navigation API
90
91 The Navigation API supports the sending of key press events and mouse
92 events through a GStreamer pipeline. Typically these will be picked up
93 by a video sink on which these events happen and then the event is
94 transmitted into the pipeline so it can be handled by elements inside
95 the pipeline if it wasn’t handled by the application.
96
97 This has traditionally been used for DVD menu support, but can also be
98 used to forward such inputs to source elements that render a web page
99 using a browser engine such as WebKit or Chromium.
100
101 This API has now gained support for touchscreen events, and this has
102 been implemented in various plugins such as the GTK, Qt, XV, and x11
103 video sinks as well as the wpevideosrc element.
104
105 GStreamer CUDA integration
106
107 -   New gst-cuda library
108 -   integration with D3D11 and NVIDIA dGPU NVMM elements
109 -   new cudaconvertscale element
110
111 GStreamer Direct3D11 integration
112
113 -   New gst-d3d11 public library
114     -   gst-d3d11 library is not integrated with GStreamer documentation
115         system yet. Please refer to the examples
116 -   d3d11screencapture: Add Windows Graphics Capture API based capture
117     mode, including Win32 application window capturing
118 -   d3d11videosink and d3d11convert can support flip/rotation and crop
119     meta
120 -   d3d11videosink: New emit-present property and present signal so that
121     applications can overlay an image on Direct3D11 swapchain’s
122     backbuffer via Direct3D/Direct2D APIs. See also C++ and Rust
123     examples
124 -   d3d11compositor supports YUV blending/composing without intermediate
125     RGB(A) conversion to improve performance
126 -   Direct3D11 video decoders are promoted to GST_RANK_PRIMARY or
127     higher, except for the MPEG2 decoder
128
129 H.264/H.265 timestamp correction elements
130
131 -   Muxers are often picky and need proper PTS/DTS timestamps set on the
132     input buffers, but that can be a problem if the encoded input media
133     stream comes from a source that doesn’t provide proper signalling of
134     DTS, such as is often the case for RTP, RTSP and WebRTC streams or
135     Matroska container files. Theoretically parsers should be able to
136     fix this up, but it would probably require fairly invasive changes
137     in the parsers, so two new elements h264timestamper and
138     h265timestamper bridge the gap in the meantime and can reconstruct
139     missing PTS/DTS.
140
141 Easy sender timestamp reconstruction for RTP and RTSP
142
143 -   it was always possible to reconstruct and retrieve the original RTP
144     sender timestamps in GStreamer, but required a fair bit of
145     understanding of the internal mechanisms and the right property
146     configuration and clock setup.
147
148 -   rtspsrc and rtpjitterbuffer gained a new
149     “add-reference-timestamp-meta” property that if set puts the
150     original absolute reconstructed sender timestamps on the output
151     buffers via a meta. This is particularly useful if the sender is
152     synced to an NTP clock or PTP clock. The original sender timestamps
153     are either based on the RTCP NTP times, NTP RTP header extensions
154     (RFC6051) or RFC7273-style clock signalling.
155
156 Qt6 support
157
158 -   new qml6glsink element for Qt6 similar to the existing Qt5 element.
159     Matching source and overlay elements will hopefully follow in the
160     near future.
161
162 OpenGL + Video library enhancements
163
164 -   Support for new video formats (NV12_4L4, NV12_16L32S, NV12_8L128,
165     NV12_10BE_8L128) and dmabuf import in more formats (Y410, Y212_LE,
166     Y212_BE, Y210, NV21, NV61)
167
168 -   Improved support for tiled formats with arbitrary tile dimensions,
169     as needed by certain hardware decoders/encoders
170
171 -   glvideomixer: New “crop-left,”crop-right, “crop-top” and
172     “crop-bottom” pad properties for cropping inputs
173
174 -   OpenGL support for gst_video_sample_convert():
175
176     -   Used for video snapshotting and thumbnailing, to convert buffers
177         retrieved from appsinks or sink “last-sample” properties in
178         JPG/PNG thumbnails.
179     -   This function can now take samples and buffers backed by GL
180         textures as input and will automatically plug a gldownload
181         element in that case.
182
183 High bit-depth support (10, 12, 16 bits per component value) improvements
184
185 -   compositor can now handle any supported input format and also mix
186     high-bitdepth (10-16 bit) formats (naively)
187
188 -   videoflip has gained support for higher bit depth formats.
189
190 -   vp9enc, vp9dec now support 12-bit formats and also 10-bit 4:4:4
191
192 WebRTC
193
194 -   Allow insertion of bandwidth estimation elements e.g. for Google
195     Congestion Control (GCC) support
196
197 -   Initial support for sending or receiving simulcast streams
198
199 -   Support for asynchronous host resolution for STUN/TURN servers
200
201 -   GstWebRTCICE was split into base classes and implementation to make
202     it possible to plug custom ICE implementations
203
204 -   webrtcsink: batteries-included WebRTC sender (Rust)
205
206 -   whipsink: WebRTC HTTP ingest (WHIP) to a MediaServer (Rust)
207
208 -   whepsrc: WebRTC HTTP egress (WHEP) from a MediaServer (Rust)
209
210 -   Many other improvements and bug fixes
211
212 New HLS, DASH and MSS adaptive streaming clients
213
214 A new set of “adaptive demuxers” to support HLS, DASH and MSS adaptive
215 streaming protocols has been added. They provide improved performance,
216 new features and better stream compatibility compared to the previous
217 elements. These new elements require a “streams-aware” pipeline such as
218 playbin3, uridecodebin3 or urisourcebin.
219
220 The previous elements’ design prevented implementing several use-cases
221 and fixing long-standing issues. The new elements were re-designed from
222 scratch to tackle those:
223
224 -   Scheduling Only 3 threads are present, regardless of the number of
225     streams selected. One in charge of downloading fragments and
226     manifests, one in charge of outputting parsed data downstream, and
227     one in charge of scheduling. This improves performance, resource
228     usage and latency.
229
230 -   Better download control The elements now directly control the
231     scheduling and download of manifests and fragments using libsoup
232     directly instead of depending on external elements for downloading.
233
234 -   Stream selection, only the selected streams are downloaded. This
235     improves bandwith usage. Switching stream is done in such a way to
236     ensure there are no gaps, meaning the new stream will be switched to
237     only once enough data for it has been downloaded.
238
239 -   Internal parsing, the downloaded streams are parsed internally. This
240     allows the element to fully respect the various specifications and
241     offer accurate buffering, seeking and playback. This is especially
242     important for HLS streams which require parsing for proper
243     positioning of streams.
244
245 -   Buffering and adaptive rate switching, the new elements handle
246     buffering internally which allows them to have a more accurate
247     visibility of which bandwith variant to switch to.
248
249 Playbin3, Decodebin3, UriDecodebin3, Parsebin improvements
250
251 The “new” playback elements introduced in 1.18 (playbin3 and its various
252 components) have been refactored to allow more use-cases and improve
253 performance. They are no longer considered experimental, so applications
254 using the legacy playback elements (playbin and (uri)decodebin) can
255 migrate to the new components to benefit from these improvements.
256
257 -   Gapless The “gapless” feature allows files and streams to be
258     fetched, buffered and decoded in order to provide a “gapless”
259     output. This feature has been refactored extensively in the new
260     components:
261     -   A single (uri)decodebin3 (and therefore a single set of
262         decoders) is used. This improves memory and cpu usage, since on
263         identical codecs a single decoder will be used.
264     -   The “next” stream to play will be pre-rolled “just-in-time”
265         thanks to the buffering improvements in urisourcebin (see below)
266     -   This feature is now handled at the uridecodebin3 level.
267         Applications that wish to have a “gapless” stream and process it
268         (instead of just outputting it, for example for transcoding,
269         retransmission, …) can now use uridecodebin3 directly. Note that
270         a streamsynchronizer element is required in that case.
271 -   Buffering improvements The urisourcebin element is in charge of
272     fetching and (optionally) buffering/downloading the stream. It has
273     been extended and improved:
274     -   When the parse-streams property is used (by default in
275         uridecodebin3 and playbin3), compatible streams will be demuxed
276         and parsed (via parsebin) and buffering will be done on the
277         elementary streams. This provides a more accurate handling of
278         buffering. Previously buffering was done on a best-effort basis
279         and was mostly wrong (i.e. downloading more than needed).
280     -   Applications can use urisourcebin with this property as a
281         convenient way of getting elementary streams from a given URI.
282     -   Elements can handle buffering themselves (such as the new
283         adaptive demuxers) by answering the GST_QUERY_BUFFERING query.
284         In that case urisourcebin will not handle it.
285 -   Stream Selection Efficient stream selection was previously only
286     possible within decodebin3. The downside is that this meant that
287     upstream elements had to provide all the streams from which to chose
288     from, which is inefficient. With the addition of the
289     GST_QUERY_SELECTABLE query, this can now be handled by elements
290     upstream (i.e. sources)
291     -   Elements that can handle stream selection internally (such as
292         the new adaptive demuxer elements) answer that query, and handle
293         the stream selection events themselves.
294     -   In this case, decodebin3 will always process all streams that
295         are provided to it.
296 -   Instant URI switching This new feature allows switching URIs
297     “instantly” in playbin3 (and uridecodebin3) without having to change
298     states. This mimics switching channels on a television.
299     -   If compatible, decoders will be re-used, providing lower
300         latency/cpu/memory than by switching states.
301     -   This is enabled by setting the instant-uri property to true,
302         setting the URI to switch to immediately, and then disabling the
303         instant-uri property again afterwards.
304 -   playbin3, decodebin3, uridecodebin3, parsebin, and urisourcebin are
305     no longer experimental
306     -   They were originally marked as ‘technology preview’ but have
307         since seen extensive usage in production settings, so are
308         considered ready for general use now.
309
310 Fraunhofer AAC audio encoder HE-AAC and AAC-LD profile support
311
312 -   fdkaacenc:
313     -   Support for encoding to HE-AACv1 and HE-AACv2 profile
314     -   Support for encoding to AAC Low Delay (LD) profile
315     -   Advanced bitrate control options via new “rate-control”,
316         “vbr-preset”, “peak-bitrate”, and “afterburner” properties
317
318 RTP rapid synchronization support in the RTP stack (RFC6051)
319
320 RTP provides several mechanisms how streams can be synchronized relative
321 to each other, and how absolute sender times for RTP packets can be
322 obtained. One of these mechanisms is via RTCP, which has the
323 disadvantage that the synchronization information is only distributed
324 out-of-band and usually some time after the start.
325
326 GStreamer’s RTP stack, specifically the rtpbin, rtpsession and
327 rtpjitterbuffer elements, now also have support for retrieving and
328 sending the same synchronization information in-band via RTP header
329 extensions according to RFC6051 (Rapid Synchronisation of RTP Flows).
330 Only 64-bit timestamps are supported currently.
331
332 This provides per packet synchronization information from the very
333 beginning of a stream and allows accurate inter-stream, and (depending
334 on setup) inter-device, synchronization at the receiver side.
335
336 ONVIF XML Timed Metadata support
337
338 The ONVIF standard implemented by various security cameras also
339 specifies a format for timed metadata that is transmitted together with
340 the audio/video streams, usually over RTSP.
341
342 Support for this timed metadata is implemented in the MP4 demuxer now as
343 well as the new fragmented MP4 muxer and the new non-fragmented MP4
344 muxer from the GStreamer Rust plugins. Additionally, the new onvif
345 plugin ‒ which is part of the GStreamer Rust plugins ‒ provides general
346 elements for handling the metadata and e.g. overlaying certain parts of
347 it over a video stream.
348
349 As part of this support for absolute UTC times was also implemented
350 according to the requirements of the ONVIF standards in the
351 corresponding elements.
352
353 MP3 gapless playback support
354
355 While MP3 can probably considered a legacy format at this point, a new
356 feature was added with this release.
357
358 When playing back plain MP3 files, i.e. outside a container format,
359 switches between files can now be completely gapless if the required
360 metadata is provided inside the file. There is no standardized metadata
361 for this, but the LAME MP3 encoder writes metadata that can be parsed by
362 the mpegaudioparse element now and forwarded to decoders for ensuring
363 removal of padding samples at the front and end of MP3 files.
364
365 “force-live” property for audio + video aggregators
366
367 This is a quality of life fix for playout and streaming applications
368 where it is common to have audio and video mixer elements that should
369 operate in live mode from the start and produce output continuously.
370
371 Often one would start a pipeline without any inputs hooked up to these
372 mixers in the beginning, and up until now there was no way to easily
373 force these elements into live mode from the start. One would have to
374 add an initial live video or audio test source as dummy input to achieve
375 this.
376
377 The new “force-live” property makes these audio and video aggregators
378 start in live mode without the need for any dummy inputs, which is
379 useful for scenarios where inputs are only added after starting the
380 pipeline.
381
382 This new property should usually be used in connection with the
383 “min-upstream-latency” property, i.e. you should always set a non-0
384 minimum upstream latency then.
385
386 This is now supported in all GstAudioAggregator and GstVideoAggregator
387 subclasses such as audiomixer, audiointerleave, compositor,
388 glvideomixer, d3d11compositor, etc.
389
390 New elements and plugins
391
392 -   new cudaconvertscale element that can convert and scale in one pass
393
394 -   new gtkwaylandsink element based on gtksink, but similar to
395     waylandsink and uses Wayland APIs directly instead of rendering with
396     Gtk/Cairo primitives. This approach is only compatible with Gtk3,
397     and like gtksink this element only supports Gtk3.
398
399 -   new h264timestamper and h265timestamper elements to reconstruct
400     missing pts/dts from inputs that might not provide them such as
401     e.g. RTP/RTSP/WebRTC inputs (see above)
402
403 -   mfaacdec, mfmp3dec: Windows MediaFoundation AAC and MP3 decoders
404
405 -   new msdkav1enc AV1 video encoder element
406
407 -   new nvcudah264enc, nvcudah265enc, nvd3d11h264enc, and nvd3d11h265enc
408     NVIDIA GPU encoder elements to support zero-copy encoding, via CUDA
409     and Direct3D11 APIs, respectively
410
411 -   new nvautogpuh264enc and nvautogpuh265enc NVIDIA GPU encoder
412     elements: The auto GPU elements will automatically select a target
413     GPU instance in case multiple NVIDIA desktop GPUs are present, also
414     taking into account the input memory. On Windows CUDA or Direct3D11
415     mode will be determined by the elements automatically as well. Those
416     new elements are useful if target GPU and/or API mode (either CUDA
417     or Direct3D11 in case of Windows) is undeterminable from the encoder
418     point of view at the time when pipeline is configured, and therefore
419     lazy target GPU and/or API selection are required in order to avoid
420     unnecessary memory copy operations.
421
422 -   new nvav1dec AV1 NVIDIA desktop GPU decoder element
423
424 -   new qml6glsink element to render video with Qt6
425
426 -   qsv: New Intel OneVPL/MediaSDK (a.k.a Intel Quick Sync) based
427     decoder and encoder elements, with gst-d3d11 (on Windows) and gst-va
428     (on Linux) integration
429
430     -   Support multi-GPU environment, for example, concurrent video
431         encoding using Intel iGPU and dGPU in a single pipeline
432     -   H.264 / H.265 / VP9 and JPEG decoders
433     -   H.264 / H.265 / VP9 / AV1 / JPEG encoders with dynamic encoding
434         bitrate update
435     -   New plugin does not require external SDK for building on Windows
436
437 -   vulkanoverlaycompositor: new vulkan overlay compositor element to
438     overlay upstream GstVideoOverlayCompositonMeta onto the video
439     stream.
440
441 -   vulkanshaderspv: performs operations with SPIRV shaders in Vulkan
442
443 -   win32ipcvideosink, win32ipcvideosrc: new shared memory videosrc/sink
444     elements for Windows
445
446 -   wicjpegdec, wicpngdec: Windows Imaging Component (WIC) based JPEG
447     and PNG decoder elements.
448
449 -   Many exciting new Rust elements, see Rust section below
450
451 New element features and additions
452
453 -   audioconvert: Dithering now uses a slightly slower, less biased PRNG
454     which results in better quality output. Also dithering can now be
455     enabled via the new “dithering-threshold” property for target bit
456     depths of more than 20 bits.
457
458 -   av1enc: Add “keyframe-max-dist” property for controlling max
459     distance between keyframes, as well as “enc-pass”, “keyframe-mode”,
460     “lag-in-frames” and “usage-profile” properties.
461
462 -   cccombiner: new “output-padding” property
463
464 -   decklink: Add support for 4k DCI, 8k/UHD2 and 8k DCI modes
465
466 -   dvbsubenc: Support for >SD resolutions is working correctly now.
467
468 -   fdkaacenc: Add HE-AAC / HE-AACv2 profile support
469
470 -   glvideomixer: New “crop-left,”crop-right, “crop-top” and
471     “crop-bottom” pad properties for cropping inputs
472
473 -   gssink: new ‘content-type’ property. Useful when one wants to upload
474     a video as video/mp4 instead of ’video/quicktime` for example.
475
476 -   jpegparse: Rewritten using the common parser library
477
478 -   msdk:
479
480     -   new msdkav1enc AV1 video encoder element
481     -   msdk decoders: Add support for Scaler Format Converter (SFC) on
482         supported Intel platforms for hardware accelerated conversion
483         and scaling
484     -   msdk encoders: support import of dmabuf, va memory and D3D11
485         memory
486     -   msdk encoders: add properties for low delay bitrate control and
487         max frame sizes for I/P frames
488     -   msdkh264enc, msdkh265enc: more properties to control intra
489         refresh
490     -   note that on systems with multi GPUs the Windows D3D11
491         integration might only work reliably if the Intel GPU is the
492         primary GPU
493
494 -   mxfdemux: Add support for Canon XF-HEVC
495
496 -   openaptx: Support the freeaptx library
497
498 -   qroverlay:
499
500     -   new “qrcode-case-sensitive” property allows encoding case
501         sensitive strings like wifi SSIDs or passwords.
502     -   added the ability to pick up data to render from an
503         upstream-provided custom GstQROverlay meta
504
505 -   qtdemux: Add support for ONVIF XML Timed MetaData and AVC-Intra
506     video
507
508 -   rfbsrc now supports the uri handler interface, so applications can
509     use RFB/VNC sources in uridecodebin(3) and playbin, with
510     e.g. rfb://:password@10.1.2.3:5903?shared=1
511
512 -   rtponviftimestamp: Add support for using reference timestamps
513
514 -   rtpvp9depay now has the same keyframe-related properties as
515     rtpvp8depay and rtph264depay: “request-keyframe” and
516     “wait-for-keyframe”
517
518 -   rtspsrc: Various RTSP servers are using invalid URL operations for
519     constructing the control URL. Until GStreamer 1.16 these worked
520     correctly because GStreamer was just appending strings itself to
521     construct the control URL, but starting version 1.18 the correct URL
522     operations were used. With GStreamer 1.22, rtspsrc now first tries
523     with the correct control URL and if that fails it will retry with
524     the wrongly constructed control URL to restore support for such
525     servers.
526
527 -   rtspsrc and rtpjitterbuffer gained a new
528     “add-reference-timestamp-meta” property that makes them put the
529     unmodified original sender timestamp on output buffers for NTP or
530     PTP clock synced senders
531
532 -   srtsrc, srtsink: new “auto-reconnect” property to make it possible
533     to disable automatic reconnects (in caller mode) and make the
534     elements post an error immediately instead; also stats improvements
535
536 -   srtsrc: new “keep-listening” property to avoid EOS on disconnect and
537     keep the source running while it waits for a new connection.
538
539 -   videocodectestsink: added YUV 4:2:2 support
540
541 -   wasapi2src: Add support for process loopback capture
542
543 -   wpesrc: Add support for modifiers in key/touch/pointer events
544
545 Plugin and library moves
546
547 -   The xingmux plugin has been moved from gst-plugins-ugly into
548     gst-plugins-good.
549
550 -   The various Windows directshow plugins in gst-plugins-bad have been
551     unified into a single directshow plugin.
552
553 Plugin removals
554
555 -   The dxgiscreencapsrc element has been removed, use
556     d3d11screencapturesrc instead
557
558 Miscellaneous API additions
559
560 -   GST_AUDIO_FORMAT_INFO_IS_VALID_RAW() and
561     GST_VIDEO_FORMAT_INFO_IS_VALID_RAW() can be used to check if a
562     GstAudioFormatInfo or GstVideoFormatInfo has been initialised to a
563     valid raw format.
564
565 -   Video SEI meta: new GstVideoSEIUserDataUnregisteredMeta to carry
566     H.264 and H.265 metadata from SEI User Data Unregistered messages.
567
568 -   vulkan: Expose gst_vulkan_result_to_string()
569
570 Miscellaneous performance, latency and memory optimisations
571
572 -   liborc 0.4.33 adds support for aarch64 (64-bit ARM) architecture
573     (not enabled by default on Windows yet though) and improvements for
574     32-bit ARM and should greatly enhance performance for certain
575     operations that use ORC.
576
577 -   as always there have been plenty of performance, latency and memory
578     optimisations all over the place.
579
580 Miscellaneous other changes and enhancements
581
582 -   the audio/video decoder base classes will not consider decoding
583     errors a hard error by default anymore but will continue trying to
584     decode. Previously more than 10 consecutive errors were considered a
585     hard error but this caused various partially broken streams to fail.
586     The threshold is configurable via the “max-errors” property.
587
588 -   compatibility of the GStreamer PTP clock implementation with
589     different PTP server implementations was improved, and
590     synchronization is achieved successfully in various scenarios that
591     failed before.
592
593 Tracing framework and debugging improvements
594
595 New tracers
596
597 -   buffer-lateness: Records lateness of buffers and the reported
598     latency for each pad in a CSV file. Comes with a script for
599     visualisation.
600
601 -   pipeline-snapshot: Creates a .dot file of all pipelines in the
602     application whenever requested via SIGUSR1 (on UNIX systems)
603
604 -   queue-levels: Records queue levels for each queue in a CSV file.
605     Comes with a script for visualisation.
606
607 Debug logging system improvements
608
609 -   new log macros GST_LOG_ID, GST_DEBUG_ID, GST_INFO_ID,
610     GST_WARNING_ID, GST_ERROR_ID, and GST_TRACE_ID allow passing a
611     string identifier instead of a GObject. This makes it easier to log
612     non-gobject-based items and also has performance benefits.
613
614 Tools
615
616 -   gst-play-1.0 gained a --no-position command line option to suppress
617     position/duration queries, which can be useful to reduce debug log
618     noise.
619
620 GStreamer FFMPEG wrapper
621
622 -   Fixed bitrate management and timestamp inaccuracies for video
623     encoders
624
625 -   Fix synchronization issues and errors created by the (wrong)
626     forwarding of upstream segment events by ffmpeg demuxers.
627
628 -   Clipping meta support for gapless mp3 playback
629
630 GStreamer RTSP server
631
632 -   Add RFC5576 Source-specific media attribute to the SDP media for
633     signalling the CNAME
634
635 -   Add support for adjusting request response on pipeline errors
636
637     -   Give the application the possibility to adjust the error code
638         when responding to a request. For that purpose the pipeline’s
639         bus messages are emitted to subscribers through a
640         “handle-message” signal. The subscribers can then check those
641         messages for errors and adjust the response error code by
642         overriding the virtual method
643         GstRTSPClientClass::adjust_error_code().
644
645 -   Add gst_rtsp_context_set_token() method to make it possible to set
646     the RTSPToken on some RTSPContext from bindings such as the Python
647     bindings.
648
649 -   rtspclientsink gained a “publish-clock-mode” property to configure
650     whether the pipeline clock should be published according to RFC7273
651     (RTP Clock Source Signalling), similar to the same API on
652     GstRTSPMedia.
653
654 GStreamer VA-API support
655
656 -   Development activity has shifted towards the new va plugin, with
657     gstreamer-vaapi now basically in maintenance-only mode. Most of the
658     below refers to the va plugin (not gstreamer-vaapi).
659
660 -   new gst-va library for GStreamer VA-API integration
661
662 -   vajpegdec: new JPEG decoder
663
664 -   vah264enc, vah265enc: new H.264/H.265 encoders
665
666 -   vah264lpenc, vah265lpenc: new low power mode encoders
667
668 -   vah265enc: Add extended formats support such as 10/12 bits, 4:2:2
669     and 4:4:4
670
671 -   Support encoder reconfiguration
672
673 -   vacompositor: Add new compositor element using the VA-API VPP
674     interface
675
676 -   vapostproc:
677
678     -   new “scale-method” property
679     -   Process HDR caps if supported
680     -   parse video orientation from tags
681
682 -   vaapipostproc: Enable the use of DMA-Buf import and export
683     (gstreamer-vaapi)
684
685 GStreamer Video4Linux2 support
686
687 -   Added support for Mediatek Stateless CODEC (VP8, H.264, VP9)
688
689 -   Stateless H.264 interlaced decoder support
690
691 -   Stateless H.265 decoder support
692
693 -   Stateful decoder support for driver resolution change events
694
695 -   Stateful decoding support fixes for NXP/Amphion driver
696
697 -   Support for hardware crop in v4l2src
698
699 -   Conformance test improvement for stateful decoders
700
701 -   Fixes for Raspberry Pi CODEC
702
703 GStreamer OMX
704
705 -   There were no changes in this module
706
707 GStreamer Editing Services and NLE
708
709 -   Handle compositors that are bins around the actual compositor
710     implementation (like glvideomixers which wraps several elements)
711
712 -   Add a mode to disable timeline editing API so the user can be in
713     full control of its layout (meaning that the user is responsible for
714     ensuring its validity/coherency)
715
716 -   Add a new fade-in transition type
717
718 -   Add support for non-1/1 PAR source videos
719
720 -   Fix frame accuracy when working with very low framerate streams
721
722 GStreamer validate
723
724 -   Clean up and stabilize API so we can now generate rust bindings
725
726 -   Enhance the appsrc-push action type allowing to find tune the
727     buffers more in details
728
729 -   Add an action type to verify currently configured pad caps
730
731 -   Add a way to run checks from any thread after executing a ‘wait’
732     action. This is useful when waiting on a signal and want to check
733     the value of a property right when it is emited for example.
734
735 GStreamer Python Bindings
736
737 -   Add a Gst.init_python() function to be called from plugins which
738     will initialise everything needed for the GStreamer Python bindings
739     but not call Gst.init() again since this will have been called
740     already.
741
742 -   Add support for the GstURIHandlerInterface that allows elements to
743     advertise what URI protocols they support.
744
745 GStreamer C# Bindings
746
747 -   Fix AppSrc and AppSink constructors
748
749 -   The C# bindings have yet to be updated to include new 1.22 API,
750     which requires improvements in various places in the bindings /
751     binding generator stack. See issue #1718 in GitLab for more
752     information and to track progress.
753
754 GStreamer Rust Bindings and Rust Plugins
755
756 The GStreamer Rust bindings are released separately with a different
757 release cadence that’s tied to gtk-rs, but the latest release has
758 already been updated for the new GStreamer 1.22 API. Check the bindings
759 release notes for details of the changes since 0.18, which was released
760 around GStreamer 1.20.
761
762 gst-plugins-rs, the module containing GStreamer plugins written in Rust,
763 has also seen lots of activity with many new elements and plugins. A
764 list of all Rust plugins and elements provided with the 0.9 release can
765 be found in the repository.
766
767 -   33% of GStreamer commits are now in Rust (bindings + plugins), and
768     the Rust plugins module is also where most of the new plugins are
769     added these days.
770
771 -   The Rust plugins are now shipped as part of the Windows MSVC + macOS
772     binary packages. See below for the list of shipped plugins and the
773     status of Rust support in cerbero.
774
775 -   The Rust plugins are also part of the documentation on the GStreamer
776     website now.
777
778 -   Rust plugins can be used from any programming language. To the
779     outside they look just like a plugin written in C or C++.
780
781 New Rust plugins and elements
782
783 -   rtpav1pay / rtpav1depay: RTP (de)payloader for the AV1 video codec
784 -   gtk4paintablesink: a GTK4 video sink that provides a GdkPaintable
785     for rendering a video in any place inside a GTK UI. Supports
786     zero-copy rendering via OpenGL on Linux and macOS.
787 -   ndi: source, sink and device provider for NewTek NDI protocol
788 -   onvif: Various elements for parsing, RTP (de)payloading, overlaying
789     of ONVIF timed metadata.
790 -   livesync: Element for converting a live stream into a continuous
791     stream without gaps and timestamp jumps while preserving live
792     latency requirements.
793 -   raptorq: Encoder/decoder elements for the RaptorQ FEC mechanism that
794     can be used for RTP streams (RFC6330).
795
796 WebRTC elements
797
798 -   webrtcsink: a WebRTC sink (batteries included WebRTC sender with
799     specific signalling)
800 -   whipsink: WebRTC HTTP ingest (WHIP) to MediaServer
801 -   whepsrc: WebRTC HTTP egress (WHEP) from MediaServer
802 -   rtpgccbwe: RTP bandwidth estimator based on the Google Congestion
803     Control algorithm (GCC), used by webrtcsink
804
805 Amazon AWS services
806
807 -   awss3src / awss3sink: A source and sink element to talk to the
808     Amazon S3 object storage system.
809 -   awss3hlssink: A sink element to store HLS streams on Amazon S3.
810 -   awstranscriber: an element wrapping the AWS Transcriber service.
811 -   awstranscribeparse: an element parsing the packets of the AWS
812     Transcriber service.
813
814 Video Effects (videofx)
815
816 -   roundedcorners: Element to make the corners of a video rounded via
817     the alpha channel.
818 -   colordetect: A pass-through filter able to detect the dominant
819     color(s) on incoming frames, using color-thief.
820 -   videocompare: Compare similarity of video frames. The element can
821     use different hashing algorithms like Blockhash, DSSIM, and others.
822
823 New MP4 muxer + Fragmented MP4 muxer
824
825 -   isofmp4mux, cmafmux, dashmp4mux, onviffmp4mux: New fragmented
826     MP4/ISOBMFF/CMAF muxer for generating e.g. DASH/HLS media fragments.
827 -   isomp4mux, onvifmp4mux: New non-fragmented, normal MP4 muxer.
828
829 Both plugins provides elements that replace the existing qtmux/mp4mux
830 element from gst-plugins-good. While not feature-equivalent yet, the new
831 codebase and using separate elements for the fragment and non-fragmented
832 case allows for easier extensability in the future.
833
834 Cerbero Rust support
835
836 -   Starting this release, cerbero has support for building and shipping
837     Rust code on Linux, Windows (MSVC) and macOS. The Windows (MSVC) and
838     macOS binaries also ship the GStreamer Rust plugins in this release.
839     Only dynamic plugins are built and shipped currently.
840
841 -   Preliminary support for Android, iOS and Windows (MinGW) exists but
842     more work is needed. Check the tracker issue for more details about
843     future work.
844
845 -   The following plugins are included currently: audiofx, aws, cdg,
846     claxon, closedcaption, dav1d, fallbackswitch, ffv1, fmp4, gif,
847     hlssink3, hsv, json, livesync, lewton, mp4, ndi, onvif, rav1e,
848     regex, reqwest, raptorq, png, rtp, textahead, textwrap, threadshare,
849     togglerecord, tracers, uriplaylistbin, videofx, webrtc, webrtchttp.
850
851 Build and Dependencies
852
853 -   meson 0.62 or newer is required
854
855 -   GLib >= 2.62 is now required (but GLib >= 2.64 is strongly
856     recommended)
857
858 -   libnice >= 0.1.21 is now required and contains important fixes for
859     GStreamer’s WebRTC stack.
860
861 -   liborc >= 0.4.33 is recommended for 64-bit ARM support and 32-bit
862     ARM improvements
863
864 -   onnx: OnnxRT >= 1.13.1 is now required
865
866 -   openaptx: can now be built against libfreeaptx
867
868 -   opencv: allow building against any 4.x version
869
870 -   shout: libshout >= 2.4.3 is now required
871
872 -   gstreamer-vaapi’s Meson build options have been switched from a
873     custom combo type (yes/no/auto) to the built-in Meson feature type
874     (enabled/disabled/auto)
875
876 -   The GStreamer Rust plugins module gst-plugins-rs is now considered
877     an essential part of the GStreamer plugin offering and packagers and
878     distributors are strongly encouraged to package and ship those
879     plugins alongside the existing plugin modules.
880
881 -   we now make use of Meson’s install tags feature which allows
882     selective installation of installl components and might be useful
883     for packagers.
884
885 Monorepo build (gst-build)
886
887 -   new “orc-source” build option to allow build against a
888     system-installed liborc instead of forcing the use of orc as a
889     subproject.
890
891 -   GStreamer command line tools can now be linked to the gstreamer-full
892     library if it’s built
893
894 Cerbero
895
896 Cerbero is a meta build system used to build GStreamer plus dependencies
897 on platforms where dependencies are not readily available, such as
898 Windows, Android, iOS, and macOS.
899
900 General improvements
901
902 -   Rust support was added for all support configurations, controlled by
903     the rust variant; see above for more details
904 -   All pkgconfig files are now reliably relocatable without requiring
905     pkg-config --define-prefix. This also fixes statically linking with
906     GStreamer plugins using the corresponding pkgconfig files.
907 -   New documentation on how to build a custom GStreamer repository
908     using Cerbero, please see the README
909 -   HTTPS certificate checking is enabled for downloads on all platforms
910     now
911 -   Fetching now automatically retries on error for robustness against
912     transient errors
913 -   Support for building the new Qt6 plugin was added
914 -   pkgconfig files for various recipes were fixed
915 -   Several recipes were updated to newer versions
916 -   New plugins: adaptivedemux2 aes codectimestamper dav1d
917 -   New libraries: cuda webrtcnice
918
919 macOS / iOS
920
921 -   Added support for running Cerbero on ARM64 macOS
922 -   GStreamer.framework and all libraries in it are now relocatable,
923     which means they use LC_RPATH entries to find dependencies instead
924     of using an absolute path. If you link to GStreamer using the
925     pkgconfig files, no action is necessary. However, if you use the
926     framework directly or link to the libraries inside the framework by
927     hand, then you need to pass -Wl,-rpath,<path_to_libdir> to the
928     linker.
929 -   Apple bitcode support was dropped, since Apple has deprecated it
930 -   macOS installer now correctly advertises support for both x86_64 and
931     arm64
932 -   macOS framework now ships the gst-rtsp-server-1.0 library
933 -   Various fixes were made to make static linking to gstreamer
934     libraries and plugins work correctly on macOS
935 -   When statically linking to the applemedia plugin using Xcode 13, you
936     will need to pass -fno-objc-msgsend-selector-stubs which works
937     around a backwards-incompatible change in Xcode 14. This is not
938     required for the rest of GStreamer at present, but will be in the
939     future.
940 -   macOS installer now shows the GStreamer logo correctly
941
942 Windows
943
944 -   MSVC is now required by default on Windows, and the Visual Studio
945     variant is enabled by default
946     -   To build with MinGW, use the mingw variant
947 -   Visual Studio props files were updated for newer Visual Studio
948     versions
949 -   Visual Studio 2015 support was dropped
950 -   MSYS2 is now supported as the base instead of MSYS. Please see the
951     README for more details. Some advantages include:
952     -   Faster build times, since parallel make works
953     -   Faster bootstrap, since some tools are provided by MSYS2
954     -   Other speed-ups due to using MSYS2 tools instead of MSYS
955 -   Faster download by using powershell instead of hand-rolled Python
956     code
957 -   Many recipes were ported from Autotools to Meson, speeding up the
958     build
959 -   Universal Windows Platform is no longer supported, and binaries are
960     no longer shipped for it
961 -   New documentation on how to force a specific Visual Studio
962     installation in Cerbero, please see the README
963 -   New plugins: qsv wavpack directshow amfcodec wic win32ipc
964 -   New libraries: d3d11
965
966 Windows MSI installer
967
968 -   Universal Windows Platform prebuilt binaries are no longer available
969
970 Linux
971
972 -   Various fixes for RHEL/CentOS 7 support
973 -   Added support for running on Linux ARM64
974
975 Android
976
977 -   Android support now requires Android API version 21 (Lollipop)
978 -   Support for Android Gradle plugin 7.2
979
980 Platform-specific changes and improvements
981
982 Android
983
984 -   Android SDK 21 is required now as minimum SDK version
985
986 -   androidmedia: Add H.265 / HEVC video encoder mapping
987
988 -   Implement JNI_OnLoad() to register static plugins etc. automatically
989     in case GStreamer is loaded from Java using System.loadLibrary(),
990     which is also useful for the gst-full deployment scenario.
991
992 Apple macOS and iOS
993
994 -   The GLib version shipped with the GStreamer binaries does not
995     initialize an NSApp and does not run a NSRunLoop on the main thread
996     anymore. This was a custom GLib patch and caused it to behave
997     different from the GLib shipped by Homebrew or anybody else.
998
999     The change was originally introduced because various macOS APIs
1000     require a NSRunLoop to run on the main thread to function correctly
1001     but as this change will never get merged into GLib and it was
1002     reverted for 1.22. Applications that relied on this behaviour should
1003     move to the new gst_macos_main() function, which also does not
1004     require the usage of a GMainLoop.
1005
1006     See e.g. gst-play.c for an example for the usage of
1007     gst_macos_main().
1008
1009 -   GStreamer.framework and all libraries in it are now relocatable,
1010     which means they use LC_RPATH entries to find dependencies instead
1011     of using an absolute path. If you link to GStreamer using the
1012     pkgconfig files, no action is necessary. However, if you use the
1013     framework directly or link to the libraries inside the framework by
1014     hand, then you need to pass -Wl,-rpath,<path_to_libdir> to the
1015     linker.
1016
1017 -   avfvideosrc: Allow specifying crop coordinates during screen capture
1018
1019 -   vtenc, vtdec: H.265 / HEVC video encoding + decoding support
1020
1021 -   osxaudiosrc: Support a device as both input and output
1022
1023     -   osxaudiodeviceprovider now probes devices more than once to
1024         determine if the device can function as both an input AND and
1025         output device. Previously, if the device provider detected that
1026         a device had any output capabilities, it was treated solely as
1027         an Audio/Sink. This caused issues for devices that have both
1028         input and output capabilities (for example, USB interfaces for
1029         professional audio have both input and output channels). Such
1030         devicesare now listed as both an Audio/Sink as well as an
1031         Audio/Source.
1032
1033 -   osxaudio: support hidden devices on macOS
1034
1035     -   These are devices that will not be shown in the macOS UIs and
1036         that cannot be retrieved without having the specific UID of the
1037         hidden device. There are cases when you might want to have a
1038         hidden device, for example when having a virtual speaker that
1039         forwards the data to a virtual hidden input device from which
1040         you can then grab the audio. The blackhole project supports
1041         these hidden devices and this change provides a way that if the
1042         device id is a hidden device it will use it instead of checkinf
1043         the hardware list of devices to understand if the device is
1044         valid.
1045
1046 Windows
1047
1048 -   win32ipcvideosink, win32ipcvideosrc: new shared memory videosrc/sink
1049     elements
1050
1051 -   wasapi2: Add support for process loopback capture for a specified
1052     PID (requires Windows 11/Windows Server 2022)
1053
1054 -   The Windows universal UWP build is currently non-functional and will
1055     need updating after the recent GLib upgrade. It is unclear if anyone
1056     is using these binaries, so if you are please make yourself known.
1057
1058 -   wicjpegdec, wicpngdec: Windows Imaging Component (WIC) based JPEG
1059     and PNG decoder elements.
1060
1061 -   mfaacdec, mfmp3dec: Windows MediaFoundation AAC and MP3 decoders
1062
1063 -   The uninstalled development environment supports PowerShell 7 now
1064
1065 Linux
1066
1067 -   Improved design for DMA buffer sharing and modifier handling for
1068     hardware-accelerated video decoders/encoders/filters and
1069     capture/rendering on Linux and Linux-like system.
1070
1071 -   kmssink
1072
1073     -   new “fd” property which allows an application to provide their
1074         own opened DRM device fd handle to kmssink. That way an
1075         application can lease multiple fd’s from a DRM master to display
1076         on different CRTC outputs at the same time with multiple kmssink
1077         instances, for example.
1078     -   new “skip-vsync” property to achieve full framerate with legacy
1079         emulation in drivers.
1080     -   HDR10 infoframe support
1081
1082 -   va plugin and gstreamer-vaapi improvements (see above)
1083
1084 -   waylandsink: Add “rotate-method” property and “render-rectangle”
1085     property
1086
1087 -   new gtkwaylandsink element based on gtksink, but similar to
1088     waylandsink and uses Wayland APIs directly instead of rendering with
1089     Gtk/Cairo primitives. This approach is only compatible with Gtk3,
1090     and like gtksink this element only supports Gtk3.
1091
1092 Documentation improvements
1093
1094 -   The GStreamer Rust plugins are now included and documented in the
1095     plugin documentation.
1096
1097 Possibly Breaking Changes
1098
1099 -   the Opus audio RTP payloader and depayloader no longer accept the
1100     lower case encoding-format=multiopus but instead produce and accept
1101     only the upper case variant encoding-format=MULTIOPUS, since those
1102     should always be upper case in GStreamer (caps fields are always
1103     case sensitive). This should hopefully only affect applications
1104     where RTP caps are set manually and multi-channel audio (>= 3
1105     channels) is used.
1106
1107 -   wpesrc: the URI handler protocols changed from wpe:// and web:// to
1108     web+http://, web+https://, and web+file:// which means URIs are RFC
1109     3986 compliant and the source can simply strip the prefix from the
1110     protocol.
1111
1112 -   The Windows screen capture element dxgiscreencapsrc has been
1113     removed, please use d3d11screencapturesrc instead.
1114
1115 -   On Android the minimum supported Android API version is now version
1116     21 and has been increased from 16.
1117
1118 -   On macOS, the GLib version shipped with the GStreamer binaries will
1119     no longer initialize an NSApp or run an NSRunLoop on the main
1120     thread. See macOS/iOS section above for details.
1121
1122 -   decklink: The decklink plugin is now using the 12.2.2 version of the
1123     SDK and will not work with drivers older than version 12.
1124
1125 -   On iOS Apple Bitcode support was removed from the binaries. This
1126     feature is deprecated since XCode 14 and not used on the App Store
1127     anymore.
1128
1129 -   The MP4/Matroska/WebM muxers now require the “stream-format” to be
1130     provided as part of the AV1 caps as only the original “obu-stream”
1131     format is supported in these containers and not the “annexb” format.
1132
1133 Known Issues
1134
1135 -   The Windows UWP build in Cerbero needs fixing after the recent GLib
1136     upgrade (see above)
1137
1138 -   The C# bindings have not been updated to include new 1.22 API yet
1139     (see above)
1140
1141 Statistics
1142
1143 -   4072 commits
1144
1145 -   2224 Merge Requests
1146
1147 -   716 Issues
1148
1149 -   200+ Contributors
1150
1151 -   ~33% of all commits and Merge Requests were in Rust modules
1152
1153 -   4747 files changed
1154
1155 -   469633 lines added
1156
1157 -   209842 lines deleted
1158
1159 -   259791 lines added (net)
1160
1161 Contributors
1162
1163 Ádám Balázs, Adam Doupe, Adrian Fiergolski, Adrian Perez de Castro, Alba
1164 Mendez, Aleix Conchillo Flaqué, Aleksandr Slobodeniuk, Alicia Boya
1165 García, Alireza Miryazdi, Andoni Morales Alastruey, Andrew Pritchard,
1166 Arun Raghavan, A. Wilcox, Bastian Krause, Bastien Nocera, Benjamin
1167 Gaignard, Bill Hofmann, Bo Elmgreen, Boyuan Zhang, Brad Hards, Branko
1168 Subasic, Bruce Liang, Bunio FH, byran77, Camilo Celis Guzman, Carlos
1169 Falgueras García, Carlos Rafael Giani, Célestin Marot, Christian Wick,
1170 Christopher Obbard, Christoph Reiter, Chris Wiggins, Chun-wei Fan, Colin
1171 Kinloch, Corentin Damman, Corentin Noël, Damian Hobson-Garcia, Daniel
1172 Almeida, Daniel Morin, Daniel Stone, Daniels Umanovskis, Danny Smith,
1173 David Svensson Fors, Devin Anderson, Diogo Goncalves, Dmitry Osipenko,
1174 Dongil Park, Doug Nazar, Edward Hervey, ekwange, Eli Schwartz, Elliot
1175 Chen, Enrique Ocaña González, Eric Knapp, Erwann Gouesbet, Evgeny
1176 Pavlov, Fabian Orccon, Fabrice Fontaine, Fan F He, F. Duncanh, Filip
1177 Hanes, Florian Zwoch, François Laignel, Fuga Kato, George Kiagiadakis,
1178 Guillaume Desmottes, Gu Yanjie, Haihao Xiang, Haihua Hu, Havard Graff,
1179 Heiko Becker, He Junyan, Henry Hoegelow, Hiero32, Hoonhee Lee, Hosang
1180 Lee, Hou Qi, Hugo Svirak, Ignacio Casal Quinteiro, Ignazio Pillai, Igor
1181 V. Kovalenko, Jacek Skiba, Jakub Adam, James Cowgill, James Hilliard,
1182 Jan Alexander Steffens (heftig), Jan Lorenz, Jan Schmidt, Jianhui Dai,
1183 jinsl00000, Johan Sternerup, Jonas Bonn, Jonas Danielsson, Jordan
1184 Petridis, Joseph Donofry, Jose Quaresma, Julian Bouzas, Junsoo Park,
1185 Justin Chadwell, Khem Raj, Krystian Wojtas, László Károlyi, Linus
1186 Svensson, Loïc Le Page, Ludvig Rappe, Marc Leeman, Marek Olejnik, Marek
1187 Vasut, Marijn Suijten, Mark Nauwelaerts, Martin Dørum, Martin Reboredo,
1188 Mart Raudsepp, Mathieu Duponchelle, Matt Crane, Matthew Waters, Matthias
1189 Clasen, Matthias Fuchs, Mengkejiergeli Ba, MGlolenstine, Michael Gruner,
1190 Michiel Konstapel, Mikhail Fludkov, Ming Qian, Mingyang Ma, Myles
1191 Inglis, Nicolas Dufresne, Nirbheek Chauhan, Olivier Crête, Pablo Marcos
1192 Oltra, Patricia Muscalu, Patrick Griffis, Paweł Stawicki, Peter
1193 Stensson, Philippe Normand, Philipp Zabel, Pierre Bourré, Piotr
1194 Brzeziński, Rabindra Harlalka, Rafael Caricio, Rafael Sobral, Rafał
1195 Dzięgiel, Raul Tambre, Robert Mader, Robert Rosengren, Rodrigo
1196 Bernardes, Rouven Czerwinski, Ruben Gonzalez, Sam Van Den Berge,
1197 Sanchayan Maity, Sangchul Lee, Sebastian Dröge, Sebastian Fricke,
1198 Sebastian Groß, Sebastian Mueller, Sebastian Wick, Sergei Kovalev,
1199 Seungha Yang, Seungmin Kim, sezanzeb, Sherrill Lin, Shingo Kitagawa,
1200 Stéphane Cerveau, Talha Khan, Taruntej Kanakamalla, Thibault Saunier,
1201 Tim Mooney, Tim-Philipp Müller, Tomasz Andrzejak, Tom Schuring, Tong Wu,
1202 toor, Tristan Matthews, Tulio Beloqui, U. Artie Eoff, Víctor Manuel
1203 Jáquez Leal, Vincent Cheah Beng Keat, Vivia Nikolaidou, Vivienne
1204 Watermeier, WANG Xuerui, Wojciech Kapsa, Wonchul Lee, Wu Tong, Xabier
1205 Rodriguez Calvar, Xavier Claessens, Yatin Mann, Yeongjin Jeong, Zebediah
1206 Figura, Zhao Zhili, Zhiyuaniu, مهدي شينون (Mehdi Chinoune),
1207
1208 … and many others who have contributed bug reports, translations, sent
1209 suggestions or helped testing.
1210
1211 Stable 1.22 branch
1212
1213 After the 1.22.0 release there will be several 1.22.x bug-fix releases
1214 which will contain bug fixes which have been deemed suitable for a
1215 stable branch, but no new features or intrusive changes will be added to
1216 a bug-fix release usually. The 1.22.x bug-fix releases will be made from
1217 the git 1.22 branch, which will be a stable branch.
1218
1219 1.22.0
1220
1221 1.22.0 was originally released on 23 January 2023.
1222
1223 1.22.1
1224
1225 The first 1.22 bug-fix release (1.22.1) was released on 04 March 2023.
1226
1227 This release only contains bugfixes and it should be safe to update from
1228 1.22.0.
1229
1230 Highlighted bugfixes in 1.22.1
1231
1232 -   audio channel-mix: allow up to 64 channels (instead of up to 63
1233     channels)
1234 -   avfvideosrc: Don’t wait on main thread for permissions request
1235 -   avvidenc: avoid generating inaccurate output timestamps, especially
1236     with variable framerate streams
1237 -   AV1 video codec caps signalling improvements in various elements
1238 -   codectimestamper: Fix timestamping on sequence update
1239 -   d3d11overlaycompositor: fix texture width and height
1240 -   d3d11videosink: Fix rendering on external handle
1241 -   dashdemux2: fix seek operation taking a log time to finish for some
1242     streams
1243 -   nvencoder: Fix B-frame encoding on Linux and min buffers in auto GPU
1244     mode
1245 -   playbin3: fixing buffering for live pipelines
1246 -   playbin: fix potential deadlock when stopping stream with subtitles
1247     visible
1248 -   redenc: fix setting of extension ID for twcc
1249 -   rtspsrc: improved compatibility with more broken RTSP servers
1250 -   v4l2h264dec: Fix Raspberry Pi4 will not play video in application
1251 -   vtdec: fix jittery playback of H.264 Level 4.1 movies in macOS
1252 -   vtdec: Fix non-deterministic frame output after flushing seeks
1253 -   vtenc: fix handling of interlaced ProRes on Apple M1 hardware
1254 -   vtenc: don’t advertise ARGB/RGBA64 input caps on M1 Pro/Max with
1255     macOS <13
1256 -   wasapi2src: Fix loopback capture on Windows 10 Anniversary Update
1257 -   tools: better handling of non-ASCII command line arguments on
1258     Windows
1259 -   gst-libav: fix build against newer ffmpeg versions
1260 -   gst-python: Use arch-specific install dir for gi overrides
1261 -   cerbero: Fix setuptools site.py breakage in Python 3.11
1262 -   macOS packages: Fix broken binaries on macos < 11.0
1263 -   various bug fixes, memory leak fixes, and other stability and
1264     reliability improvements
1265
1266 gstreamer
1267
1268 -   buffer: fix copy meta reference debug log formatting
1269 -   bin: Don’t unlock unlocked mutex in gst_bin_remove_func()
1270 -   pad: Don’t leak user_data in gst_pad_start_task()
1271 -   aggregator: Always lock aggpad around update_time_level
1272 -   inputselector: Avoid potential deadlock when shutting down,
1273     e.g. playbin with subtitles
1274 -   multiqueue: Handle use-interleave latency live pipelines, fixing
1275     buffering for live pipelines in playbin3
1276 -   GstBaseSrc: fix transfer annotation for fixate() virtual method
1277 -   GstBaseSrc, GstPushSrc: add nullable annotations to virtual methods
1278 -   tools: Make sure UTF-8 encoded command line arguments on Windows
1279
1280 gst-plugins-base
1281
1282 -   alsasink: Fix stall when going from PLAYING to NULL (stucked at
1283     PAUSED) with uac1 gadget
1284 -   appsrc: Don’t chain up BaseSrc::negotiate()
1285 -   audio: channel-mix: Fix channel count limit to be able to equal 64
1286 -   gldisplay: Mark gst_gl_display_create_context() other_context
1287     parameter as nullable
1288 -   gldisplay: Remove unused code
1289 -   gstglwindow_x11.c: Fix colormap leak
1290 -   gl/cocoa: Return a strong ref to the parent GstGLContext
1291 -   rtspconnection: Annotate RTSP message and RTSP events parameters
1292     correctly
1293 -   sdp, typefind: Fix some annotations
1294 -   sdp: gstmikey: gst_mikey_message_to_caps: extract ROC from first
1295     crypto session
1296 -   subparse: Properly forward segment seqnum
1297 -   uridecodebin: Set source element to READY before querying it
1298 -   uritranscodebin: Fix unref of NULL
1299 -   gst-play-1.0: Don’t force accurate seeking
1300
1301 gst-plugins-good
1302
1303 -   adaptivedemux2: Fix buffering threshold initialization
1304 -   dashdemux2: the seek operation takes a log time to finish for some
1305     streams
1306 -   glvideomixer: Keep a reference to the underlying pad
1307 -   qtdemux: Don’t emit GstSegment correcting start time when in MSE
1308     mode
1309 -   qtdemux: Handle moov atom length=0 case by reading until the end
1310 -   qtdemux, qtmux: Drop av1C version 0 parsing and implement version 1
1311     parsing/writing
1312 -   qtmux: Fix assertion on caps update
1313 -   redenc: fix setting of extension ID for twcc
1314 -   rtspsrc: Use the correct vfunc for the push-backchannel-sample
1315     action signal
1316 -   rtpssrcdemux: set different stream-id on each src pad
1317 -   udpsrc: GstSocketTimestampMessage only for SCM_TIMESTAMPNS
1318 -   v4l2h264dec: Fix Raspberry Pi4 will not play video in application
1319
1320 gst-plugins-bad
1321
1322 -   aom: Include stream-format and alignment in the AV1 caps
1323 -   av1parser, h265parser: Fix some code defects
1324 -   av1parser: Don’t consider unknown metadata OBUs a bitstream error
1325 -   avfvideosrc: Don’t wait on main thread for permissions request
1326 -   ccconverter: don’t debug a potentially freed filter caps
1327 -   codectimestamper: Fix timestamping on sequence update
1328 -   codecparsers: {h264, h265}bitwriter: Remove redundant condition
1329     checks
1330 -   codecs: decoders: fail early if no input caps have been provided for
1331     all new decoder base classes
1332 -   closedcaption: Don’t leak caps event
1333 -   curlhttpsrc: Add curl anyauth option
1334 -   d3d11overlaycompositor: fix texture width and height
1335 -   d3d11videosink: Fix rendering on external handle
1336 -   h265parse: Always set profile on src caps
1337 -   msdkav1enc: fix the category for msdkav1enc debug
1338 -   nvcodec: improve error reporting on plugin init
1339 -   nvencoder: Fix b-frame encoding on Linux
1340 -   nvencoder: Fix min buffers parameter of allocation query in auto GPU
1341     mode
1342 -   nvvp9dec: Fix return value
1343 -   qsvav1enc, amfav1enc: Set stream-format on caps
1344 -   vtdec: Jittery playback of H.264 Level 4.1 movies in macOS (both
1345     x86_64 and arm64)
1346 -   vtdec: Fix DPB size calculations not taking values from SPS into
1347     account
1348 -   vtdec: Fix not waiting for async frames when flushing
1349 -   vtenc: Disable ARGB/RGBA64 caps on M1 Pro/Max with macOS <13
1350 -   vtenc: Fix checking for certain CPU variants when running in VMs
1351 -   vtenc: Disable HW acceleration for interlaced ProRes
1352 -   va: Avoid the array index overflow when filling 8x8 scaling list.
1353 -   va: Fix some code defects
1354 -   vah265enc: Use helper to update properties.
1355 -   vulkan: memory: Flush non coherent memory after write.
1356 -   wasapi2src: Fix loopback capture on Windows 10 Anniversary Update
1357 -   webrtcbin: small stats improvements
1358 -   win32ipcutils: Add missing include
1359 -   wpe: Logging fixes for the WebExtension
1360
1361 gst-plugins-ugly
1362
1363 -   mpegpsdemux: Ignore DTS if PTS < DTS
1364
1365 gst-libav
1366
1367 -   avauddec, avviddec: Free packet side data after usage
1368 -   avviddec: change
1369     AV_CODEC_CAP_AUTO_THREADS->AV_CODEC_CAP_OTHER_THREADS to fix build
1370     against newer ffmpeg versions
1371 -   Memory leak in ’ av_packet_add_side_data’ in
1372     /lib/x86_64-linux-gnu/libavcodec.so reading the file
1373     clock_odd_size_RLE_g1597902.avi
1374 -   avvidenc: Don’t take ffmpeg timestamps verbatim but only use them to
1375     calculate DTS
1376
1377 gst-rtsp-server
1378
1379 -   No changes
1380
1381 gstreamer-vaapi
1382
1383 -   vaapi: Skip plugin pc file for shared plugins
1384
1385 gstreamer-sharp
1386
1387 -   No changes
1388
1389 gst-omx
1390
1391 -   No changes
1392
1393 gst-python
1394
1395 -   gst-python: Use arch-specific install dir for gi overrides
1396
1397 gst-editing-services
1398
1399 -   No changes
1400
1401 gst-validate + gst-integration-testsuites
1402
1403 -   validate:scenario: sink refs when building
1404 -   tests: Fix known issue definition location for unit tests and how we
1405     handle them in validate launcher
1406 -   tests: mark elements_srtp.test_play test as flaky
1407 -   Fix gstreamer-validate-1.0 dependency name
1408 -   validate-scenario: fix g-i warning in annotation
1409 -   validate: Fix gst_validate_execute_action annotation
1410
1411 gst-examples
1412
1413 -   webrtc examples: Use webrtc.gstreamer.net
1414 -   webrtc_sendrecv.py: Various fixes
1415
1416 Development build environment
1417
1418 -   gst-env: Handle installing python modules to dist-packages
1419 -   meson: Allow sysdeps to be forced as fallback subprojects
1420 -   meson: Switch dav1d wrap to a tarball and update to dav1d 1.1.0
1421
1422 Cerbero build tool and packaging changes in 1.22.1
1423
1424 -   macos: Fix broken binaries on macos < 11.0
1425 -   orc: Update pthread_jit_write_protect fix for macOS/iOS
1426 -   dav1d: Update to 1.1.0
1427 -   libsrtp: update to v2.5.0
1428 -   rustup: Update to 1.25.2
1429 -   rust: Update to 1.67; cargo-c to 0.9.16
1430 -   cerbero: Don’t error out if bindir already exists
1431 -   Fix setuptools site.py breakage in Python 3.11, bump
1432     gobject-introspection, bump windows image
1433 -   cerbero: Retry if cargo update fails on macOS
1434 -   gst-plugins-rs: Build glib/gio bindings with 2.74 API support
1435
1436 Contributors to 1.22.1
1437
1438 Alessandro Bono, Arun Raghavan, Bart Van Severen, Carlos Falgueras
1439 García, Célestin Marot, David Svensson Fors, Edward Hervey, Enrique
1440 Ocaña González, Frank Dana, Guillaume Desmottes, He Junyan, James
1441 Hilliard, Jan Alexander Steffens (heftig), Jan Schmidt, Jordan Petridis,
1442 Mathieu Duponchelle, Matthew Waters, medithe, Mengkejiergeli Ba, Nicolas
1443 Beland, Nirbheek Chauhan, Patricia Muscalu, Pawel Stawicki, Philippe
1444 Normand, Piotr Brzeziński, Rajneesh Soni, Robert Rosengren, Sanchayan
1445 Maity, Sebastian Dröge, Seungha Yang, Simon Himmelbauer, Thibault
1446 Saunier, Tim-Philipp Müller, Tristan van Berkom, U. Artie Eoff, Víctor
1447 Manuel Jáquez Leal, Vivia Nikolaidou, Xuchen Yang, Yinhang Liu,
1448
1449 … and many others who have contributed bug reports, translations, sent
1450 suggestions or helped testing. Thank you all!
1451
1452 List of merge requests and issues fixed in 1.22.1
1453
1454 -   List of Merge Requests applied in 1.22.1
1455 -   List of Issues fixed in 1.22.1
1456
1457 1.22.2
1458
1459 The second 1.22 bug-fix release (1.22.2) was released on 11 April 2023.
1460
1461 This release only contains bugfixes and it should be safe to update from
1462 1.22.x.
1463
1464 Highlighted bugfixes in 1.22.2
1465
1466 -   avdec_h264: fix decoder deadlocks with FFmpeg 6.0
1467 -   rtspsrc: fix regression with URI protocols in OPTIONS requests for
1468     RTSP over TLS
1469 -   rtspsrc: improved control url handling compatibility for broken
1470     servers
1471 -   decklink: fix 10 bit RGB (r210) format auto detection for capture
1472     and fix playout if video caps are configured before audio caps
1473 -   d3d11videosink: Fix tearing in case of fullscreen mode
1474 -   playbin: fix deadlock when stopping stream with subtitles visible
1475     (even more)
1476 -   typefinding: fix regression not detecting application/dash+xml in
1477     some corner cases
1478 -   osxvideosink: fix broken aspect ratio and frame drawing region
1479 -   decodebin3, parsebin: Improve elementary stream handling when
1480     decoders are not present and fix hang when removing a failing stream
1481 -   urisourcebin: Propagate sticky events from parsebin, so that the
1482     STREAM_START event with the GstStream info is always available when
1483     pads get exposed
1484 -   v4l2: Add support for YVU420M format; mark JPEG content as parsed
1485 -   h264decoder, h265decoder: DPB bumping process and latency reporting
1486     fixes
1487 -   Opus: Fix reading of extended channel config in MPEG-TS and fix
1488     missing sample rate when remuxing from RTP to Matroska
1489 -   zxing: add support for building against zxing-c++ 2.0
1490 -   cerbero: Fix packaging of Rust plugins on Android; fix modern Gentoo
1491     distro detection
1492 -   various bug fixes, memory leak fixes, and other stability and
1493     reliability improvements
1494
1495 gstreamer
1496
1497 -   datetime: Return G_MAXFLOAT instead of G_MAXDOUBLE for no timezone
1498     offset
1499 -   inputselector: Wake up streaming thread before PLAYING_TO_PAUSED
1500     transition
1501 -   tools: fix potential crash when passing command-line options on
1502     Windows
1503
1504 gst-plugins-base
1505
1506 -   alsasink: Fix for being stuck in stop_streaming_threads state
1507 -   decodebin3: fix hang when removing a failing stream
1508 -   gl: wayland: cleanup on close
1509 -   parsebin: Improve elementary stream handling
1510 -   playbin: fix deadlock when stopping stream with subtitles visible
1511     even more
1512 -   sdp: Skip source-specific caps fields when creating an SDP media
1513     from caps
1514 -   urisourcebin: Propagate sticky events from parsebin
1515 -   urisourcebin: Activate pad before transferring sticky events
1516 -   typefinding: fix failure to recognize application/dash+xml in some
1517     cases
1518
1519 gst-plugins-good
1520
1521 -   osxvideosink: fix broken aspect ratio and frame drawing region
1522 -   qtdemux: Fix seek adjustment with SNAP_AFTER flag
1523 -   rtpopusdepay, matroskamux: Fix invalid rate while muxing Opus in
1524     Matroska
1525 -   rtpmanager: twcc: Fix duplicate packet handling
1526 -   rtsp: url: fix incorrect request URI scheme for TLS transport
1527     methods (regression)
1528 -   rtspsrc: Consider “451: Parameter Not Understood” when handling
1529     broken control urls
1530 -   rtspsrc: fix behavior change with URI protocols in OPTIONS requests
1531 -   rtspsrc: Skip PTs with caps incompatible to the global caps
1532 -   rtpjpegdepay: fix logic error when checking if an end of image (EOI)
1533     tag is present
1534 -   v4l2: Add support for YVU420M format
1535 -   v4l2: mark JPEG as parsed
1536
1537 gst-plugins-bad
1538
1539 -   cea708overlay: fix HCR interpretation
1540 -   d3d11bufferpool: Fix invalid access in debug print loop
1541 -   d3d11compositor: Fix composition error on release_pad()
1542 -   d3d11converter: Fix conversion backend selection
1543 -   d3d11videosink: Fix tearing in case of fullscreen mode -
1544     d3d11bufferpool: Fix invalid access in debug print loop
1545 -   d3d11window: fix memory leak
1546 -   decklink: fix 10 bit RGB (r210) format auto detection
1547 -   decklinkaudiosink: Fix playback when video caps is configured before
1548     audio
1549 -   decklinkvideosrc: RGB 4:4:4 doesn’t work after GStreamer upgrade
1550     (regression)
1551 -   decklinkvideosrc: unable to show HDMI stream that Blackmagic’s Media
1552     Express is able to see
1553 -   debugqroverlay: fix string leak
1554 -   gtkwaylandsink: Destroy GstWlWindow when parent GtkWindow is
1555     destroyed
1556 -   gtkwaylandsink: Fix crash when rendering after the window is closed
1557 -   ksvideo, directshow: Fix reference leaks in device providers
1558 -   h264decoder: Fix DPB bumping process
1559 -   h264decoder, h265decoder: Latency reporting related fixes
1560 -   h264parse: Validate VUI framerate
1561 -   jpegparse: reset parse state when the SOI is not the first marker
1562 -   nvencoder: Fix CQP option setting
1563 -   nvh264encoder: Fix template caps to include progressive mode as well
1564 -   openjpegdec: allow multithread decoding only in subframe mode
1565 -   tsdemux: Fix reading of extended Opus channel configuration
1566 -   vulkan: fix validation layer issues
1567 -   vulkanoverlaycompositor: fix potential use after free
1568 -   vulkanswapper: correctly handle force-aspect-ratio=false
1569 -   wasapi2: Fix potential crash on device activation failure
1570 -   webrtc: Fix segfault traversing ice transports
1571 -   webrtc: patch leak caused by early return
1572 -   zxing: add support for zxing-c++ 2.0
1573
1574 gst-plugins-ugly
1575
1576 -   No changes
1577
1578 gst-libav
1579
1580 -   avdec_h264 pipeline freeze with FFmpeg6
1581 -   avdeinterlace, avmux: fix element reference leak
1582 -   avviddec: Drop decoder stream lock when calling send_packet
1583
1584 gst-rtsp-server
1585
1586 -   rtsp-server: fix deadlock on shutdown with non-live pipeline if
1587     media isn’t playing/prerolled yet and eos-shutdown is enabled for
1588     the media
1589
1590 gstreamer-vaapi
1591
1592 -   No changes
1593
1594 gstreamer-sharp
1595
1596 -   No changes
1597
1598 gst-omx
1599
1600 -   No changes
1601
1602 gst-python
1603
1604 -   No changes
1605
1606 gst-editing-services
1607
1608 -   No changes
1609
1610 gst-validate + gst-integration-testsuites
1611
1612 -   No changes
1613
1614 gst-examples
1615
1616 -   No changes
1617
1618 Development build environment
1619
1620 -   git: prevent CRLF line ending conversion for patches to fix pango
1621     subproject patching issues on Windows
1622
1623 Cerbero build tool and packaging changes in 1.22.2
1624
1625 -   build: retry rust build on SIGBUS errors too
1626 -   Fix packaging of rust plugins on Android
1627 -   Modern Gentoo distro adaptation
1628 -   sbc: update to 2.0
1629 -   speex: update to 1.2.1
1630
1631 Contributors to 1.22.2
1632
1633 Adrien De Coninck, Albert Sjölund, Alexande B, Antonio Rojas, Arun
1634 Raghavan, Bart Van Severen, Carlo Cabrera, Colin Kinloch, Edward Hervey,
1635 Guillaume Desmottes, Haihua Hu, He Junyan, Ilie Halip, Jordan Petridis,
1636 Josef Kolář, Lily Foster, Mathieu Duponchelle, Matt Feury, Matthew
1637 Waters, Maxim P. Dementyev, Michael Tretter, Nicolas Dufresne, Nirbheek
1638 Chauhan, Piotr Brzeziński, Robert Rosengren, Rouven Czerwinski,
1639 Sebastian Dröge, Seungha Yang, Shengqi Yu, Stéphane Cerveau, Talha Khan,
1640 Thibault Saunier, Tim-Philipp Müller, Víctor Manuel Jáquez Leal, Vivia
1641 Nikolaidou, Wang Chuan, Wojciech Kapsa,
1642
1643 … and many others who have contributed bug reports, translations, sent
1644 suggestions or helped testing. Thank you all!
1645
1646 List of merge requests and issues fixed in 1.22.2
1647
1648 -   List of Merge Requests applied in 1.22.2
1649 -   List of Issues fixed in 1.22.2
1650
1651 Schedule for 1.24
1652
1653 Our next major feature release will be 1.24, and 1.23 will be the
1654 unstable development version leading up to the stable 1.24 release. The
1655 development of 1.23/1.24 will happen in the git main branch of the
1656 GStreamer mono repository.
1657
1658 The plan for the 1.24 development cycle is yet to be confirmed.
1659
1660 1.24 will be backwards-compatible to the stable 1.22, 1.20, 1.18, 1.16,
1661 1.14, 1.12, 1.10, 1.8, 1.6, 1.4, 1.2 and 1.0 release series.
1662
1663 ------------------------------------------------------------------------
1664
1665 These release notes have been prepared by Tim-Philipp Müller with
1666 contributions from Edward Hervey, Matthew Waters, Nicolas Dufresne,
1667 Nirbheek Chauhan, Olivier Crête, Sebastian Dröge, Seungha Yang, and
1668 Thibault Saunier.
1669
1670 License: CC BY-SA 4.0