d3d11videosink: Ensure shader resource view of fallback buffer
authorSeungha Yang <seungha@centricular.com>
Fri, 12 Jun 2020 10:44:01 +0000 (19:44 +0900)
committerGStreamer Merge Bot <gitlab-merge-bot@gstreamer-foundation.org>
Tue, 16 Jun 2020 10:49:02 +0000 (10:49 +0000)
SRV must be configured for color conversion

Part-of: <https://gitlab.freedesktop.org/gstreamer/gst-plugins-bad/-/merge_requests/1339>

sys/d3d11/gstd3d11videosink.c

index 2cf4611..3ada96f 100644 (file)
@@ -740,6 +740,8 @@ gst_d3d11_video_sink_upload_frame (GstD3D11VideoSink * self, GstBuffer * inbuf,
   gboolean ret;
   gint i;
 
+  GST_LOG_OBJECT (self, "Copy to fallback buffer");
+
   if (!gst_video_frame_map (&in_frame, &self->info, inbuf,
           GST_MAP_READ | GST_VIDEO_FRAME_MAP_FLAG_NO_REF))
     goto invalid_buffer;
@@ -846,6 +848,18 @@ gst_d3d11_video_sink_show_frame (GstVideoSink * sink, GstBuffer * buf)
       return GST_FLOW_ERROR;
     }
 
+    for (i = 0; i < gst_buffer_n_memory (render_buf); i++) {
+      GstD3D11Memory *dmem;
+
+      dmem = (GstD3D11Memory *) gst_buffer_peek_memory (render_buf, i);
+      if (!gst_d3d11_memory_ensure_shader_resource_view (dmem)) {
+        GST_ERROR_OBJECT (self, "fallback shader resource view is unavailable");
+        gst_buffer_unref (render_buf);
+
+        return GST_FLOW_ERROR;
+      }
+    }
+
     if (!gst_d3d11_video_sink_upload_frame (self, buf, render_buf)) {
       GST_ERROR_OBJECT (self, "cannot upload frame");
       gst_buffer_unref (render_buf);