d3d11device: Print supported DXGI format for debugging
authorSeungha Yang <seungha@centricular.com>
Fri, 19 Jun 2020 12:34:32 +0000 (21:34 +0900)
committerGStreamer Merge Bot <gitlab-merge-bot@gstreamer-foundation.org>
Mon, 22 Jun 2020 14:36:16 +0000 (14:36 +0000)
Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/1355>

sys/d3d11/gstd3d11device.c

index c8df4a8aa1cbad8e3a7e53d440a227ba035e6839..0641e5a5000f8a77ecac3d566563f826f23fc921 100644 (file)
@@ -371,14 +371,29 @@ can_support_format (GstD3D11Device * self, DXGI_FORMAT format)
       (D3D11_FORMAT_SUPPORT_TEXTURE2D | D3D11_FORMAT_SUPPORT_RENDER_TARGET |
       D3D11_FORMAT_SUPPORT_SHADER_SAMPLE);
 
-  if (!gst_d3d11_is_windows_8_or_greater ())
+  if (!gst_d3d11_is_windows_8_or_greater ()) {
+    GST_WARNING_OBJECT (self, "DXGI format %d needs Windows 8 or greater",
+        (guint) format);
     return FALSE;
+  }
 
   hr = ID3D11Device_CheckFormatSupport (handle, format, &supported);
-  if (!gst_d3d11_result (hr, NULL))
+  if (!gst_d3d11_result (hr, NULL)) {
+    GST_WARNING_OBJECT (self, "DXGI format %d is not supported by device",
+        (guint) format);
     return FALSE;
+  }
+
+  if ((supported & flags) != flags) {
+    GST_WARNING_OBJECT (self,
+        "DXGI format %d doesn't support flag 0x%x (supported flag 0x%x)",
+        (guint) format, (guint) supported, (guint) flags);
+    return FALSE;
+  }
+
+  GST_INFO_OBJECT (self, "Device supports DXGI format %d", (guint) format);
 
-  return (supported & flags) == flags;
+  return TRUE;
 }
 
 static void