From 3c8ac7de80a51cf51da86d322308b24a70080116 Mon Sep 17 00:00:00 2001
From: Philipp Zabel
Date: Wed, 17 Oct 2018 17:22:10 +0200
Subject: [PATCH] glupload: dmabuf-direct: report driver limitations to debug
log
Report in the DEBUG log if the driver does not support importing a given
format with linear modifiers non-externally.
https://bugzilla.gnome.org/show_bug.cgi?id=783521
---
gst-libs/gst/gl/egl/gsteglimage.c | 16 ++++++++++++++--
1 file changed, 14 insertions(+), 2 deletions(-)
diff --git a/gst-libs/gst/gl/egl/gsteglimage.c b/gst-libs/gst/gl/egl/gsteglimage.c
index 6138ba0fa8..81eb1ec9bd 100644
--- a/gst-libs/gst/gl/egl/gsteglimage.c
+++ b/gst-libs/gst/gl/egl/gsteglimage.c
@@ -637,13 +637,19 @@ _gst_egl_image_check_dmabuf_direct (GstGLContext * context, int fourcc)
break;
}
g_free (formats);
- if (i == num_formats)
+ if (i == num_formats) {
+ GST_DEBUG ("driver does not support importing fourcc %" GST_FOURCC_FORMAT,
+ GST_FOURCC_ARGS (fourcc));
return FALSE;
+ }
ret = gst_eglQueryDmaBufModifiersEXT (egl_display, fourcc, 0, NULL, NULL,
&num_modifiers);
- if (!ret || num_modifiers == 0)
+ if (!ret || num_modifiers == 0) {
+ GST_DEBUG ("driver does not report modifiers for fourcc %"
+ GST_FOURCC_FORMAT, GST_FOURCC_ARGS (fourcc));
return FALSE;
+ }
modifiers = g_new (EGLuint64KHR, num_modifiers);
external_only = g_new (EGLBoolean, num_modifiers);
@@ -658,12 +664,18 @@ _gst_egl_image_check_dmabuf_direct (GstGLContext * context, int fourcc)
for (i = 0; i < num_modifiers; ++i) {
if (modifiers[i] == DRM_FORMAT_MOD_LINEAR) {
+ if (external_only[i]) {
+ GST_DEBUG ("driver only supports external import of fourcc %"
+ GST_FOURCC_FORMAT, GST_FOURCC_ARGS (fourcc));
+ }
ret = !external_only[i];
g_free (modifiers);
g_free (external_only);
return ret;
}
}
+ GST_DEBUG ("driver only supports non-linear import of fourcc %"
+ GST_FOURCC_FORMAT, GST_FOURCC_ARGS (fourcc));
g_free (modifiers);
g_free (external_only);
return FALSE;