mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2024-11-26 11:41:09 +00:00
d3d12memory: Add GstD3D12AllocationParams struct
Will be used for buffer pool configuration. And update C++ helper to reduce the number of required arguments Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5345>
This commit is contained in:
parent
73744df6e4
commit
c0572f8749
7 changed files with 171 additions and 21 deletions
|
@ -51,5 +51,7 @@ typedef struct _GstD3D12PoolAllocatorPrivate GstD3D12PoolAllocatorPrivate;
|
||||||
|
|
||||||
typedef struct _GstD3D12Format GstD3D12Format;
|
typedef struct _GstD3D12Format GstD3D12Format;
|
||||||
|
|
||||||
|
typedef struct _GstD3D12AllocationParams GstD3D12AllocationParams;
|
||||||
|
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
|
|
|
@ -460,7 +460,7 @@ gst_d3d12_decoder_configure (GstD3D12Decoder * decoder,
|
||||||
|
|
||||||
gst_d3d12_decoder_reset (decoder);
|
gst_d3d12_decoder_reset (decoder);
|
||||||
|
|
||||||
if (!gst_d3d12_device_get_device_format (priv->device,
|
if (!gst_d3d12_device_get_format (priv->device,
|
||||||
GST_VIDEO_INFO_FORMAT (info), &device_format) ||
|
GST_VIDEO_INFO_FORMAT (info), &device_format) ||
|
||||||
device_format.dxgi_format == DXGI_FORMAT_UNKNOWN) {
|
device_format.dxgi_format == DXGI_FORMAT_UNKNOWN) {
|
||||||
GST_ERROR_OBJECT (decoder, "Could not determine dxgi format from %s",
|
GST_ERROR_OBJECT (decoder, "Could not determine dxgi format from %s",
|
||||||
|
@ -526,13 +526,7 @@ gst_d3d12_decoder_prepare_allocator (GstD3D12Decoder * self)
|
||||||
D3D12_HEAP_PROPERTIES heap_prop =
|
D3D12_HEAP_PROPERTIES heap_prop =
|
||||||
CD3D12_HEAP_PROPERTIES (D3D12_HEAP_TYPE_DEFAULT);
|
CD3D12_HEAP_PROPERTIES (D3D12_HEAP_TYPE_DEFAULT);
|
||||||
D3D12_RESOURCE_DESC desc = CD3D12_RESOURCE_DESC::Tex2D (priv->decoder_format,
|
D3D12_RESOURCE_DESC desc = CD3D12_RESOURCE_DESC::Tex2D (priv->decoder_format,
|
||||||
priv->aligned_width,
|
priv->aligned_width, priv->aligned_height, resource_flags, array_size);
|
||||||
priv->aligned_height,
|
|
||||||
array_size,
|
|
||||||
1,
|
|
||||||
1,
|
|
||||||
0,
|
|
||||||
resource_flags);
|
|
||||||
|
|
||||||
priv->allocator = (GstD3D12Allocator *)
|
priv->allocator = (GstD3D12Allocator *)
|
||||||
gst_d3d12_pool_allocator_new (priv->device,
|
gst_d3d12_pool_allocator_new (priv->device,
|
||||||
|
@ -547,9 +541,7 @@ gst_d3d12_decoder_prepare_allocator (GstD3D12Decoder * self)
|
||||||
D3D12_RESOURCE_DESC ref_desc =
|
D3D12_RESOURCE_DESC ref_desc =
|
||||||
CD3D12_RESOURCE_DESC::Tex2D (priv->decoder_format,
|
CD3D12_RESOURCE_DESC::Tex2D (priv->decoder_format,
|
||||||
priv->aligned_width,
|
priv->aligned_width,
|
||||||
priv->aligned_height,
|
priv->aligned_height);
|
||||||
1,
|
|
||||||
1);
|
|
||||||
|
|
||||||
priv->output_allocator = (GstD3D12Allocator *)
|
priv->output_allocator = (GstD3D12Allocator *)
|
||||||
gst_d3d12_pool_allocator_new (priv->device, &heap_prop,
|
gst_d3d12_pool_allocator_new (priv->device, &heap_prop,
|
||||||
|
@ -974,10 +966,7 @@ gst_d3d12_decoder_ensure_staging_texture (GstD3D12Decoder * self)
|
||||||
ID3D12Device *device = gst_d3d12_device_get_device_handle (priv->device);
|
ID3D12Device *device = gst_d3d12_device_get_device_handle (priv->device);
|
||||||
D3D12_RESOURCE_DESC tex_desc =
|
D3D12_RESOURCE_DESC tex_desc =
|
||||||
CD3D12_RESOURCE_DESC::Tex2D (priv->decoder_format,
|
CD3D12_RESOURCE_DESC::Tex2D (priv->decoder_format,
|
||||||
priv->aligned_width,
|
priv->aligned_width, priv->aligned_height);
|
||||||
priv->aligned_height,
|
|
||||||
1,
|
|
||||||
1);
|
|
||||||
|
|
||||||
device->GetCopyableFootprints (&tex_desc, 0, 2, 0, priv->layout, nullptr,
|
device->GetCopyableFootprints (&tex_desc, 0, 2, 0, priv->layout, nullptr,
|
||||||
nullptr, &size);
|
nullptr, &size);
|
||||||
|
|
|
@ -713,7 +713,7 @@ gst_d3d12_device_get_factory_handle (GstD3D12Device * device)
|
||||||
}
|
}
|
||||||
|
|
||||||
gboolean
|
gboolean
|
||||||
gst_d3d12_device_get_device_format (GstD3D12Device * device,
|
gst_d3d12_device_get_format (GstD3D12Device * device,
|
||||||
GstVideoFormat format, GstD3D12Format * device_format)
|
GstVideoFormat format, GstD3D12Format * device_format)
|
||||||
{
|
{
|
||||||
g_return_val_if_fail (GST_IS_D3D12_DEVICE (device), FALSE);
|
g_return_val_if_fail (GST_IS_D3D12_DEVICE (device), FALSE);
|
||||||
|
|
|
@ -64,7 +64,7 @@ IDXGIAdapter1 * gst_d3d12_device_get_adapter_handle (GstD3D12Devic
|
||||||
|
|
||||||
IDXGIFactory2 * gst_d3d12_device_get_factory_handle (GstD3D12Device * device);
|
IDXGIFactory2 * gst_d3d12_device_get_factory_handle (GstD3D12Device * device);
|
||||||
|
|
||||||
gboolean gst_d3d12_device_get_device_format (GstD3D12Device * device,
|
gboolean gst_d3d12_device_get_format (GstD3D12Device * device,
|
||||||
GstVideoFormat format,
|
GstVideoFormat format,
|
||||||
GstD3D12Format * device_format);
|
GstD3D12Format * device_format);
|
||||||
|
|
||||||
|
|
|
@ -33,14 +33,143 @@
|
||||||
#include <atomic>
|
#include <atomic>
|
||||||
#include <queue>
|
#include <queue>
|
||||||
|
|
||||||
|
/* *INDENT-OFF* */
|
||||||
|
using namespace Microsoft::WRL;
|
||||||
|
/* *INDENT-ON* */
|
||||||
|
|
||||||
GST_DEBUG_CATEGORY_EXTERN (gst_d3d12_allocator_debug);
|
GST_DEBUG_CATEGORY_EXTERN (gst_d3d12_allocator_debug);
|
||||||
#define GST_CAT_DEFAULT gst_d3d12_allocator_debug
|
#define GST_CAT_DEFAULT gst_d3d12_allocator_debug
|
||||||
|
|
||||||
static GstD3D12Allocator *_d3d12_memory_allocator = nullptr;
|
static GstD3D12Allocator *_d3d12_memory_allocator = nullptr;
|
||||||
|
|
||||||
/* *INDENT-OFF* */
|
static gint
|
||||||
using namespace Microsoft::WRL;
|
gst_d3d12_allocation_params_compare (const GstD3D12AllocationParams * p1,
|
||||||
|
const GstD3D12AllocationParams * p2)
|
||||||
|
{
|
||||||
|
g_return_val_if_fail (p1, -1);
|
||||||
|
g_return_val_if_fail (p2, -1);
|
||||||
|
|
||||||
|
if (p1 == p2)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gst_d3d12_allocation_params_init (GType type)
|
||||||
|
{
|
||||||
|
static GstValueTable table = {
|
||||||
|
0, (GstValueCompareFunc) gst_d3d12_allocation_params_compare,
|
||||||
|
nullptr, nullptr
|
||||||
|
};
|
||||||
|
|
||||||
|
table.type = type;
|
||||||
|
gst_value_register (&table);
|
||||||
|
}
|
||||||
|
|
||||||
|
G_DEFINE_BOXED_TYPE_WITH_CODE (GstD3D12AllocationParams,
|
||||||
|
gst_d3d12_allocation_params,
|
||||||
|
(GBoxedCopyFunc) gst_d3d12_allocation_params_copy,
|
||||||
|
(GBoxedFreeFunc) gst_d3d12_allocation_params_free,
|
||||||
|
gst_d3d12_allocation_params_init (g_define_type_id));
|
||||||
|
|
||||||
|
GstD3D12AllocationParams *
|
||||||
|
gst_d3d12_allocation_params_new (GstD3D12Device * device,
|
||||||
|
const GstVideoInfo * info, GstD3D12AllocationFlags flags,
|
||||||
|
D3D12_RESOURCE_FLAGS resource_flags)
|
||||||
|
{
|
||||||
|
GstD3D12AllocationParams *ret;
|
||||||
|
GstD3D12Format d3d12_format;
|
||||||
|
GstVideoFormat format;
|
||||||
|
|
||||||
|
g_return_val_if_fail (GST_IS_D3D12_DEVICE (device), nullptr);
|
||||||
|
g_return_val_if_fail (info, nullptr);
|
||||||
|
|
||||||
|
format = GST_VIDEO_INFO_FORMAT (info);
|
||||||
|
if (!gst_d3d12_device_get_format (device, format, &d3d12_format)) {
|
||||||
|
GST_WARNING_OBJECT (device, "%s is not supported",
|
||||||
|
gst_video_format_to_string (format));
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
ret = g_new0 (GstD3D12AllocationParams, 1);
|
||||||
|
ret->info = *info;
|
||||||
|
ret->aligned_info = *info;
|
||||||
|
ret->d3d12_format = d3d12_format;
|
||||||
|
|
||||||
|
if (d3d12_format.dxgi_format == DXGI_FORMAT_UNKNOWN) {
|
||||||
|
for (guint i = 0; i < GST_VIDEO_INFO_N_PLANES (info); i++) {
|
||||||
|
g_assert (d3d12_format.resource_format[i] != DXGI_FORMAT_UNKNOWN);
|
||||||
|
|
||||||
|
ret->desc[i] =
|
||||||
|
CD3D12_RESOURCE_DESC::Tex2D (d3d12_format.resource_format[i],
|
||||||
|
GST_VIDEO_INFO_COMP_WIDTH (info, i),
|
||||||
|
GST_VIDEO_INFO_COMP_HEIGHT (info, i), resource_flags);
|
||||||
|
}
|
||||||
|
} else {
|
||||||
|
ret->desc[0] = CD3D12_RESOURCE_DESC::Tex2D (d3d12_format.dxgi_format,
|
||||||
|
info->width, info->height, resource_flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
ret->flags = flags;
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
|
||||||
|
GstD3D12AllocationParams *
|
||||||
|
gst_d3d12_allocation_params_copy (GstD3D12AllocationParams * src)
|
||||||
|
{
|
||||||
|
GstD3D12AllocationParams *dst;
|
||||||
|
|
||||||
|
g_return_val_if_fail (src != NULL, NULL);
|
||||||
|
|
||||||
|
dst = g_new0 (GstD3D12AllocationParams, 1);
|
||||||
|
memcpy (dst, src, sizeof (GstD3D12AllocationParams));
|
||||||
|
|
||||||
|
return dst;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
gst_d3d12_allocation_params_free (GstD3D12AllocationParams * params)
|
||||||
|
{
|
||||||
|
g_free (params);
|
||||||
|
}
|
||||||
|
|
||||||
|
gboolean
|
||||||
|
gst_d3d12_allocation_params_alignment (GstD3D12AllocationParams * params,
|
||||||
|
const GstVideoAlignment * align)
|
||||||
|
{
|
||||||
|
guint padding_width, padding_height;
|
||||||
|
GstVideoInfo *info;
|
||||||
|
GstVideoInfo new_info;
|
||||||
|
|
||||||
|
g_return_val_if_fail (params, FALSE);
|
||||||
|
g_return_val_if_fail (align, FALSE);
|
||||||
|
|
||||||
|
/* d3d11 does not support stride align. Consider padding only */
|
||||||
|
padding_width = align->padding_left + align->padding_right;
|
||||||
|
padding_height = align->padding_top + align->padding_bottom;
|
||||||
|
|
||||||
|
info = ¶ms->info;
|
||||||
|
|
||||||
|
if (!gst_video_info_set_format (&new_info, GST_VIDEO_INFO_FORMAT (info),
|
||||||
|
GST_VIDEO_INFO_WIDTH (info) + padding_width,
|
||||||
|
GST_VIDEO_INFO_HEIGHT (info) + padding_height)) {
|
||||||
|
GST_WARNING ("Set format failed");
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
|
||||||
|
params->aligned_info = new_info;
|
||||||
|
|
||||||
|
for (guint i = 0; i < GST_VIDEO_INFO_N_PLANES (info); i++) {
|
||||||
|
params->desc[i].Width = GST_VIDEO_INFO_COMP_WIDTH (&new_info, i);
|
||||||
|
params->desc[i].Height = GST_VIDEO_INFO_COMP_HEIGHT (&new_info, i);
|
||||||
|
}
|
||||||
|
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* *INDENT-OFF* */
|
||||||
struct _GstD3D12MemoryPrivate
|
struct _GstD3D12MemoryPrivate
|
||||||
{
|
{
|
||||||
ComPtr<ID3D12Resource> resource;
|
ComPtr<ID3D12Resource> resource;
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <gst/gst.h>
|
#include <gst/gst.h>
|
||||||
#include <gst/video/video.h>
|
#include <gst/video/video.h>
|
||||||
#include "gstd3d12_fwd.h"
|
#include "gstd3d12_fwd.h"
|
||||||
|
#include "gstd3d12format.h"
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
|
@ -78,6 +79,35 @@ typedef enum
|
||||||
GST_D3D12_MEMORY_TRANSFER_NEED_UPLOAD = (GST_MEMORY_FLAG_LAST << 1)
|
GST_D3D12_MEMORY_TRANSFER_NEED_UPLOAD = (GST_MEMORY_FLAG_LAST << 1)
|
||||||
} GstD3D12MemoryTransfer;
|
} GstD3D12MemoryTransfer;
|
||||||
|
|
||||||
|
typedef enum
|
||||||
|
{
|
||||||
|
GST_D3D12_ALLOCATION_FLAG_DEFAULT = 0,
|
||||||
|
GST_D3D12_ALLOCATION_FLAG_TEXTURE_ARRAY = (1 << 0),
|
||||||
|
} GstD3D12AllocationFlags;
|
||||||
|
|
||||||
|
struct _GstD3D12AllocationParams
|
||||||
|
{
|
||||||
|
D3D12_RESOURCE_DESC desc[GST_VIDEO_MAX_PLANES];
|
||||||
|
GstVideoInfo info;
|
||||||
|
GstVideoInfo aligned_info;
|
||||||
|
GstD3D12Format d3d12_format;
|
||||||
|
GstD3D12AllocationFlags flags;
|
||||||
|
};
|
||||||
|
|
||||||
|
GType gst_d3d12_allocation_params_get_type (void);
|
||||||
|
|
||||||
|
GstD3D12AllocationParams * gst_d3d12_allocation_params_new (GstD3D12Device * device,
|
||||||
|
const GstVideoInfo * info,
|
||||||
|
GstD3D12AllocationFlags flags,
|
||||||
|
D3D12_RESOURCE_FLAGS resource_flags);
|
||||||
|
|
||||||
|
GstD3D12AllocationParams * gst_d3d12_allocation_params_copy (GstD3D12AllocationParams * src);
|
||||||
|
|
||||||
|
void gst_d3d12_allocation_params_free (GstD3D12AllocationParams * params);
|
||||||
|
|
||||||
|
gboolean gst_d3d12_allocation_params_alignment (GstD3D12AllocationParams * parms,
|
||||||
|
const GstVideoAlignment * align);
|
||||||
|
|
||||||
struct _GstD3D12Memory
|
struct _GstD3D12Memory
|
||||||
{
|
{
|
||||||
GstMemory mem;
|
GstMemory mem;
|
||||||
|
|
|
@ -143,11 +143,11 @@ struct CD3D12_RESOURCE_DESC : public D3D12_RESOURCE_DESC
|
||||||
DXGI_FORMAT format,
|
DXGI_FORMAT format,
|
||||||
UINT64 width,
|
UINT64 width,
|
||||||
UINT height,
|
UINT height,
|
||||||
|
D3D12_RESOURCE_FLAGS flags = D3D12_RESOURCE_FLAG_NONE,
|
||||||
UINT16 array_size = 1,
|
UINT16 array_size = 1,
|
||||||
UINT16 mip_levels = 0,
|
UINT16 mip_levels = 1,
|
||||||
UINT sample_count = 1,
|
UINT sample_count = 1,
|
||||||
UINT sample_quality = 0,
|
UINT sample_quality = 0,
|
||||||
D3D12_RESOURCE_FLAGS flags = D3D12_RESOURCE_FLAG_NONE,
|
|
||||||
D3D12_TEXTURE_LAYOUT layout = D3D12_TEXTURE_LAYOUT_UNKNOWN,
|
D3D12_TEXTURE_LAYOUT layout = D3D12_TEXTURE_LAYOUT_UNKNOWN,
|
||||||
UINT64 alignment = 0)
|
UINT64 alignment = 0)
|
||||||
{
|
{
|
||||||
|
|
Loading…
Reference in a new issue