mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-12-31 20:48:56 +00:00
1239 lines
50 KiB
Text
1239 lines
50 KiB
Text
GStreamer 1.22 Release Notes
|
||
|
||
GStreamer 1.22.0 was originally released on 23 January 2023.
|
||
|
||
See https://gstreamer.freedesktop.org/releases/1.22/ for the latest
|
||
version of this document.
|
||
|
||
Last updated: Monday 23 January 2023, 17:00 UTC (log)
|
||
|
||
Introduction
|
||
|
||
The GStreamer team is proud to announce a new major feature release in
|
||
the stable 1.x API series of your favourite cross-platform multimedia
|
||
framework!
|
||
|
||
As always, this release is again packed with many new features, bug
|
||
fixes and other improvements.
|
||
|
||
Highlights
|
||
|
||
- AV1 video codec support improvements
|
||
- New HLS, DASH and Microsoft Smooth Streaming adaptive streaming
|
||
clients
|
||
- Qt6 support for rendering video inside a QML scene
|
||
- Minimal builds optimised for binary size, including only the
|
||
individual elements needed
|
||
- Playbin3, Decodebin3, UriDecodebin3, Parsebin enhancements and
|
||
stabilisation
|
||
- WebRTC simulcast support and support for Google Congestion Control
|
||
- WebRTC-based media server ingestion/egress (WHIP/WHEP) support
|
||
- New easy to use batteries-included WebRTC sender plugin
|
||
- Easy RTP sender timestamp reconstruction for RTP and RTSP
|
||
- ONVIF timed metadata support
|
||
- New fragmented MP4 muxer and non-fragmented MP4 muxer
|
||
- New plugins for Amazon AWS storage and audio transcription services
|
||
- New gtk4paintablesink and gtkwaylandsink renderers
|
||
- New videocolorscale element that can convert and scale in one go for
|
||
better performance
|
||
- High bit-depth video improvements
|
||
- Touchscreen event support in navigation API
|
||
- Rust plugins now shipped in macOS and Windows/MSVC binary packages
|
||
- H.264/H.265 timestamp correction elements for PTS/DTS reconstruction
|
||
before muxers
|
||
- Improved design for DMA buffer sharing and modifier handling for
|
||
hardware-accelerated video decoders/encoders/filters and
|
||
capturing/rendering on Linux
|
||
- Video4Linux2 hardware accelerated decoder improvements
|
||
- CUDA integration and Direct3D11 integration and plugin improvements
|
||
- New H.264 / AVC, H.265 / HEVC and AV1 hardware-accelerated video
|
||
encoders for AMD GPUs using the Advanced Media Framework (AMF) SDK
|
||
- applemedia: H.265 / HEVC video encoding + decoding support
|
||
- androidmedia: H.265 / HEVC video encoding support
|
||
- New “force-live” property for audiomixer, compositor, glvideomixer,
|
||
d3d11compositor etc.
|
||
- Lots of new plugins, features, performance improvements and bug
|
||
fixes
|
||
|
||
Major new features and changes
|
||
|
||
AV1 video codec support improvements
|
||
|
||
AV1 is a royalty free next-generation video codec by AOMedia and a free
|
||
alternative to H.265/HEVC.
|
||
|
||
While supported in earlier versions of GStreamer already, this release
|
||
saw a lot of improvements across the board:
|
||
|
||
- Support for hardware encoding and decoding via VAAPI/VA, AMF, D3D11,
|
||
NVCODEC, QSV and Intel MediaSDK. Hardware codecs for AV1 are slowly
|
||
becoming available in embedded systems and desktop GPUs (AMD, Intel,
|
||
NVIDIA), and these can now be used via GStreamer.
|
||
|
||
- New AV1 RTP payloader and depayloader elements.
|
||
|
||
- New encoder settings in the AOM reference encoder-based av1enc
|
||
element.
|
||
|
||
- Various improvements in the AV1 parser and in the MP4/Matroska/WebM
|
||
muxers/demuxers.
|
||
|
||
- dav1d and rav1e based software decoder/encoder elements shipped as
|
||
part of the binaries.
|
||
|
||
- AV1 parser improvements and various bugfixes all over the place.
|
||
|
||
Touchscreen event support in Navigation API
|
||
|
||
The Navigation API supports the sending of key press events and mouse
|
||
events through a GStreamer pipeline. Typically these will be picked up
|
||
by a video sink on which these events happen and then the event is
|
||
transmitted into the pipeline so it can be handled by elements inside
|
||
the pipeline if it wasn’t handled by the application.
|
||
|
||
This has traditionally been used for DVD menu support, but can also be
|
||
used to forward such inputs to source elements that render a web page
|
||
using a browser engine such as WebKit or Chromium.
|
||
|
||
This API has now gained support for touchscreen events, and this has
|
||
been implemented in various plugins such as the GTK, Qt, XV, and x11
|
||
video sinks as well as the wpevideosrc element.
|
||
|
||
GStreamer CUDA integration
|
||
|
||
- New gst-cuda library
|
||
- integration with D3D11 and NVIDIA dGPU NVMM elements
|
||
- new cudaconvertscale element
|
||
|
||
GStreamer Direct3D11 integration
|
||
|
||
- New gst-d3d11 public library
|
||
- gst-d3d11 library is not integrated with GStreamer documentation
|
||
system yet. Please refer to the examples
|
||
- d3d11screencapture: Add Windows Graphics Capture API based capture
|
||
mode, including Win32 application window capturing
|
||
- d3d11videosink and d3d11convert can support flip/rotation and crop
|
||
meta
|
||
- d3d11videosink: New emit-present property and present signal so that
|
||
applications can overlay an image on Direct3D11 swapchain’s
|
||
backbuffer via Direct3D/Direct2D APIs. See also C++ and Rust
|
||
examples
|
||
- d3d11compositor supports YUV blending/composing without intermediate
|
||
RGB(A) conversion to improve performance
|
||
- Direct3D11 video decoders are promoted to GST_RANK_PRIMARY or
|
||
higher, except for the MPEG2 decoder
|
||
|
||
H.264/H.265 timestamp correction elements
|
||
|
||
- Muxers are often picky and need proper PTS/DTS timestamps set on the
|
||
input buffers, but that can be a problem if the encoded input media
|
||
stream comes from a source that doesn’t provide proper signalling of
|
||
DTS, such as is often the case for RTP, RTSP and WebRTC streams or
|
||
Matroska container files. Theoretically parsers should be able to
|
||
fix this up, but it would probably require fairly invasive changes
|
||
in the parsers, so two new elements h264timestamper and
|
||
h265timestamper bridge the gap in the meantime and can reconstruct
|
||
missing PTS/DTS.
|
||
|
||
Easy sender timestamp reconstruction for RTP and RTSP
|
||
|
||
- it was always possible to reconstruct and retrieve the original RTP
|
||
sender timestamps in GStreamer, but required a fair bit of
|
||
understanding of the internal mechanisms and the right property
|
||
configuration and clock setup.
|
||
|
||
- rtspsrc and rtpjitterbuffer gained a new
|
||
“add-reference-timestamp-meta” property that if set puts the
|
||
original absolute reconstructed sender timestamps on the output
|
||
buffers via a meta. This is particularly useful if the sender is
|
||
synced to an NTP clock or PTP clock. The original sender timestamps
|
||
are either based on the RTCP NTP times, NTP RTP header extensions
|
||
(RFC6051) or RFC7273-style clock signalling.
|
||
|
||
Qt6 support
|
||
|
||
- new qml6glsink element for Qt6 similar to the existing Qt5 element.
|
||
Matching source and overlay elements will hopefully follow in the
|
||
near future.
|
||
|
||
OpenGL + Video library enhancements
|
||
|
||
- Support for new video formats (NV12_4L4, NV12_16L32S, NV12_8L128,
|
||
NV12_10BE_8L128) and dmabuf import in more formats (Y410, Y212_LE,
|
||
Y212_BE, Y210, NV21, NV61)
|
||
|
||
- Improved support for tiled formats with arbitrary tile dimensions,
|
||
as needed by certain hardware decoders/encoders
|
||
|
||
- glvideomixer: New “crop-left,”crop-right, “crop-top” and
|
||
“crop-bottom” pad properties for cropping inputs
|
||
|
||
- OpenGL support for gst_video_sample_convert():
|
||
|
||
- Used for video snapshotting and thumbnailing, to convert buffers
|
||
retrieved from appsinks or sink “last-sample” properties in
|
||
JPG/PNG thumbnails.
|
||
- This function can now take samples and buffers backed by GL
|
||
textures as input and will automatically plug a gldownload
|
||
element in that case.
|
||
|
||
High bit-depth support (10, 12, 16 bits per component value) improvements
|
||
|
||
- compositor can now handle any supported input format and also mix
|
||
high-bitdepth (10-16 bit) formats (naively)
|
||
|
||
- videoflip has gained support for higher bit depth formats.
|
||
|
||
- vp9enc, vp9dec now support 12-bit formats and also 10-bit 4:4:4
|
||
|
||
WebRTC
|
||
|
||
- Allow insertion of bandwidth estimation elements e.g. for Google
|
||
Congestion Control (GCC) support
|
||
|
||
- Initial support for sending or receiving simulcast streams
|
||
|
||
- Support for asynchronous host resolution for STUN/TURN servers
|
||
|
||
- GstWebRTCICE was split into base classes and implementation to make
|
||
it possible to plug custom ICE implementations
|
||
|
||
- webrtcsink: batteries-included WebRTC sender (Rust)
|
||
|
||
- whipsink: WebRTC HTTP ingest (WHIP) to a MediaServer (Rust)
|
||
|
||
- whepsrc: WebRTC HTTP egress (WHEP) from a MediaServer (Rust)
|
||
|
||
- Many other improvements and bug fixes
|
||
|
||
New HLS, DASH and MSS adaptive streaming clients
|
||
|
||
A new set of “adaptive demuxers” to support HLS, DASH and MSS adaptive
|
||
streaming protocols has been added. They provide improved performance,
|
||
new features and better stream compatibility compared to the previous
|
||
elements. These new elements require a “streams-aware” pipeline such as
|
||
playbin3, uridecodebin3 or urisourcebin.
|
||
|
||
The previous elements’ design prevented implementing several use-cases
|
||
and fixing long-standing issues. The new elements were re-designed from
|
||
scratch to tackle those:
|
||
|
||
- Scheduling Only 3 threads are present, regardless of the number of
|
||
streams selected. One in charge of downloading fragments and
|
||
manifests, one in charge of outputting parsed data downstream, and
|
||
one in charge of scheduling. This improves performance, resource
|
||
usage and latency.
|
||
|
||
- Better download control The elements now directly control the
|
||
scheduling and download of manifests and fragments using libsoup
|
||
directly instead of depending on external elements for downloading.
|
||
|
||
- Stream selection, only the selected streams are downloaded. This
|
||
improves bandwith usage. Switching stream is done in such a way to
|
||
ensure there are no gaps, meaning the new stream will be switched to
|
||
only once enough data for it has been downloaded.
|
||
|
||
- Internal parsing, the downloaded streams are parsed internally. This
|
||
allows the element to fully respect the various specifications and
|
||
offer accurate buffering, seeking and playback. This is especially
|
||
important for HLS streams which require parsing for proper
|
||
positioning of streams.
|
||
|
||
- Buffering and adaptive rate switching, the new elements handle
|
||
buffering internally which allows them to have a more accurate
|
||
visibility of which bandwith variant to switch to.
|
||
|
||
Playbin3, Decodebin3, UriDecodebin3, Parsebin improvements
|
||
|
||
The “new” playback elements introduced in 1.18 (playbin3 and its various
|
||
components) have been refactored to allow more use-cases and improve
|
||
performance. They are no longer considered experimental, so applications
|
||
using the legacy playback elements (playbin and (uri)decodebin) can
|
||
migrate to the new components to benefit from these improvements.
|
||
|
||
- Gapless The “gapless” feature allows files and streams to be
|
||
fetched, buffered and decoded in order to provide a “gapless”
|
||
output. This feature has been refactored extensively in the new
|
||
components:
|
||
- A single (uri)decodebin3 (and therefore a single set of
|
||
decoders) is used. This improves memory and cpu usage, since on
|
||
identical codecs a single decoder will be used.
|
||
- The “next” stream to play will be pre-rolled “just-in-time”
|
||
thanks to the buffering improvements in urisourcebin (see below)
|
||
- This feature is now handled at the uridecodebin3 level.
|
||
Applications that wish to have a “gapless” stream and process it
|
||
(instead of just outputting it, for example for transcoding,
|
||
retransmission, …) can now use uridecodebin3 directly. Note that
|
||
a streamsynchronizer element is required in that case.
|
||
- Buffering improvements The urisourcebin element is in charge of
|
||
fetching and (optionally) buffering/downloading the stream. It has
|
||
been extended and improved:
|
||
- When the parse-streams property is used (by default in
|
||
uridecodebin3 and playbin3), compatible streams will be demuxed
|
||
and parsed (via parsebin) and buffering will be done on the
|
||
elementary streams. This provides a more accurate handling of
|
||
buffering. Previously buffering was done on a best-effort basis
|
||
and was mostly wrong (i.e. downloading more than needed).
|
||
- Applications can use urisourcebin with this property as a
|
||
convenient way of getting elementary streams from a given URI.
|
||
- Elements can handle buffering themselves (such as the new
|
||
adaptive demuxers) by answering the GST_QUERY_BUFFERING query.
|
||
In that case urisourcebin will not handle it.
|
||
- Stream Selection Efficient stream selection was previously only
|
||
possible within decodebin3. The downside is that this meant that
|
||
upstream elements had to provide all the streams from which to chose
|
||
from, which is inefficient. With the addition of the
|
||
GST_QUERY_SELECTABLE query, this can now be handled by elements
|
||
upstream (i.e. sources)
|
||
- Elements that can handle stream selection internally (such as
|
||
the new adaptive demuxer elements) answer that query, and handle
|
||
the stream selection events themselves.
|
||
- In this case, decodebin3 will always process all streams that
|
||
are provided to it.
|
||
- Instant URI switching This new feature allows switching URIs
|
||
“instantly” in playbin3 (and uridecodebin3) without having to change
|
||
states. This mimics switching channels on a television.
|
||
- If compatible, decoders will be re-used, providing lower
|
||
latency/cpu/memory than by switching states.
|
||
- This is enabled by setting the instant-uri property to true,
|
||
setting the URI to switch to immediately, and then disabling the
|
||
instant-uri property again afterwards.
|
||
- playbin3, decodebin3, uridecodebin3, parsebin, and urisrc are no
|
||
longer experimental
|
||
- They were originally marked as ‘technology preview’ but have
|
||
since seen extensive usage in production settings, so are
|
||
considered ready for general use now.
|
||
|
||
Fraunhofer AAC audio encoder HE-AAC and AAC-LD profile support
|
||
|
||
- fdkaacenc:
|
||
- Support for encoding to HE-AACv1 and HE-AACv2 profile
|
||
- Support for encoding to AAC Low Delay (LD) profile
|
||
- Advanced bitrate control options via new “rate-control”,
|
||
“vbr-preset”, “peak-bitrate”, and “afterburner” properties
|
||
|
||
RTP rapid synchronization support in the RTP stack (RFC6051)
|
||
|
||
RTP provides several mechanisms how streams can be synchronized relative
|
||
to each other, and how absolute sender times for RTP packets can be
|
||
obtained. One of these mechanisms is via RTCP, which has the
|
||
disadvantage that the synchronization information is only distributed
|
||
out-of-band and usually some time after the start.
|
||
|
||
GStreamer’s RTP stack, specifically the rtpbin, rtpsession and
|
||
rtpjitterbuffer elements, now also have support for retrieving and
|
||
sending the same synchronization information in-band via RTP header
|
||
extensions according to RFC6051 (Rapid Synchronisation of RTP Flows).
|
||
Only 64-bit timestamps are supported currently.
|
||
|
||
This provides per packet synchronization information from the very
|
||
beginning of a stream and allows accurate inter-stream, and (depending
|
||
on setup) inter-device, synchronization at the receiver side.
|
||
|
||
ONVIF XML Timed Metadata support
|
||
|
||
The ONVIF standard implemented by various security cameras also
|
||
specifies a format for timed metadata that is transmitted together with
|
||
the audio/video streams, usually over RTSP.
|
||
|
||
Support for this timed metadata is implemented in the MP4 demuxer now as
|
||
well as the new fragmented MP4 muxer and the new non-fragmented MP4
|
||
muxer from the GStreamer Rust plugins. Additionally, the new onvif
|
||
plugin ‒ which is part of the GStreamer Rust plugins ‒ provides general
|
||
elements for handling the metadata and e.g. overlaying certain parts of
|
||
it over a video stream.
|
||
|
||
As part of this support for absolute UTC times was also implemented
|
||
according to the requirements of the ONVIF standards in the
|
||
corresponding elements.
|
||
|
||
MP3 gapless playback support
|
||
|
||
While MP3 can probably considered a legacy format at this point, a new
|
||
feature was added with this release.
|
||
|
||
When playing back plain MP3 files, i.e. outside a container format,
|
||
switches between files can now be completely gapless if the required
|
||
metadata is provided inside the file. There is no standardized metadata
|
||
for this, but the LAME MP3 encoder writes metadata that can be parsed by
|
||
the mpegaudioparse element now and forwarded to decoders for ensuring
|
||
removal of padding samples at the front and end of MP3 files.
|
||
|
||
“force-live” property for audio + video aggregators
|
||
|
||
This is a quality of life fix for playout and streaming applications
|
||
where it is common to have audio and video mixer elements that should
|
||
operate in live mode from the start and produce output continuously.
|
||
|
||
Often one would start a pipeline without any inputs hooked up to these
|
||
mixers in the beginning, and up until now there was no way to easily
|
||
force these elements into live mode from the start. One would have to
|
||
add an initial live video or audio test source as dummy input to achieve
|
||
this.
|
||
|
||
The new “force-live” property makes these audio and video aggregators
|
||
start in live mode without the need for any dummy inputs, which is
|
||
useful for scenarios where inputs are only added after starting the
|
||
pipeline.
|
||
|
||
This new property should usually be used in connection with the
|
||
“min-upstream-latency” property, i.e. you should always set a non-0
|
||
minimum upstream latency then.
|
||
|
||
This is now supported in all GstAudioAggregator and GstVideoAggregator
|
||
subclasses such as audiomixer, audiointerleave, compositor,
|
||
glvideomixer, d3d11compositor, etc.
|
||
|
||
New elements and plugins
|
||
|
||
- new cudaconvertscale element that can convert and scale in one pass
|
||
|
||
- new gtkwaylandsink element based on gtksink, but similar to
|
||
waylandsink and uses Wayland APIs directly instead of rendering with
|
||
Gtk/Cairo primitives. This approach is only compatible with Gtk3,
|
||
and like gtksink this element only supports Gtk3.
|
||
|
||
- new h264timestamper and h265timestamper elements to reconstruct
|
||
missing pts/dts from inputs that might not provide them such as
|
||
e.g. RTP/RTSP/WebRTC inputs (see above)
|
||
|
||
- mfaacdec, mfmp3dec: Windows MediaFoundation AAC and MP3 decoders
|
||
|
||
- new msdkav1enc AV1 video encoder element
|
||
|
||
- new nvcudah264enc, nvcudah265enc, nvd3d11h264enc, and nvd3d11h265enc
|
||
NVIDIA GPU encoder elements to support zero-copy encoding, via CUDA
|
||
and Direct3D11 APIs, respectively
|
||
|
||
- new nvautogpuh264enc and nvautogpuh265enc NVIDIA GPU encoder
|
||
elements: The auto GPU elements will automatically select a target
|
||
GPU instance in case multiple NVIDIA desktop GPUs are present, also
|
||
taking into account the input memory. On Windows CUDA or Direct3D11
|
||
mode will be determined by the elements automatically as well. Those
|
||
new elements are useful if target GPU and/or API mode (either CUDA
|
||
or Direct3D11 in case of Windows) is undeterminable from the encoder
|
||
point of view at the time when pipeline is configured, and therefore
|
||
lazy target GPU and/or API selection are required in order to avoid
|
||
unnecessary memory copy operations.
|
||
|
||
- new nvav1dec AV1 NVIDIA desktop GPU decoder element
|
||
|
||
- new qml6glsink element to render video with Qt6
|
||
|
||
- qsv: New Intel OneVPL/MediaSDK (a.k.a Intel Quick Sync) based
|
||
decoder and encoder elements, with gst-d3d11 (on Windows) and gst-va
|
||
(on Linux) integration
|
||
|
||
- Support multi-GPU environment, for example, concurrent video
|
||
encoding using Intel iGPU and dGPU in a single pipeline
|
||
- H.264 / H.265 / VP9 and JPEG decoders
|
||
- H.264 / H.265 / VP9 / AV1 / JPEG encoders with dynamic encoding
|
||
bitrate update
|
||
- New plugin does not require external SDK for building on Windows
|
||
|
||
- vulkanoverlaycompositor: new vulkan overlay compositor element to
|
||
overlay upstream GstVideoOverlayCompositonMeta onto the video
|
||
stream.
|
||
|
||
- vulkanshaderspv: performs operations with SPIRV shaders in Vulkan
|
||
|
||
- win32ipcvideosink, win32ipcvideosrc: new shared memory videosrc/sink
|
||
elements for Windows
|
||
|
||
- wicjpegdec, wicpngdec: Windows Imaging Component (WIC) based JPEG
|
||
and PNG decoder elements.
|
||
|
||
- Many exciting new Rust elements, see Rust section below
|
||
|
||
New element features and additions
|
||
|
||
- audioconvert: Dithering now uses a slightly slower, less biased PRNG
|
||
which results in better quality output. Also dithering can now be
|
||
enabled via the new “dithering-threshold” property for target bit
|
||
depths of more than 20 bits.
|
||
|
||
- av1enc: Add “keyframe-max-dist” property for controlling max
|
||
distance between keyframes, as well as “enc-pass”, “keyframe-mode”,
|
||
“lag-in-frames” and “usage-profile” properties.
|
||
|
||
- cccombiner: new “output-padding” property
|
||
|
||
- decklink: Add support for 4k DCI, 8k/UHD2 and 8k DCI modes
|
||
|
||
- dvbsubenc: Support for >SD resolutions is working correctly now.
|
||
|
||
- fdkaacenc: Add HE-AAC / HE-AACv2 profile support
|
||
|
||
- glvideomixer: New “crop-left,”crop-right, “crop-top” and
|
||
“crop-bottom” pad properties for cropping inputs
|
||
|
||
- gssink: new ‘content-type’ property. Useful when one wants to upload
|
||
a video as video/mp4 instead of ’video/quicktime` for example.
|
||
|
||
- jpegparse: Rewritten using the common parser library
|
||
|
||
- msdk:
|
||
|
||
- new msdkav1enc AV1 video encoder element
|
||
- msdk decoders: Add support for Scaler Format Converter (SFC) on
|
||
supported Intel platforms for hardware accelerated conversion
|
||
and scaling
|
||
- msdk encoders: support import of dmabuf, va memory and D3D11
|
||
memory
|
||
- msdk encoders: add properties for low delay bitrate control and
|
||
max frame sizes for I/P frames
|
||
- msdkh264enc, msdkh265enc: more properties to control intra
|
||
refresh
|
||
- note that on systems with multi GPUs the Windows D3D11
|
||
integration might only work reliably if the Intel GPU is the
|
||
primary GPU
|
||
|
||
- mxfdemux: Add support for Canon XF-HEVC
|
||
|
||
- openaptx: Support the freeaptx library
|
||
|
||
- qroverlay:
|
||
|
||
- new “qrcode-case-sensitive” property allows encoding case
|
||
sensitive strings like wifi SSIDs or passwords.
|
||
- added the ability to pick up data to render from an
|
||
upstream-provided custom GstQROverlay meta
|
||
|
||
- qtdemux: Add support for ONVIF XML Timed MetaData and AVC-Intra
|
||
video
|
||
|
||
- rfbsrc now supports the uri handler interface, so applications can
|
||
use RFB/VNC sources in uridecodebin(3) and playbin, with
|
||
e.g. rfb://:password@10.1.2.3:5903?shared=1
|
||
|
||
- rtponviftimestamp: Add support for using reference timestamps
|
||
|
||
- rtpvp9depay now has the same keyframe-related properties as
|
||
rtpvp8depay and rtph264depay: “request-keyframe” and
|
||
“wait-for-keyframe”
|
||
|
||
- rtspsrc: Various RTSP servers are using invalid URL operations for
|
||
constructing the control URL. Until GStreamer 1.16 these worked
|
||
correctly because GStreamer was just appending strings itself to
|
||
construct the control URL, but starting version 1.18 the correct URL
|
||
operations were used. With GStreamer 1.22, rtspsrc now first tries
|
||
with the correct control URL and if that fails it will retry with
|
||
the wrongly constructed control URL to restore support for such
|
||
servers.
|
||
|
||
- rtspsrc and rtpjitterbuffer gained a new
|
||
“add-reference-timestamp-meta” property that makes them put the
|
||
unmodified original sender timestamp on output buffers for NTP or
|
||
PTP clock synced senders
|
||
|
||
- srtsrc, srtsink: new “auto-reconnect” property to make it possible
|
||
to disable automatic reconnects (in caller mode) and make the
|
||
elements post an error immediately instead; also stats improvements
|
||
|
||
- srtsrc: new “keep-listening” property to avoid EOS on disconnect and
|
||
keep the source running while it waits for a new connection.
|
||
|
||
- videocodectestsink: added YUV 4:2:2 support
|
||
|
||
- wasapi2src: Add support for process loopback capture
|
||
|
||
- wpesrc: Add support for modifiers in key/touch/pointer events
|
||
|
||
Plugin and library moves
|
||
|
||
- The xingmux plugin has been moved from gst-plugins-ugly into
|
||
gst-plugins-good.
|
||
|
||
- The various Windows directshow plugins in gst-plugins-bad have been
|
||
unified into a single directshow plugin.
|
||
|
||
Plugin removals
|
||
|
||
- The dxgiscreencapsrc element has been removed, use
|
||
d3d11screencapturesrc instead
|
||
|
||
Miscellaneous API additions
|
||
|
||
- GST_AUDIO_FORMAT_INFO_IS_VALID_RAW() and
|
||
GST_VIDEO_FORMAT_INFO_IS_VALID_RAW() can be used to check if a
|
||
GstAudioFormatInfo or GstVideoFormatInfo has been initialised to a
|
||
valid raw format.
|
||
|
||
- Video SEI meta: new GstVideoSEIUserDataUnregisteredMeta to carry
|
||
H.264 and H.265 metadata from SEI User Data Unregistered messages.
|
||
|
||
- vulkan: Expose gst_vulkan_result_to_string()
|
||
|
||
Miscellaneous performance, latency and memory optimisations
|
||
|
||
- liborc 0.4.33 adds support for aarch64 (64-bit ARM) architecture
|
||
(not enabled by default on Windows yet though) and improvements for
|
||
32-bit ARM and should greatly enhance performance for certain
|
||
operations that use ORC.
|
||
|
||
- as always there have been plenty of performance, latency and memory
|
||
optimisations all over the place.
|
||
|
||
Miscellaneous other changes and enhancements
|
||
|
||
- the audio/video decoder base classes will not consider decoding
|
||
errors a hard error by default anymore but will continue trying to
|
||
decode. Previously more than 10 consecutive errors were considered a
|
||
hard error but this caused various partially broken streams to fail.
|
||
The threshold is configurable via the “max-errors” property.
|
||
|
||
- compatibility of the GStreamer PTP clock implementation with
|
||
different PTP server implementations was improved, and
|
||
synchronization is achieved successfully in various scenarios that
|
||
failed before.
|
||
|
||
Tracing framework and debugging improvements
|
||
|
||
New tracers
|
||
|
||
- buffer-lateness: Records lateness of buffers and the reported
|
||
latency for each pad in a CSV file. Comes with a script for
|
||
visualisation.
|
||
|
||
- pipeline-snapshot: Creates a .dot file of all pipelines in the
|
||
application whenever requested via SIGUSR1 (on UNIX systems)
|
||
|
||
- queue-levels: Records queue levels for each queue in a CSV file.
|
||
Comes with a script for visualisation.
|
||
|
||
Debug logging system improvements
|
||
|
||
- new log macros GST_LOG_ID, GST_DEBUG_ID, GST_INFO_ID,
|
||
GST_WARNING_ID, GST_ERROR_ID, and GST_TRACE_ID allow passing a
|
||
string identifier instead of a GObject. This makes it easier to log
|
||
non-gobject-based items and also has performance benefits.
|
||
|
||
Tools
|
||
|
||
- gst-play-1.0 gained a --no-position command line option to suppress
|
||
position/duration queries, which can be useful to reduce debug log
|
||
noise.
|
||
|
||
GStreamer FFMPEG wrapper
|
||
|
||
- Fixed bitrate management and timestamp inaccuracies for video
|
||
encoders
|
||
|
||
- Fix synchronization issues and errors created by the (wrong)
|
||
forwarding of upstream segment events by ffmpeg demuxers.
|
||
|
||
- Clipping meta support for gapless mp3 playback
|
||
|
||
GStreamer RTSP server
|
||
|
||
- Add RFC5576 Source-specific media attribute to the SDP media for
|
||
signalling the CNAME
|
||
|
||
- Add support for adjusting request response on pipeline errors
|
||
|
||
- Give the application the possibility to adjust the error code
|
||
when responding to a request. For that purpose the pipeline’s
|
||
bus messages are emitted to subscribers through a
|
||
“handle-message” signal. The subscribers can then check those
|
||
messages for errors and adjust the response error code by
|
||
overriding the virtual method
|
||
GstRTSPClientClass::adjust_error_code().
|
||
|
||
- Add gst_rtsp_context_set_token() method to make it possible to set
|
||
the RTSPToken on some RTSPContext from bindings such as the Python
|
||
bindings.
|
||
|
||
- rtspclientsink gained a “publish-clock-mode” property to configure
|
||
whether the pipeline clock should be published according to RFC7273
|
||
(RTP Clock Source Signalling), similar to the same API on
|
||
GstRTSPMedia.
|
||
|
||
GStreamer VA-API support
|
||
|
||
- Development activity has shifted towards the new va plugin, with
|
||
gstreamer-vaapi now basically in maintenance-only mode. Most of the
|
||
below refers to the va plugin (not gstreamer-vaapi).
|
||
|
||
- new gst-va library for GStreamer VA-API integration
|
||
|
||
- vajpegdec: new JPEG decoder
|
||
|
||
- vah264enc, vah265enc: new H.264/H.265 encoders
|
||
|
||
- vah264lpenc, vah265lpenc: new low power mode encoders
|
||
|
||
- vah265enc: Add extended formats support such as 10/12 bits, 4:2:2
|
||
and 4:4:4
|
||
|
||
- Support encoder reconfiguration
|
||
|
||
- vacompositor: Add new compositor element using the VA-API VPP
|
||
interface
|
||
|
||
- vapostproc:
|
||
|
||
- new “scale-method” property
|
||
- Process HDR caps if supported
|
||
- parse video orientation from tags
|
||
|
||
- vaapipostproc: Enable the use of DMA-Buf import and export
|
||
(gstreamer-vaapi)
|
||
|
||
GStreamer Video4Linux2 support
|
||
|
||
- Added support for Mediatek Stateless CODEC (VP8, H.264, VP9)
|
||
|
||
- Stateless H.264 interlaced decoder support
|
||
|
||
- Stateless H.265 decoder support
|
||
|
||
- Stateful decoder support for driver resolution change events
|
||
|
||
- Stateful decoding support fixes for NXP/Amphion driver
|
||
|
||
- Support for hardware crop in v4l2src
|
||
|
||
- Conformance test improvement for stateful decoders
|
||
|
||
- Fixes for Raspberry Pi CODEC
|
||
|
||
GStreamer OMX
|
||
|
||
- There were no changes in this module
|
||
|
||
GStreamer Editing Services and NLE
|
||
|
||
- Handle compositors that are bins around the actual compositor
|
||
implementation (like glvideomixers which wraps several elements)
|
||
|
||
- Add a mode to disable timeline editing API so the user can be in
|
||
full control of its layout (meaning that the user is responsible for
|
||
ensuring its validity/coherency)
|
||
|
||
- Add a new fade-in transition type
|
||
|
||
- Add support for non-1/1 PAR source videos
|
||
|
||
- Fix frame accuracy when working with very low framerate streams
|
||
|
||
GStreamer validate
|
||
|
||
- Clean up and stabilize API so we can now generate rust bindings
|
||
|
||
- Enhance the appsrc-push action type allowing to find tune the
|
||
buffers more in details
|
||
|
||
- Add an action type to verify currently configured pad caps
|
||
|
||
- Add a way to run checks from any thread after executing a ‘wait’
|
||
action. This is useful when waiting on a signal and want to check
|
||
the value of a property right when it is emited for example.
|
||
|
||
GStreamer Python Bindings
|
||
|
||
- Add a Gst.init_python() function to be called from plugins which
|
||
will initialise everything needed for the GStreamer Python bindings
|
||
but not call Gst.init() again since this will have been called
|
||
already.
|
||
|
||
- Add support for the GstURIHandlerInterface that allows elements to
|
||
advertise what URI protocols they support.
|
||
|
||
GStreamer C# Bindings
|
||
|
||
- Fix AppSrc and AppSink constructors
|
||
|
||
- The C# bindings have yet to be updated to include new 1.22 API,
|
||
which requires improvements in various places in the bindings /
|
||
binding generator stack. See issue #1718 in GitLab for more
|
||
information and to track progress.
|
||
|
||
GStreamer Rust Bindings and Rust Plugins
|
||
|
||
The GStreamer Rust bindings are released separately with a different
|
||
release cadence that’s tied to gtk-rs, but the latest release has
|
||
already been updated for the new GStreamer 1.22 API. Check the bindings
|
||
release notes for details of the changes since 0.18, which was released
|
||
around GStreamer 1.20.
|
||
|
||
gst-plugins-rs, the module containing GStreamer plugins written in Rust,
|
||
has also seen lots of activity with many new elements and plugins. A
|
||
list of all Rust plugins and elements provided with the 0.9 release can
|
||
be found in the repository.
|
||
|
||
- 33% of GStreamer commits are now in Rust (bindings + plugins), and
|
||
the Rust plugins module is also where most of the new plugins are
|
||
added these days.
|
||
|
||
- The Rust plugins are now shipped as part of the Windows MSVC + macOS
|
||
binary packages. See below for the list of shipped plugins and the
|
||
status of Rust support in cerbero.
|
||
|
||
- The Rust plugins are also part of the documentation on the GStreamer
|
||
website now.
|
||
|
||
- Rust plugins can be used from any programming language. To the
|
||
outside they look just like a plugin written in C or C++.
|
||
|
||
New Rust plugins and elements
|
||
|
||
- rtpav1pay / rtpav1depay: RTP (de)payloader for the AV1 video codec
|
||
- gtk4paintablesink: a GTK4 video sink that provides a GdkPaintable
|
||
for rendering a video in any place inside a GTK UI. Supports
|
||
zero-copy rendering via OpenGL on Linux and macOS.
|
||
- ndi: source, sink and device provider for NewTek NDI protocol
|
||
- onvif: Various elements for parsing, RTP (de)payloading, overlaying
|
||
of ONVIF timed metadata.
|
||
- livesync: Element for converting a live stream into a continuous
|
||
stream without gaps and timestamp jumps while preserving live
|
||
latency requirements.
|
||
- raptorq: Encoder/decoder elements for the RaptorQ FEC mechanism that
|
||
can be used for RTP streams (RFC6330).
|
||
|
||
WebRTC elements
|
||
|
||
- webrtcsink: a WebRTC sink (batteries included WebRTC sender with
|
||
specific signalling)
|
||
- whipsink: WebRTC HTTP ingest (WHIP) to MediaServer
|
||
- whepsrc: WebRTC HTTP egress (WHEP) from MediaServer
|
||
- rtpgccbwe: RTP bandwidth estimator based on the Google Congestion
|
||
Control algorithm (GCC), used by webrtcsink
|
||
|
||
Amazon AWS services
|
||
|
||
- awss3src / awss3sink: A source and sink element to talk to the
|
||
Amazon S3 object storage system.
|
||
- awss3hlssink: A sink element to store HLS streams on Amazon S3.
|
||
- awstranscriber: an element wrapping the AWS Transcriber service.
|
||
- awstranscribeparse: an element parsing the packets of the AWS
|
||
Transcriber service.
|
||
|
||
Video Effects (videofx)
|
||
|
||
- roundedcorners: Element to make the corners of a video rounded via
|
||
the alpha channel.
|
||
- colordetect: A pass-through filter able to detect the dominant
|
||
color(s) on incoming frames, using color-thief.
|
||
- videocompare: Compare similarity of video frames. The element can
|
||
use different hashing algorithms like Blockhash, DSSIM, and others.
|
||
|
||
New MP4 muxer + Fragmented MP4 muxer
|
||
|
||
- fmp4mux: New fragmented MP4/ISOBMFF/CMAF muxer for generating
|
||
e.g. DASH/HLS media fragments.
|
||
- isomp4mux: New non-fragmented, normal MP4 muxer.
|
||
|
||
Both plugins provides elements that replace the existing qtmux/mp4mux
|
||
element from gst-plugins-good. While not feature-equivalent yet, the new
|
||
codebase and using separate elements for the fragment and non-fragmented
|
||
case allows for easier extensability in the future.
|
||
|
||
Cerbero Rust support
|
||
|
||
- Starting this release, cerbero has support for building and shipping
|
||
Rust code on Linux, Windows (MSVC) and macOS. The Windows (MSVC) and
|
||
macOS binaries also ship the GStreamer Rust plugins in this release.
|
||
Only dynamic plugins are built and shipped currently.
|
||
|
||
- Preliminary support for Android, iOS and Windows (MinGW) exists but
|
||
more work is needed. Check the tracker issue for more details about
|
||
future work.
|
||
|
||
- The following plugins are included currently: audiofx, aws, cdg,
|
||
claxon, closedcaption, dav1d, fallbackswitch, ffv1, fmp4, gif,
|
||
hlssink3, hsv, json, livesync, lewton, mp4, ndi, onvif, rav1e,
|
||
regex, reqwest, raptorq, png, rtp, textahead, textwrap, threadshare,
|
||
togglerecord, tracers, uriplaylistbin, videofx, webrtc, webrtchttp.
|
||
|
||
Build and Dependencies
|
||
|
||
- meson 0.62 or newer is required
|
||
|
||
- GLib >= 2.62 is now required (but GLib >= 2.64 is strongly
|
||
recommended)
|
||
|
||
- libnice >= 0.1.21 is now required and contains important fixes for
|
||
GStreamer’s WebRTC stack.
|
||
|
||
- liborc >= 0.4.33 is recommended for 64-bit ARM support and 32-bit
|
||
ARM improvements
|
||
|
||
- onnx: OnnxRT >= 1.13.1 is now required
|
||
|
||
- openaptx: can now be built against libfreeaptx
|
||
|
||
- opencv: allow building against any 4.x version
|
||
|
||
- shout: libshout >= 2.4.3 is now required
|
||
|
||
- gstreamer-vaapi’s Meson build options have been switched from a
|
||
custom combo type (yes/no/auto) to the built-in Meson feature type
|
||
(enabled/disabled/auto)
|
||
|
||
- The GStreamer Rust plugins module gst-plugins-rs is now considered
|
||
an essential part of the GStreamer plugin offering and packagers and
|
||
distributors are strongly encouraged to package and ship those
|
||
plugins alongside the existing plugin modules.
|
||
|
||
- we now make use of Meson’s install tags feature which allows
|
||
selective installation of installl components and might be useful
|
||
for packagers.
|
||
|
||
Monorepo build (gst-build)
|
||
|
||
- new “orc-source” build option to allow build against a
|
||
system-installed liborc instead of forcing the use of orc as a
|
||
subproject.
|
||
|
||
- GStreamer command line tools can now be linked to the gstreamer-full
|
||
library if it’s built
|
||
|
||
Cerbero
|
||
|
||
Cerbero is a meta build system used to build GStreamer plus dependencies
|
||
on platforms where dependencies are not readily available, such as
|
||
Windows, Android, iOS, and macOS.
|
||
|
||
General improvements
|
||
|
||
- Rust support was added for all support configurations, controlled by
|
||
the rust variant; see above for more details
|
||
- All pkgconfig files are now reliably relocatable without requiring
|
||
pkg-config --define-prefix. This also fixes statically linking with
|
||
GStreamer plugins using the corresponding pkgconfig files.
|
||
- New documentation on how to build a custom GStreamer repository
|
||
using Cerbero, please see the README
|
||
- HTTPS certificate checking is enabled for downloads on all platforms
|
||
now
|
||
- Fetching now automatically retries on error for robustness against
|
||
transient errors
|
||
- Support for building the new Qt6 plugin was added
|
||
- pkgconfig files for various recipes were fixed
|
||
- Several recipes were updated to newer versions
|
||
- New plugins: adaptivedemux2 aes codectimestamper dav1d
|
||
- New libraries: cuda webrtcnice
|
||
|
||
macOS / iOS
|
||
|
||
- Added support for running Cerbero on ARM64 macOS
|
||
- GStreamer.framework and all libraries in it are now relocatable,
|
||
which means they use LC_RPATH entries to find dependencies instead
|
||
of using an absolute path. If you link to GStreamer using the
|
||
pkgconfig files, no action is necessary. However, if you use the
|
||
framework directly or link to the libraries inside the framework by
|
||
hand, then you need to pass -Wl,-rpath,<path_to_libdir> to the
|
||
linker.
|
||
- Apple bitcode support was dropped, since Apple has deprecated it
|
||
- macOS installer now correctly advertises support for both x86_64 and
|
||
arm64
|
||
- macOS framework now ships the gst-rtsp-server-1.0 library
|
||
- Various fixes were made to make static linking to gstreamer
|
||
libraries and plugins work correctly on macOS
|
||
- When statically linking to the applemedia plugin using Xcode 13, you
|
||
will need to pass -fno-objc-msgsend-selector-stubs which works
|
||
around a backwards-incompatible change in Xcode 14. This is not
|
||
required for the rest of GStreamer at present, but will be in the
|
||
future.
|
||
- macOS installer now shows the GStreamer logo correctly
|
||
|
||
Windows
|
||
|
||
- MSVC is now required by default on Windows, and the Visual Studio
|
||
variant is enabled by default
|
||
- To build with MinGW, use the mingw variant
|
||
- Visual Studio props files were updated for newer Visual Studio
|
||
versions
|
||
- Visual Studio 2015 support was dropped
|
||
- MSYS2 is now supported as the base instead of MSYS. Please see the
|
||
README for more details. Some advantages include:
|
||
- Faster build times, since parallel make works
|
||
- Faster bootstrap, since some tools are provided by MSYS2
|
||
- Other speed-ups due to using MSYS2 tools instead of MSYS
|
||
- Faster download by using powershell instead of hand-rolled Python
|
||
code
|
||
- Many recipes were ported from Autotools to Meson, speeding up the
|
||
build
|
||
- Universal Windows Platform is no longer supported, and binaries are
|
||
no longer shipped for it
|
||
- New documentation on how to force a specific Visual Studio
|
||
installation in Cerbero, please see the README
|
||
- New plugins: qsv wavpack directshow amfcodec wic win32ipc
|
||
- New libraries: d3d11
|
||
|
||
Windows MSI installer
|
||
|
||
- Universal Windows Platform prebuilt binaries are no longer available
|
||
|
||
Linux
|
||
|
||
- Various fixes for RHEL/CentOS 7 support
|
||
- Added support for running on Linux ARM64
|
||
|
||
Android
|
||
|
||
- Android support now requires Android API version 21 (Lollipop)
|
||
- Support for Android Gradle plugin 7.2
|
||
|
||
Platform-specific changes and improvements
|
||
|
||
Android
|
||
|
||
- Android SDK 21 is required now as minimum SDK version
|
||
|
||
- androidmedia: Add H.265 / HEVC video encoder mapping
|
||
|
||
- Implement JNI_OnLoad() to register static plugins etc. automatically
|
||
in case GStreamer is loaded from Java using System.loadLibrary(),
|
||
which is also useful for the gst-full deployment scenario.
|
||
|
||
Apple macOS and iOS
|
||
|
||
- The GLib version shipped with the GStreamer binaries does not
|
||
initialize an NSApp and does not run a NSRunLoop on the main thread
|
||
anymore. This was a custom GLib patch and caused it to behave
|
||
different from the GLib shipped by Homebrew or anybody else.
|
||
|
||
The change was originally introduced because various macOS APIs
|
||
require a NSRunLoop to run on the main thread to function correctly
|
||
but as this change will never get merged into GLib and it was
|
||
reverted for 1.22. Applications that relied on this behaviour should
|
||
move to the new gst_macos_main() function, which also does not
|
||
require the usage of a GMainLoop.
|
||
|
||
See e.g. gst-play.c for an example for the usage of
|
||
gst_macos_main().
|
||
|
||
- GStreamer.framework and all libraries in it are now relocatable,
|
||
which means they use LC_RPATH entries to find dependencies instead
|
||
of using an absolute path. If you link to GStreamer using the
|
||
pkgconfig files, no action is necessary. However, if you use the
|
||
framework directly or link to the libraries inside the framework by
|
||
hand, then you need to pass -Wl,-rpath,<path_to_libdir> to the
|
||
linker.
|
||
|
||
- avfvideosrc: Allow specifying crop coordinates during screen capture
|
||
|
||
- vtenc, vtdec: H.265 / HEVC video encoding + decoding support
|
||
|
||
- osxaudiosrc: Support a device as both input and output
|
||
|
||
- osxaudiodeviceprovider now probes devices more than once to
|
||
determine if the device can function as both an input AND and
|
||
output device. Previously, if the device provider detected that
|
||
a device had any output capabilities, it was treated solely as
|
||
an Audio/Sink. This caused issues for devices that have both
|
||
input and output capabilities (for example, USB interfaces for
|
||
professional audio have both input and output channels). Such
|
||
devicesare now listed as both an Audio/Sink as well as an
|
||
Audio/Source.
|
||
|
||
- osxaudio: support hidden devices on macOS
|
||
|
||
- These are devices that will not be shown in the macOS UIs and
|
||
that cannot be retrieved without having the specific UID of the
|
||
hidden device. There are cases when you might want to have a
|
||
hidden device, for example when having a virtual speaker that
|
||
forwards the data to a virtual hidden input device from which
|
||
you can then grab the audio. The blackhole project supports
|
||
these hidden devices and this change provides a way that if the
|
||
device id is a hidden device it will use it instead of checkinf
|
||
the hardware list of devices to understand if the device is
|
||
valid.
|
||
|
||
Windows
|
||
|
||
- win32ipcvideosink, win32ipcvideosrc: new shared memory videosrc/sink
|
||
elements
|
||
|
||
- wasapi2: Add support for process loopback capture for a specified
|
||
PID (requires Windows 11/Windows Server 2022)
|
||
|
||
- The Windows universal UWP build is currently non-functional and will
|
||
need updating after the recent GLib upgrade. It is unclear if anyone
|
||
is using these binaries, so if you are please make yourself known.
|
||
|
||
- wicjpegdec, wicpngdec: Windows Imaging Component (WIC) based JPEG
|
||
and PNG decoder elements.
|
||
|
||
- mfaacdec, mfmp3dec: Windows MediaFoundation AAC and MP3 decoders
|
||
|
||
- The uninstalled development environment supports PowerShell 7 now
|
||
|
||
Linux
|
||
|
||
- Improved design for DMA buffer sharing and modifier handling for
|
||
hardware-accelerated video decoders/encoders/filters and
|
||
capture/rendering on Linux and Linux-like system.
|
||
|
||
- kmssink
|
||
|
||
- new “fd” property which allows an application to provide their
|
||
own opened DRM device fd handle to kmssink. That way an
|
||
application can lease multiple fd’s from a DRM master to display
|
||
on different CRTC outputs at the same time with multiple kmssink
|
||
instances, for example.
|
||
- new “skip-vsync” property to achieve full framerate with legacy
|
||
emulation in drivers.
|
||
- HDR10 infoframe support
|
||
|
||
- va plugin and gstreamer-vaapi improvements (see above)
|
||
|
||
- waylandsink: Add “rotate-method” property and “render-rectangle”
|
||
property
|
||
|
||
- new gtkwaylandsink element based on gtksink, but similar to
|
||
waylandsink and uses Wayland APIs directly instead of rendering with
|
||
Gtk/Cairo primitives. This approach is only compatible with Gtk3,
|
||
and like gtksink this element only supports Gtk3.
|
||
|
||
Documentation improvements
|
||
|
||
- The GStreamer Rust plugins are now included and documented in the
|
||
plugin documentation.
|
||
|
||
Possibly Breaking Changes
|
||
|
||
- the Opus audio RTP payloader and depayloader no longer accept the
|
||
lower case encoding-format=multiopus but instead produce and accept
|
||
only the upper case variant encoding-format=MULTIOPUS, since those
|
||
should always be upper case in GStreamer (caps fields are always
|
||
case sensitive). This should hopefully only affect applications
|
||
where RTP caps are set manually and multi-channel audio (>= 3
|
||
channels) is used.
|
||
|
||
- wpesrc: the URI handler protocols changed from wpe:// and web:// to
|
||
web+http://, web+https://, and web+file:// which means URIs are RFC
|
||
3986 compliant and the source can simply strip the prefix from the
|
||
protocol.
|
||
|
||
- The Windows screen capture element dxgiscreencapsrc has been
|
||
removed, please use d3d11screencapturesrc instead.
|
||
|
||
- On Android the minimum supported Android API version is now version
|
||
21 and has been increased from 16.
|
||
|
||
- On macOS, the GLib version shipped with the GStreamer binaries will
|
||
no longer initialize an NSApp or run an NSRunLoop on the main
|
||
thread. See macOS/iOS section above for details.
|
||
|
||
- decklink: The decklink plugin is now using the 12.2.2 version of the
|
||
SDK and will not work with drivers older than version 12.
|
||
|
||
- On iOS Apple Bitcode support was removed from the binaries. This
|
||
feature is deprecated since XCode 14 and not used on the App Store
|
||
anymore.
|
||
|
||
- The MP4/Matroska/WebM muxers now require the “stream-format” to be
|
||
provided as part of the AV1 caps as only the original “obu-stream”
|
||
format is supported in these containers and not the “annexb” format.
|
||
|
||
Known Issues
|
||
|
||
- The Windows UWP build in Cerbero needs fixing after the recent GLib
|
||
upgrade (see above)
|
||
|
||
- The C# bindings have not been updated to include new 1.22 API yet
|
||
(see above)
|
||
|
||
Statistics
|
||
|
||
- 4072 commits
|
||
|
||
- 2224 Merge Requests
|
||
|
||
- 716 Issues
|
||
|
||
- 200+ Contributors
|
||
|
||
- ~33% of all commits and Merge Requests were in Rust modules
|
||
|
||
- 4747 files changed
|
||
|
||
- 469633 lines added
|
||
|
||
- 209842 lines deleted
|
||
|
||
- 259791 lines added (net)
|
||
|
||
Contributors
|
||
|
||
Ádám Balázs, Adam Doupe, Adrian Fiergolski, Adrian Perez de Castro, Alba
|
||
Mendez, Aleix Conchillo Flaqué, Aleksandr Slobodeniuk, Alicia Boya
|
||
García, Alireza Miryazdi, Andoni Morales Alastruey, Andrew Pritchard,
|
||
Arun Raghavan, A. Wilcox, Bastian Krause, Bastien Nocera, Benjamin
|
||
Gaignard, Bill Hofmann, Bo Elmgreen, Boyuan Zhang, Brad Hards, Branko
|
||
Subasic, Bruce Liang, Bunio FH, byran77, Camilo Celis Guzman, Carlos
|
||
Falgueras García, Carlos Rafael Giani, Célestin Marot, Christian Wick,
|
||
Christopher Obbard, Christoph Reiter, Chris Wiggins, Chun-wei Fan, Colin
|
||
Kinloch, Corentin Damman, Corentin Noël, Damian Hobson-Garcia, Daniel
|
||
Almeida, Daniel Morin, Daniel Stone, Daniels Umanovskis, Danny Smith,
|
||
David Svensson Fors, Devin Anderson, Diogo Goncalves, Dmitry Osipenko,
|
||
Dongil Park, Doug Nazar, Edward Hervey, ekwange, Eli Schwartz, Elliot
|
||
Chen, Enrique Ocaña González, Eric Knapp, Erwann Gouesbet, Evgeny
|
||
Pavlov, Fabian Orccon, Fabrice Fontaine, Fan F He, F. Duncanh, Filip
|
||
Hanes, Florian Zwoch, François Laignel, Fuga Kato, George Kiagiadakis,
|
||
Guillaume Desmottes, Gu Yanjie, Haihao Xiang, Haihua Hu, Havard Graff,
|
||
Heiko Becker, He Junyan, Henry Hoegelow, Hiero32, Hoonhee Lee, Hosang
|
||
Lee, Hou Qi, Hugo Svirak, Ignacio Casal Quinteiro, Ignazio Pillai, Igor
|
||
V. Kovalenko, Jacek Skiba, Jakub Adam, James Cowgill, James Hilliard,
|
||
Jan Alexander Steffens (heftig), Jan Lorenz, Jan Schmidt, Jianhui Dai,
|
||
jinsl00000, Johan Sternerup, Jonas Bonn, Jonas Danielsson, Jordan
|
||
Petridis, Joseph Donofry, Jose Quaresma, Julian Bouzas, Junsoo Park,
|
||
Justin Chadwell, Khem Raj, Krystian Wojtas, László Károlyi, Linus
|
||
Svensson, Loïc Le Page, Ludvig Rappe, Marc Leeman, Marek Olejnik, Marek
|
||
Vasut, Marijn Suijten, Mark Nauwelaerts, Martin Dørum, Martin Reboredo,
|
||
Mart Raudsepp, Mathieu Duponchelle, Matt Crane, Matthew Waters, Matthias
|
||
Clasen, Matthias Fuchs, Mengkejiergeli Ba, MGlolenstine, Michael Gruner,
|
||
Michiel Konstapel, Mikhail Fludkov, Ming Qian, Mingyang Ma, Myles
|
||
Inglis, Nicolas Dufresne, Nirbheek Chauhan, Olivier Crête, Pablo Marcos
|
||
Oltra, Patricia Muscalu, Patrick Griffis, Paweł Stawicki, Peter
|
||
Stensson, Philippe Normand, Philipp Zabel, Pierre Bourré, Piotr
|
||
Brzeziński, Rabindra Harlalka, Rafael Caricio, Rafael Sobral, Rafał
|
||
Dzięgiel, Raul Tambre, Robert Mader, Robert Rosengren, Rodrigo
|
||
Bernardes, Rouven Czerwinski, Ruben Gonzalez, Sam Van Den Berge,
|
||
Sanchayan Maity, Sangchul Lee, Sebastian Dröge, Sebastian Fricke,
|
||
Sebastian Groß, Sebastian Mueller, Sebastian Wick, Sergei Kovalev,
|
||
Seungha Yang, Seungmin Kim, sezanzeb, Sherrill Lin, Shingo Kitagawa,
|
||
Stéphane Cerveau, Talha Khan, Taruntej Kanakamalla, Thibault Saunier,
|
||
Tim Mooney, Tim-Philipp Müller, Tomasz Andrzejak, Tom Schuring, Tong Wu,
|
||
toor, Tristan Matthews, Tulio Beloqui, U. Artie Eoff, Víctor Manuel
|
||
Jáquez Leal, Vincent Cheah Beng Keat, Vivia Nikolaidou, Vivienne
|
||
Watermeier, WANG Xuerui, Wojciech Kapsa, Wonchul Lee, Wu Tong, Xabier
|
||
Rodriguez Calvar, Xavier Claessens, Yatin Mann, Yeongjin Jeong, Zebediah
|
||
Figura, Zhao Zhili, Zhiyuaniu, مهدي شينون (Mehdi Chinoune),
|
||
|
||
… and many others who have contributed bug reports, translations, sent
|
||
suggestions or helped testing.
|
||
|
||
Stable 1.22 branch
|
||
|
||
After the 1.22.0 release there will be several 1.22.x bug-fix releases
|
||
which will contain bug fixes which have been deemed suitable for a
|
||
stable branch, but no new features or intrusive changes will be added to
|
||
a bug-fix release usually. The 1.22.x bug-fix releases will be made from
|
||
the git 1.22 branch, which will be a stable branch.
|
||
|
||
1.22.0
|
||
|
||
1.22.0 was originally released on 23 January 2023.
|
||
|
||
Schedule for 1.24
|
||
|
||
Our next major feature release will be 1.24, and 1.23 will be the
|
||
unstable development version leading up to the stable 1.24 release. The
|
||
development of 1.23/1.24 will happen in the git main branch of the
|
||
GStreamer mono repository.
|
||
|
||
The plan for the 1.24 development cycle is yet to be confirmed.
|
||
|
||
1.24 will be backwards-compatible to the stable 1.22, 1.20, 1.18, 1.16,
|
||
1.14, 1.12, 1.10, 1.8, 1.6, 1.4, 1.2 and 1.0 release series.
|
||
|
||
------------------------------------------------------------------------
|
||
|
||
These release notes have been prepared by Tim-Philipp Müller with
|
||
contributions from Edward Hervey, Matthew Waters, Nicolas Dufresne,
|
||
Nirbheek Chauhan, Olivier Crête, Sebastian Dröge, Seungha Yang, and
|
||
Thibault Saunier.
|
||
|
||
License: CC BY-SA 4.0
|