Edward Hervey
4f94749665
gstpromise: Don't use g_return_* for internal checks
...
If assertion/checks are disabled bad things will happen and the function won't
return as expected
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6993 >
2024-06-05 18:47:05 +00:00
Stéphane Cerveau
df33ae2da6
gst-plugins-bad: tests: rename vkvideoencode tests
...
Rename vulkan encode tests to be able to use the namespace
libs_vkvideoencode*.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6992 >
2024-06-05 17:50:27 +00:00
Stéphane Cerveau
21ee264d65
vulkan: remove GST_VULKAN_HAVE_VIDEO_ENCODERS
...
Use 2.3.275 as first supported SDK version
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6992 >
2024-06-05 17:50:27 +00:00
Stéphane Cerveau
b9633cb766
vkqueue: remove useless decoder include
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6992 >
2024-06-05 17:50:26 +00:00
Corentin Damman
bdeabcc4a6
gstqsg6material: fix RGB format support
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6991 >
2024-06-05 16:49:06 +00:00
Thibault Saunier
11f96ce4dd
autoconvert: Fix race condition when creating sub elements
...
There was a case where the element would get destroyed while being
added to the hash table of elements
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6989 >
2024-06-05 12:53:45 +00:00
Sebastian Dröge
c14a2d7d6d
video: Document UL_LR / UR_LL video orientation methods correctly
...
They're not flipping along the diagonal axis but a flip and rotation.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6936 >
2024-06-05 11:37:13 +00:00
Chun-wei Fan
d024ee4303
GTK plugin: Support OpenGL/WGL on Windows
...
This attempts to implement the gtkglsink element on Windows using WGL,
as there were some more gotchas that are along the way, since we need to
juggle with libepoxy along the way, meaning that we need a recent
GTK+-3.24.x for this to work properly, i.e. the upcoming GTK+-3.24.43.
Since we are essentially using an overlay compositor only during
rendering, move its initialization and destruction into the
gtk_gst_gl_widget_render() function, so that things are safer as we are
doing things across threads between gstreamer (gst-gl) and GTK, as GL
operations, as above, have more gotchas on Windows.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/4289 >
2024-06-05 08:53:19 +00:00
Sebastian Dröge
cfb59df83e
dtlssrtpenc: Don't crash if no pad name is provided when requesting a new pad
...
It is mandatory to provide a valid pad name for dtlssrtpenc.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6984 >
2024-06-05 07:30:36 +00:00
Edward Hervey
6c4f52ea20
decodebin3: Avoid usage of parsebin even more
...
When dealing with push-based inputs, we are now delaying the creation of
parsebin/identity until we get all pre-buffer events.
We therefore can simplify the handling of new pads being linked and only have to
check if upstream can handle pull-based or not.
Avoids creating parsebin for parsed upstream data altogether
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6953 >
2024-06-04 14:44:14 +00:00
Matthew Waters
013026b06a
vulkan/videofilter: add getters for queue/device/instance
...
Allows bindings to not pke at structs for this information.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6987 >
2024-06-03 00:06:18 +10:00
Matthew Waters
a7a70ca7b6
vulkan/fullscreenquad: add get_queue()
...
Allows bindings to not poke at the instance struct.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6987 >
2024-06-03 00:06:18 +10:00
Matthew Waters
5e182c911c
vulkan/fullscreenquad: mark set_info GstVideoInfo as const
...
It's not modified by the function.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6987 >
2024-06-03 00:06:18 +10:00
Piotr Brzeziński
9ca8f16a3b
macos: Listen for audio devices being added/removed
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6981 >
2024-06-01 13:21:59 +00:00
Matthew Waters
5b471311c5
vulkan: also support glslang as a shader compiler
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6980 >
2024-06-01 12:41:49 +00:00
Matthew Waters
346df4cb3f
vulkan: support not having glslc available for building vulkan plugin
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6980 >
2024-06-01 12:41:49 +00:00
Sebastian Dröge
9b60b32cf8
rtspsrc: Only update from the Content-Base header in the initial OPTION / DESCRIBE response
...
Some servers send a new content base in the SETUP response, which is
just the non-aggregate control URL of the individual streams.
See https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3563
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6926 >
2024-06-01 11:30:44 +00:00
Sebastian Dröge
e65344afac
rtspsrc: Handle the case of *
as session-wide control URL from the SDP
...
Just like the comment above says this is supposed to indicate that the
same URL should be used as for the connection so far. If encountering
this case simply do nothing.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6926 >
2024-06-01 11:30:44 +00:00
Sebastian Dröge
e73e34fd6f
rtspsrc: Also handle rtsps://
and similar URLs as absolute in other places
...
Previously a direct comparison with `rtsp://` was performed, which
didn't catch cases like `rtsps://`.
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3563
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6926 >
2024-06-01 11:30:44 +00:00
Sebastian Dröge
966c39b92e
rtspsrc: Don't try the SETUP workaround for broken servers with absolute control URIs
...
Previously only control URIs that started with "rtsp://" were ignored
but it makes more sense to ignore all absolute URIs.
gst_uri_is_valid() conveniently checks for exactly that.
See https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3563
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6926 >
2024-06-01 11:30:43 +00:00
Jakub Adam
c56a87b73d
gldownload: use gst_gl_sync_meta_wait_cpu()
...
Simple gst_gl_sync_meta_wait() is not sufficient to ensure GL commands
are executed before dma-buf devices get to see the buffer.
This is the first step that should make the code behave correctly for
everybody, although there may be performance penalty. In the future we
should introduce a more general sync meta that would allow to move the
waiting from gldownload (the producer) to the sink elements (the
consumers).
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6968 >
2024-06-01 08:09:34 +00:00
Martin Nordholts
5d2421b8c8
gst_debug: Add missing gst_debug_log_id_literal() dummy with gst_debug=false
...
E.g. gst_debug_log_literal() already has a dummy variant.
gst_debug_log_id_literal() is simply missing, which can
cause link errors for project using gstreamer with
gst_debug=false.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6972 >
2024-06-01 07:30:34 +00:00
Stéphane Cerveau
7bbf5fd801
vkutils: do not forget to clear context in case of error
...
The context is leaking in case of a failing instance open.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6975 >
2024-05-31 14:44:09 +00:00
Stéphane Cerveau
c3f3fd7351
vkerror: free the error string after usage
...
g_set_error already used the var string, can clear it now.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6975 >
2024-05-31 14:44:09 +00:00
Edward Hervey
cb95ba72cf
decodebin3: Include the stream-id in ERROR/WARNING/INFO messages
...
Allows application and other users to know to which stream the
error/warning/info message originated from.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6964 >
2024-05-31 11:58:21 +00:00
Seungha Yang
fd21d97060
qtdemux: Handle keyunit trick mode in case of push mode too
...
Skip non-keyframe video frames if trickmode-keyunit flag is set
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5900 >
2024-05-31 11:21:55 +00:00
Samuel Thibault
31047b878f
ptp-helper: Add GNU/Hurd support
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6970 >
2024-05-30 16:14:29 +00:00
Seungha Yang
e9cefde479
d3d12memory: Fix staging buffer alignment
...
Not all GPUs can support arbitrary offset of
D3D12_PLACED_SUBRESOURCE_FOOTPRINT when copying GPU memory between
texture and buffer. Instead of calculating size/offset per plane,
calculate the entire size and offsets at once.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6967 >
2024-05-30 10:40:44 +00:00
Edward Hervey
686d980955
uridecodebin3: Specify URI for INFO/WARNING/ERROR messages
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6929 >
2024-05-29 22:24:07 +00:00
Edward Hervey
1f4c1c18ca
gstmessage: Allow retrieving and setting details on messages
...
This was only available on warning/error/info messages creator/parsers. These
new functions make it more generic and also add a writable variant for users who
want to add/extend the details
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6929 >
2024-05-29 22:24:07 +00:00
Nirbheek Chauhan
fe1a7edda2
gl: Fix libdrm dependency detection and usage
...
drm_fourcc.h should be picked up via the pkgconfig dep, not the system
includedir directly. All this allows it to be picked up consistently
(via the subproject, for example).
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6932 >
2024-05-29 15:49:45 +00:00
Nirbheek Chauhan
907aca399f
msdk: Fix libdrm dependency detection and usage
...
drm_fourcc.h should be picked up via the pkgconfig include, not the
system includedir directly.
Also consolidate the libdrm usage in va and msdk.
All this allows it to be picked up consistently (via the subproject,
for example).
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6932 >
2024-05-29 15:49:45 +00:00
Nirbheek Chauhan
82b7850c2f
libdrm.wrap: Bump to latest 2.4.120
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6932 >
2024-05-29 15:49:45 +00:00
Nirbheek Chauhan
73cb87de4e
libva.wrap: Bump to latest release 2.21.0, move to wrap-file
...
Since we no longer require a pre-release git commit, we an use
a tarball which is faster and easier to update/cache.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6932 >
2024-05-29 15:49:45 +00:00
Nirbheek Chauhan
e3f086c648
meson: Don't use fallback: kwarg for libva deps
...
This will cause a fallback even when the `va` option is `auto`, not
giving the user a chance to provide the dependency via the system, and
likely building this feature unnecessarily.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6932 >
2024-05-29 15:49:45 +00:00
Nirbheek Chauhan
deaa0aef79
va: Fix libdrm include
...
The libdrm/ prefix should not be used, it will be provided by the
pkgconfig file. Also HAVE_LIBDRM is necessary.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6932 >
2024-05-29 15:49:45 +00:00
Víctor Manuel Jáquez Leal
236d6714ec
msdkcaps: fix ill-format string
...
This patch fixes this critical warning when registering MSDK:
_dma_fmt_to_dma_drm_fmts: assertion 'fmt != GST_VIDEO_FORMAT_UNKNOWN' failed
It was because the HEVC string with possible output formats has an extra space
that could not be parsed correctly.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6853 >
2024-05-29 13:08:55 +00:00
Edward Hervey
94646c642d
decodebin3: Specify stream-id for missing decoder
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6886 >
2024-05-29 11:44:06 +00:00
Edward Hervey
c987eaa427
pbutils: Missing plugin messages can contain the stream-id
...
In order to help users and applications, allow setting the stream-id for which
there is a missing plugin.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6886 >
2024-05-29 11:44:05 +00:00
Seungha Yang
96cf3d7063
d3d12encoder: Do not print error log for not-supported feature
...
gst_d3d12_result() will print message with ERROR level if failed.
Use FAILED/SUCCEEDED macros instead, since not-supported feature
is not a critical error
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6955 >
2024-05-29 10:45:13 +00:00
Seungha Yang
ec11bb8253
d3d12memory: Allow null allocator in alloc()
...
Update code as documented
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6940 >
2024-05-29 09:45:26 +00:00
Jakub Adam
859b1c8b63
glcolorconvert: update existing sync meta if outbuf has one
...
Instead of always adding a new one, which means the buffer could end up
with multiple sync meta instances.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6942 >
2024-05-29 07:29:43 +00:00
Sebastian Dröge
529f2472b3
gstreamer: parse: Don't assume that child proxy child objects are GstObjects
...
The name is already passed via the signal parameters so it doesn't have
to be retrieved again via GstObject API, which would crash on other
GObjects. Child proxy child objects can be any kind of GObject and the
code here otherwise handles this correctly already.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6938 >
2024-05-29 05:33:03 +00:00
Nicolas Dufresne
79312357a6
av1parse: Properly transfer TU timestamp
...
When transforming from unknown alignment to frame or obu, the TU timestamp
was not properly transferred. Fix this by saving the TU DTS as the first
DTS seen within the the TU data, and the PTS as the last PTS seen in that
TU data. Finally, reset the TU timestamp after each TU have completed.
Fixes #1496
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6895 >
2024-05-28 23:59:36 +00:00
Nicolas Dufresne
5b1bc0f19f
av1parse: Only place a marker on the last frame of a TU
...
Markers are meant to indicate the buffer that ends a frame, which imply
something can be displayed. The dependent decode only frames should not
have markers. This should also fix last subframe detection.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6895 >
2024-05-28 23:59:36 +00:00
Francisco Javier Velázquez-García
5fe7803128
docs: Correct pipeline examples in rawaudioparse
...
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6933 >
2024-05-28 22:20:08 +00:00
Sebastian Dröge
bb6d737a1e
typefind: Fix handling of ID_ODD_SIZE in WavPack typefinder
...
Chunks are always starting on an even position and this flag only
specifies that the last byte of the chunk is not valid.
Fixes https://gitlab.freedesktop.org/gstreamer/gstreamer/-/issues/3569
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6941 >
2024-05-28 19:18:37 +00:00
Seungha Yang
a4dfca3ae4
webview2: Add user-data-folder property
...
Adding a propery to specify location of WebView2's user data folder
location.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6921 >
2024-05-28 16:56:09 +00:00
Seungha Yang
05f9eadcaf
qtmux: Handle time information value > UINT32_MAX
...
If any duration in timescale is larger than UINT32_MAX, use version 1
atom, otherwise file header will be constructed with truncated values.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6843 >
2024-05-28 16:09:58 +00:00
Seungha Yang
c1b1c849f2
d3d12: Add support for Device Removed Extended Data (DRED)
...
Enable DRED if "d3d12dred > GST_LEVEL_ERROR", and print
DRED debug information on device removed.
Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/6718 >
2024-05-28 15:09:21 +00:00