mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-11 09:55:36 +00:00
switchbin: Don't report sink pad caps for src pad queries.
When handling a caps query on the src pad, don't return the union of input caps. Even when not active, a path element can be queried for srcpad template caps, or for dropping paths the allowed downstream caps is anything - as data will be dropped anyway. Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/2018>
This commit is contained in:
parent
891be51105
commit
1f865246c1
1 changed files with 12 additions and 8 deletions
|
@ -145,7 +145,7 @@ static GstPadProbeReturn gst_switch_bin_blocking_pad_probe (GstPad * pad,
|
||||||
GstPadProbeInfo * info, gpointer user_data);
|
GstPadProbeInfo * info, gpointer user_data);
|
||||||
|
|
||||||
static GstCaps *gst_switch_bin_get_allowed_caps (GstSwitchBin * switch_bin,
|
static GstCaps *gst_switch_bin_get_allowed_caps (GstSwitchBin * switch_bin,
|
||||||
gchar const *pad_name, GstCaps * filter);
|
GstPad * switch_bin_pad, gchar const *pad_name, GstCaps * filter);
|
||||||
static gboolean gst_switch_bin_are_caps_acceptable (GstSwitchBin *
|
static gboolean gst_switch_bin_are_caps_acceptable (GstSwitchBin *
|
||||||
switch_bin, GstCaps const *caps);
|
switch_bin, GstCaps const *caps);
|
||||||
|
|
||||||
|
@ -463,7 +463,8 @@ gst_switch_bin_handle_query (GstPad * pad, GstObject * parent, GstQuery * query,
|
||||||
|| (switch_bin->current_path->element == NULL)) {
|
|| (switch_bin->current_path->element == NULL)) {
|
||||||
/* Paths exist, but there is no current path (or the path is a dropping path,
|
/* Paths exist, but there is no current path (or the path is a dropping path,
|
||||||
* so no element exists) - just return all allowed caps */
|
* so no element exists) - just return all allowed caps */
|
||||||
caps = gst_switch_bin_get_allowed_caps (switch_bin, pad_name, filter);
|
caps =
|
||||||
|
gst_switch_bin_get_allowed_caps (switch_bin, pad, pad_name, filter);
|
||||||
} else {
|
} else {
|
||||||
/* Paths exist and there is a current path
|
/* Paths exist and there is a current path
|
||||||
* Forward the query to its element */
|
* Forward the query to its element */
|
||||||
|
@ -817,7 +818,7 @@ gst_switch_bin_find_matching_path (GstSwitchBin * switch_bin,
|
||||||
|
|
||||||
static GstCaps *
|
static GstCaps *
|
||||||
gst_switch_bin_get_allowed_caps (GstSwitchBin * switch_bin,
|
gst_switch_bin_get_allowed_caps (GstSwitchBin * switch_bin,
|
||||||
G_GNUC_UNUSED gchar const *pad_name, GstCaps * filter)
|
GstPad * switch_bin_pad, gchar const *pad_name, GstCaps * filter)
|
||||||
{
|
{
|
||||||
/* must be called with path lock held */
|
/* must be called with path lock held */
|
||||||
|
|
||||||
|
@ -849,7 +850,7 @@ gst_switch_bin_get_allowed_caps (GstSwitchBin * switch_bin,
|
||||||
for (i = 0; i < switch_bin->num_paths; ++i) {
|
for (i = 0; i < switch_bin->num_paths; ++i) {
|
||||||
GstSwitchBinPath *path = switch_bin->paths[i];
|
GstSwitchBinPath *path = switch_bin->paths[i];
|
||||||
|
|
||||||
if ((path->element != NULL) && (path == switch_bin->current_path)) {
|
if (path->element != NULL) {
|
||||||
GstPad *pad;
|
GstPad *pad;
|
||||||
GstCaps *caps, *intersected_caps;
|
GstCaps *caps, *intersected_caps;
|
||||||
GstQuery *caps_query = NULL;
|
GstQuery *caps_query = NULL;
|
||||||
|
@ -870,10 +871,13 @@ gst_switch_bin_get_allowed_caps (GstSwitchBin * switch_bin,
|
||||||
gst_object_unref (GST_OBJECT (pad));
|
gst_object_unref (GST_OBJECT (pad));
|
||||||
gst_query_unref (caps_query);
|
gst_query_unref (caps_query);
|
||||||
} else {
|
} else {
|
||||||
/* Either this is the current path and it has no element (= is a dropping path),
|
/* This is a path with no element (= is a dropping path),
|
||||||
* or it is not the current path. In both cases, no caps query can be performed.
|
* If querying the sink caps, append the path
|
||||||
* Just append the path caps then. */
|
* input caps, otherwise the output caps can be ANY */
|
||||||
|
if (gst_pad_get_direction (switch_bin_pad) == GST_PAD_SINK)
|
||||||
gst_caps_append (total_path_caps, gst_caps_ref (path->caps));
|
gst_caps_append (total_path_caps, gst_caps_ref (path->caps));
|
||||||
|
else
|
||||||
|
gst_caps_append (total_path_caps, gst_caps_new_any ());
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue