2019-01-30 11:07:29 +00:00
|
|
|
/* GStreamer
|
|
|
|
* Copyright (C) 2019 Seungha Yang <seungha.yang@navercorp.com>
|
|
|
|
*
|
|
|
|
* This library is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU Library General Public
|
|
|
|
* License as published by the Free Software Foundation; either
|
|
|
|
* version 2 of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This library is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
|
|
* Library General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Library General Public
|
|
|
|
* License along with this library; if not, write to the
|
|
|
|
* Free Software Foundation, Inc., 51 Franklin St, Fifth Floor,
|
|
|
|
* Boston, MA 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2021-10-21 10:41:15 +00:00
|
|
|
/**
|
|
|
|
* SECTION:plugin-d3d11
|
|
|
|
*
|
|
|
|
* Microsoft Direct3D11 plugin.
|
|
|
|
*
|
|
|
|
* This plugin consists of various video filter, screen capture source,
|
|
|
|
* video sink, and video decoder elements.
|
|
|
|
*
|
|
|
|
* GstD3D11 plugin supports H.264/AVC, H.265/HEVC, VP8, VP9, H.262/MPEG-2 video,
|
|
|
|
* and AV1 codecs for decoding as well as hardware-accelerated video
|
|
|
|
* deinterlacing. Note that minimum required OS version for video decoder and
|
|
|
|
* deinterlacing elements is Windows 8.
|
|
|
|
*
|
|
|
|
* Plugin feature names of decoders:
|
|
|
|
* - d3d11h264dec
|
|
|
|
* - d3d11h265dec
|
|
|
|
* - d3d11vp8dec
|
|
|
|
* - d3d11vp9dec
|
|
|
|
* - d3d11mpeg2dec
|
|
|
|
* - d3d11av1dec
|
|
|
|
*
|
|
|
|
* Similar to the video decoder case, deinterlacing element would be registered
|
|
|
|
* only if its supported by hardware with the feature name `d3d11deinterlace`
|
|
|
|
*
|
|
|
|
* However, depending on the hardware it runs on, some elements might not be
|
|
|
|
* registered in case that underlying hardware doesn't support the feature.
|
|
|
|
* For a system with multiple Direct3D11 compatible hardwares (i.e., GPU),
|
|
|
|
* there can be multiple plugin features having the same role.
|
|
|
|
* The naming rule for the non-primary decoder element is
|
|
|
|
* `d3d11{codec}device{index}dec` where `index` is an arbitrary index number of
|
|
|
|
* hardware starting from 1.
|
|
|
|
*
|
|
|
|
* To get a list of all available elements, user can run
|
|
|
|
* ```sh
|
|
|
|
* gst-inspect-1.0.exe d3d11
|
|
|
|
* ```
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-01-30 11:07:29 +00:00
|
|
|
#ifdef HAVE_CONFIG_H
|
|
|
|
#include "config.h"
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#include <gst/gst.h>
|
2020-12-20 17:47:45 +00:00
|
|
|
#include <gst/d3d11/gstd3d11.h>
|
2019-01-30 11:07:29 +00:00
|
|
|
#include "gstd3d11videosink.h"
|
2019-11-06 10:38:31 +00:00
|
|
|
#include "gstd3d11upload.h"
|
|
|
|
#include "gstd3d11download.h"
|
2021-03-13 08:40:57 +00:00
|
|
|
#include "gstd3d11convert.h"
|
2020-06-02 16:26:12 +00:00
|
|
|
#include "gstd3d11compositor.h"
|
2019-12-26 05:24:46 +00:00
|
|
|
#include "gstd3d11h264dec.h"
|
2019-12-26 05:28:03 +00:00
|
|
|
#include "gstd3d11h265dec.h"
|
2019-12-20 14:05:52 +00:00
|
|
|
#include "gstd3d11vp9dec.h"
|
2020-02-28 09:14:51 +00:00
|
|
|
#include "gstd3d11vp8dec.h"
|
2021-01-10 16:06:24 +00:00
|
|
|
#include "gstd3d11mpeg2dec.h"
|
2021-06-14 09:49:20 +00:00
|
|
|
#include "gstd3d11av1dec.h"
|
2022-02-10 13:31:06 +00:00
|
|
|
#include "gstd3d11deinterlace.h"
|
2022-06-04 13:33:34 +00:00
|
|
|
#include "gstd3d11testsrc.h"
|
2022-02-10 13:31:06 +00:00
|
|
|
|
|
|
|
#if !GST_D3D11_WINAPI_ONLY_APP
|
2021-10-13 12:45:34 +00:00
|
|
|
#include "gstd3d11screencapturesrc.h"
|
|
|
|
#include "gstd3d11screencapturedevice.h"
|
2020-11-20 18:20:36 +00:00
|
|
|
#endif
|
2019-01-30 11:07:29 +00:00
|
|
|
|
2022-06-26 19:07:04 +00:00
|
|
|
#include <wrl.h>
|
|
|
|
|
|
|
|
/* *INDENT-OFF* */
|
|
|
|
using namespace Microsoft::WRL;
|
|
|
|
/* *INDENT-ON* */
|
|
|
|
|
2020-06-19 12:24:59 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_debug);
|
2020-12-20 17:47:45 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_plugin_utils_debug);
|
2019-12-04 15:53:40 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_format_debug);
|
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_device_debug);
|
2019-12-24 06:54:57 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_overlay_compositor_debug);
|
2019-12-30 09:58:59 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_window_debug);
|
2020-01-10 14:54:43 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_video_processor_debug);
|
2021-09-15 15:59:37 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_decoder_debug);
|
2019-12-26 05:24:46 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_h264_dec_debug);
|
2019-12-26 05:28:03 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_h265_dec_debug);
|
2019-12-20 14:05:52 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_vp9_dec_debug);
|
2020-02-28 09:14:51 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_vp8_dec_debug);
|
2021-01-10 16:06:24 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_mpeg2_dec_debug);
|
2021-06-14 09:49:20 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_av1_dec_debug);
|
2022-02-10 13:31:06 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_deinterlace_debug);
|
2019-12-26 05:24:46 +00:00
|
|
|
|
2022-02-10 13:31:06 +00:00
|
|
|
#if !GST_D3D11_WINAPI_ONLY_APP
|
2021-10-13 12:45:34 +00:00
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_screen_capture_debug);
|
|
|
|
GST_DEBUG_CATEGORY (gst_d3d11_screen_capture_device_debug);
|
2020-11-20 18:20:36 +00:00
|
|
|
#endif
|
|
|
|
|
2020-06-19 12:24:59 +00:00
|
|
|
#define GST_CAT_DEFAULT gst_d3d11_debug
|
|
|
|
|
2019-01-30 11:07:29 +00:00
|
|
|
static gboolean
|
|
|
|
plugin_init (GstPlugin * plugin)
|
|
|
|
{
|
2021-01-19 17:29:43 +00:00
|
|
|
GstRank video_sink_rank = GST_RANK_PRIMARY;
|
|
|
|
D3D_FEATURE_LEVEL max_feature_level = D3D_FEATURE_LEVEL_9_3;
|
2022-06-26 19:07:04 +00:00
|
|
|
HRESULT hr;
|
|
|
|
ComPtr < IDXGIFactory1 > factory;
|
2020-06-15 19:41:14 +00:00
|
|
|
|
2020-06-19 12:24:59 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_debug, "d3d11", 0, "direct3d 11 plugin");
|
2020-12-20 17:47:45 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_plugin_utils_debug,
|
|
|
|
"d3d11pluginutils", 0, "d3d11 plugin utility functions");
|
2019-12-24 06:54:57 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_overlay_compositor_debug,
|
|
|
|
"d3d11overlaycompositor", 0, "d3d11overlaycompositor");
|
2019-12-30 09:58:59 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_window_debug,
|
|
|
|
"d3d11window", 0, "d3d11window");
|
2020-01-10 14:54:43 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_video_processor_debug,
|
|
|
|
"d3d11videoprocessor", 0, "d3d11videoprocessor");
|
2019-12-24 06:54:57 +00:00
|
|
|
|
2022-06-15 18:57:37 +00:00
|
|
|
if (!gst_d3d11_compile_init ()) {
|
|
|
|
GST_WARNING ("Cannot initialize d3d11 compiler");
|
2020-06-19 12:24:59 +00:00
|
|
|
return TRUE;
|
|
|
|
}
|
2022-02-10 13:31:06 +00:00
|
|
|
|
2019-12-26 05:24:46 +00:00
|
|
|
/* DXVA2 API is availble since Windows 8 */
|
|
|
|
if (gst_d3d11_is_windows_8_or_greater ()) {
|
2021-09-15 15:59:37 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_decoder_debug,
|
|
|
|
"d3d11decoder", 0, "Direct3D11 Video Decoder object");
|
2019-12-26 05:24:46 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_h264_dec_debug,
|
|
|
|
"d3d11h264dec", 0, "Direct3D11 H.264 Video Decoder");
|
2019-12-20 14:05:52 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_vp9_dec_debug,
|
|
|
|
"d3d11vp9dec", 0, "Direct3D11 VP9 Video Decoder");
|
2019-12-26 05:28:03 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_h265_dec_debug,
|
|
|
|
"d3d11h265dec", 0, "Direct3D11 H.265 Video Decoder");
|
2020-02-28 09:14:51 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_vp8_dec_debug,
|
|
|
|
"d3d11vp8dec", 0, "Direct3D11 VP8 Decoder");
|
2021-01-10 16:06:24 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_mpeg2_dec_debug,
|
|
|
|
"d3d11mpeg2dec", 0, "Direct3D11 MPEG2 Decoder");
|
2021-06-14 09:49:20 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_av1_dec_debug,
|
|
|
|
"d3d11av1dec", 0, "Direct3D11 AV1 Decoder");
|
2022-02-10 13:31:06 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_deinterlace_debug,
|
|
|
|
"d3d11deinterlace", 0, "Direct3D11 Deinterlacer");
|
2021-01-19 17:29:43 +00:00
|
|
|
}
|
2021-01-21 15:10:28 +00:00
|
|
|
|
2022-06-26 19:07:04 +00:00
|
|
|
hr = CreateDXGIFactory1 (IID_PPV_ARGS (&factory));
|
|
|
|
if (FAILED (hr))
|
|
|
|
return TRUE;
|
|
|
|
|
2021-01-19 17:29:43 +00:00
|
|
|
/* Enumerate devices to register decoders per device and to get the highest
|
|
|
|
* feature level */
|
2022-06-26 19:07:04 +00:00
|
|
|
for (guint i = 0;; i++) {
|
|
|
|
ComPtr < IDXGIAdapter1 > adapter;
|
|
|
|
GstD3D11Device *device;
|
2021-01-19 17:29:43 +00:00
|
|
|
ID3D11Device *device_handle;
|
|
|
|
D3D_FEATURE_LEVEL feature_level;
|
2019-12-26 05:24:46 +00:00
|
|
|
|
2022-06-26 19:07:04 +00:00
|
|
|
hr = factory->EnumAdapters1 (i, &adapter);
|
|
|
|
if (FAILED (hr))
|
|
|
|
break;
|
|
|
|
|
2021-01-19 17:29:43 +00:00
|
|
|
device = gst_d3d11_device_new (i, D3D11_CREATE_DEVICE_BGRA_SUPPORT);
|
|
|
|
if (!device)
|
2022-06-26 19:07:04 +00:00
|
|
|
continue;
|
2021-01-19 17:29:43 +00:00
|
|
|
|
|
|
|
device_handle = gst_d3d11_device_get_device_handle (device);
|
2021-09-10 15:43:26 +00:00
|
|
|
feature_level = device_handle->GetFeatureLevel ();
|
2021-01-19 17:29:43 +00:00
|
|
|
|
|
|
|
if (feature_level > max_feature_level)
|
|
|
|
max_feature_level = feature_level;
|
|
|
|
|
|
|
|
/* DXVA2 API is availble since Windows 8 */
|
2021-09-15 15:59:37 +00:00
|
|
|
if (gst_d3d11_is_windows_8_or_greater () &&
|
|
|
|
gst_d3d11_device_get_video_device_handle (device)) {
|
|
|
|
gboolean legacy = gst_d3d11_decoder_util_is_legacy_device (device);
|
2020-02-14 16:23:32 +00:00
|
|
|
|
2022-02-08 18:27:41 +00:00
|
|
|
/* avdec_h264 has primary rank, make this higher than it */
|
|
|
|
gst_d3d11_h264_dec_register (plugin,
|
|
|
|
device, GST_RANK_PRIMARY + 1, legacy);
|
2020-02-14 16:23:32 +00:00
|
|
|
if (!legacy) {
|
2022-04-27 15:48:35 +00:00
|
|
|
/* avdec_h265 has primary rank, make this higher than it */
|
|
|
|
gst_d3d11_h265_dec_register (plugin, device, GST_RANK_PRIMARY + 1);
|
2022-02-08 18:27:41 +00:00
|
|
|
gst_d3d11_vp9_dec_register (plugin, device, GST_RANK_PRIMARY);
|
|
|
|
gst_d3d11_vp8_dec_register (plugin, device, GST_RANK_PRIMARY);
|
2022-11-30 18:52:53 +00:00
|
|
|
/* rust dav1ddec has "primary" rank */
|
|
|
|
gst_d3d11_av1_dec_register (plugin, device, GST_RANK_PRIMARY + 1);
|
2023-02-21 10:29:18 +00:00
|
|
|
/* avdec_mpeg2video has primary rank */
|
|
|
|
gst_d3d11_mpeg2_dec_register (plugin, device, GST_RANK_PRIMARY + 1);
|
2020-02-14 16:23:32 +00:00
|
|
|
}
|
2019-12-26 05:24:46 +00:00
|
|
|
|
2022-02-10 13:31:06 +00:00
|
|
|
gst_d3d11_deinterlace_register (plugin, device, GST_RANK_MARGINAL);
|
2021-01-21 15:10:28 +00:00
|
|
|
}
|
|
|
|
|
2021-01-19 17:29:43 +00:00
|
|
|
gst_object_unref (device);
|
|
|
|
}
|
|
|
|
|
|
|
|
/* FIXME: Our shader code is not compatible with D3D_FEATURE_LEVEL_9_3
|
|
|
|
* or lower. So HLSL compiler cannot understand our shader code and
|
|
|
|
* therefore d3d11colorconverter cannot be configured.
|
|
|
|
*
|
|
|
|
* Known D3D_FEATURE_LEVEL_9_3 driver is
|
|
|
|
* "VirtualBox Graphics Adapter (WDDM)"
|
|
|
|
* ... and there might be some more old physical devices which don't support
|
|
|
|
* D3D_FEATURE_LEVEL_10_0.
|
|
|
|
*/
|
|
|
|
if (max_feature_level < D3D_FEATURE_LEVEL_10_0)
|
|
|
|
video_sink_rank = GST_RANK_NONE;
|
|
|
|
|
|
|
|
gst_d3d11_plugin_utils_init (max_feature_level);
|
|
|
|
|
|
|
|
gst_element_register (plugin,
|
|
|
|
"d3d11upload", GST_RANK_NONE, GST_TYPE_D3D11_UPLOAD);
|
|
|
|
gst_element_register (plugin,
|
|
|
|
"d3d11download", GST_RANK_NONE, GST_TYPE_D3D11_DOWNLOAD);
|
|
|
|
gst_element_register (plugin,
|
|
|
|
"d3d11convert", GST_RANK_NONE, GST_TYPE_D3D11_CONVERT);
|
|
|
|
gst_element_register (plugin,
|
|
|
|
"d3d11colorconvert", GST_RANK_NONE, GST_TYPE_D3D11_COLOR_CONVERT);
|
|
|
|
gst_element_register (plugin,
|
|
|
|
"d3d11scale", GST_RANK_NONE, GST_TYPE_D3D11_SCALE);
|
|
|
|
gst_element_register (plugin,
|
2021-04-17 11:37:13 +00:00
|
|
|
"d3d11videosink", video_sink_rank, GST_TYPE_D3D11_VIDEO_SINK);
|
2021-01-19 17:29:43 +00:00
|
|
|
|
|
|
|
gst_element_register (plugin,
|
2022-06-18 11:14:22 +00:00
|
|
|
"d3d11compositor", GST_RANK_SECONDARY, GST_TYPE_D3D11_COMPOSITOR);
|
2022-06-04 13:33:34 +00:00
|
|
|
gst_element_register (plugin,
|
|
|
|
"d3d11testsrc", GST_RANK_NONE, GST_TYPE_D3D11_TEST_SRC);
|
2021-01-19 17:29:43 +00:00
|
|
|
|
2022-02-10 13:31:06 +00:00
|
|
|
#if !GST_D3D11_WINAPI_ONLY_APP
|
2020-11-20 18:20:36 +00:00
|
|
|
if (gst_d3d11_is_windows_8_or_greater ()) {
|
2021-10-13 12:45:34 +00:00
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_screen_capture_debug,
|
|
|
|
"d3d11screencapturesrc", 0, "d3d11screencapturesrc");
|
|
|
|
GST_DEBUG_CATEGORY_INIT (gst_d3d11_screen_capture_device_debug,
|
|
|
|
"d3d11screencapturedevice", 0, "d3d11screencapturedevice");
|
2021-10-05 12:49:38 +00:00
|
|
|
|
2020-11-20 18:20:36 +00:00
|
|
|
gst_element_register (plugin,
|
2021-10-13 12:45:34 +00:00
|
|
|
"d3d11screencapturesrc", GST_RANK_NONE,
|
|
|
|
GST_TYPE_D3D11_SCREEN_CAPTURE_SRC);
|
2021-10-05 12:49:38 +00:00
|
|
|
gst_device_provider_register (plugin,
|
2021-10-13 12:45:34 +00:00
|
|
|
"d3d11screencapturedeviceprovider", GST_RANK_PRIMARY,
|
|
|
|
GST_TYPE_D3D11_SCREEN_CAPTURE_DEVICE_PROVIDER);
|
2020-11-20 18:20:36 +00:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2019-11-06 10:38:31 +00:00
|
|
|
return TRUE;
|
2019-01-30 11:07:29 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
GST_PLUGIN_DEFINE (GST_VERSION_MAJOR,
|
|
|
|
GST_VERSION_MINOR,
|
|
|
|
d3d11,
|
|
|
|
"Direct3D11 plugin",
|
|
|
|
plugin_init, VERSION, "LGPL", GST_PACKAGE_NAME, GST_PACKAGE_ORIGIN)
|