plugin: if any caps in downstream, negotiate raw video

When downstream has any caps, vaapi should not shovel vaapi featured
buffers, but rather plain raw video, assuming always the worst case
scenario (downstream cannot handle featured video memory but raw
system memory buffers).

This patch query the peer caps without any filter, to know if
donwstream just ask for any caps, if so jump to the color space
checking, otherwise do the caps intersection and continue with the
feature selection algorithm.

Fixes: #139
This commit is contained in:
Víctor Manuel Jáquez Leal 2019-02-27 13:02:10 +01:00
parent 3fa74d7838
commit 3e992d8adb

View file

@ -638,21 +638,31 @@ gst_vaapi_find_preferred_caps_feature (GstPad * pad, GstCaps * allowed_caps,
{ {
GstVaapiCapsFeature feature = GST_VAAPI_CAPS_FEATURE_NOT_NEGOTIATED; GstVaapiCapsFeature feature = GST_VAAPI_CAPS_FEATURE_NOT_NEGOTIATED;
guint i, j, num_structures; guint i, j, num_structures;
GstCaps *out_caps, *caps = NULL; GstCaps *peer_caps, *out_caps = NULL, *caps = NULL;
static const guint feature_list[] = { GST_VAAPI_CAPS_FEATURE_VAAPI_SURFACE, static const guint feature_list[] = { GST_VAAPI_CAPS_FEATURE_VAAPI_SURFACE,
GST_VAAPI_CAPS_FEATURE_DMABUF, GST_VAAPI_CAPS_FEATURE_DMABUF,
GST_VAAPI_CAPS_FEATURE_GL_TEXTURE_UPLOAD_META, GST_VAAPI_CAPS_FEATURE_GL_TEXTURE_UPLOAD_META,
GST_VAAPI_CAPS_FEATURE_SYSTEM_MEMORY, GST_VAAPI_CAPS_FEATURE_SYSTEM_MEMORY,
}; };
out_caps = gst_pad_peer_query_caps (pad, allowed_caps); /* query with no filter */
if (!out_caps) peer_caps = gst_pad_peer_query_caps (pad, NULL);
if (!peer_caps)
goto cleanup;
if (gst_caps_is_empty (peer_caps))
goto cleanup; goto cleanup;
if (gst_caps_is_any (out_caps) || gst_caps_is_empty (out_caps)) /* filter against our allowed caps */
goto cleanup; out_caps = gst_caps_intersect_full (allowed_caps, peer_caps,
GST_CAPS_INTERSECT_FIRST);
/* default feature */
feature = GST_VAAPI_CAPS_FEATURE_SYSTEM_MEMORY; feature = GST_VAAPI_CAPS_FEATURE_SYSTEM_MEMORY;
/* if downstream requests caps ANY, system memory is preferred */
if (gst_caps_is_any (peer_caps))
goto find_format;
num_structures = gst_caps_get_size (out_caps); num_structures = gst_caps_get_size (out_caps);
for (i = 0; i < num_structures; i++) { for (i = 0; i < num_structures; i++) {
GstCapsFeatures *const features = gst_caps_get_features (out_caps, i); GstCapsFeatures *const features = gst_caps_get_features (out_caps, i);
@ -685,13 +695,14 @@ gst_vaapi_find_preferred_caps_feature (GstPad * pad, GstCaps * allowed_caps,
if (!caps) if (!caps)
goto cleanup; goto cleanup;
find_format:
if (out_format_ptr) { if (out_format_ptr) {
GstVideoFormat out_format; GstVideoFormat out_format;
GstStructure *structure; GstStructure *structure;
const GValue *format_list; const GValue *format_list;
/* if the best feature is SystemMemory, we should use the first /* if the best feature is SystemMemory, we should use the first
* caps in the peer caps set, which is the preferred by * caps in the filtered peer caps set, which is the preferred by
* downstream. */ * downstream. */
if (feature == GST_VAAPI_CAPS_FEATURE_SYSTEM_MEMORY) if (feature == GST_VAAPI_CAPS_FEATURE_SYSTEM_MEMORY)
gst_caps_replace (&caps, out_caps); gst_caps_replace (&caps, out_caps);
@ -713,6 +724,7 @@ gst_vaapi_find_preferred_caps_feature (GstPad * pad, GstCaps * allowed_caps,
cleanup: cleanup:
gst_caps_replace (&caps, NULL); gst_caps_replace (&caps, NULL);
gst_caps_replace (&out_caps, NULL); gst_caps_replace (&out_caps, NULL);
gst_caps_replace (&peer_caps, NULL);
return feature; return feature;
} }