d3d11: Report D3D11_FORMAT_SUPPORT_IA_VERTEX_BUFFER.

Signed-off-by: Zebediah Figura <zfigura@codeweavers.com>
Signed-off-by: Henri Verbeet <hverbeet@codeweavers.com>
Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
Zebediah Figura 2022-01-21 11:52:17 -06:00 committed by Alexandre Julliard
parent 98d3624f23
commit 59636714e7
4 changed files with 13 additions and 6 deletions

View File

@ -13630,7 +13630,7 @@ static void check_format_support(const unsigned int *format_support,
continue; continue;
} }
todo_wine todo_wine_if (feature_flag != D3D11_FORMAT_SUPPORT_IA_VERTEX_BUFFER)
ok(supported, "Format %#x - %s supported, format support %#x.\n", ok(supported, "Format %#x - %s supported, format support %#x.\n",
format, feature_name, format_support[format]); format, feature_name, format_support[format]);
} }

View File

@ -3757,6 +3757,7 @@ static HRESULT STDMETHODCALLTYPE d3d11_device_CheckFormatSupport(ID3D11Device2 *
flag_mapping[] = flag_mapping[] =
{ {
{WINED3D_RTYPE_BUFFER, WINED3D_BIND_SHADER_RESOURCE, 0, D3D11_FORMAT_SUPPORT_BUFFER}, {WINED3D_RTYPE_BUFFER, WINED3D_BIND_SHADER_RESOURCE, 0, D3D11_FORMAT_SUPPORT_BUFFER},
{WINED3D_RTYPE_BUFFER, WINED3D_BIND_VERTEX_BUFFER, 0, D3D11_FORMAT_SUPPORT_IA_VERTEX_BUFFER},
{WINED3D_RTYPE_TEXTURE_1D, WINED3D_BIND_SHADER_RESOURCE, 0, D3D11_FORMAT_SUPPORT_TEXTURE1D}, {WINED3D_RTYPE_TEXTURE_1D, WINED3D_BIND_SHADER_RESOURCE, 0, D3D11_FORMAT_SUPPORT_TEXTURE1D},
{WINED3D_RTYPE_TEXTURE_2D, WINED3D_BIND_SHADER_RESOURCE, 0, D3D11_FORMAT_SUPPORT_TEXTURE2D}, {WINED3D_RTYPE_TEXTURE_2D, WINED3D_BIND_SHADER_RESOURCE, 0, D3D11_FORMAT_SUPPORT_TEXTURE2D},
{WINED3D_RTYPE_TEXTURE_3D, WINED3D_BIND_SHADER_RESOURCE, 0, D3D11_FORMAT_SUPPORT_TEXTURE3D}, {WINED3D_RTYPE_TEXTURE_3D, WINED3D_BIND_SHADER_RESOURCE, 0, D3D11_FORMAT_SUPPORT_TEXTURE3D},

View File

@ -20645,7 +20645,8 @@ static void check_format_support(const unsigned int *format_support, D3D_FEATURE
if (formats[i].fl_required <= feature_level) if (formats[i].fl_required <= feature_level)
{ {
todo_wine ok(supported, "Format %#x - %s not supported, feature_level %#x, format support %#x.\n", todo_wine_if (feature_flag != D3D11_FORMAT_SUPPORT_IA_VERTEX_BUFFER)
ok(supported, "Format %#x - %s not supported, feature_level %#x, format support %#x.\n",
format, feature_name, feature_level, format_support[format]); format, feature_name, feature_level, format_support[format]);
continue; continue;
} }
@ -20658,6 +20659,7 @@ static void check_format_support(const unsigned int *format_support, D3D_FEATURE
continue; continue;
} }
todo_wine_if (feature_flag == D3D11_FORMAT_SUPPORT_IA_VERTEX_BUFFER)
ok(!supported, "Format %#x - %s supported, feature level %#x, format support %#x.\n", ok(!supported, "Format %#x - %s supported, feature level %#x, format support %#x.\n",
format, feature_name, feature_level, format_support[format]); format, feature_name, feature_level, format_support[format]);
} }

View File

@ -1821,7 +1821,8 @@ HRESULT CDECL wined3d_check_device_format(const struct wined3d *wined3d,
allowed_usage = WINED3DUSAGE_DYNAMIC; allowed_usage = WINED3DUSAGE_DYNAMIC;
allowed_bind_flags = WINED3D_BIND_SHADER_RESOURCE allowed_bind_flags = WINED3D_BIND_SHADER_RESOURCE
| WINED3D_BIND_UNORDERED_ACCESS; | WINED3D_BIND_UNORDERED_ACCESS
| WINED3D_BIND_VERTEX_BUFFER;
gl_type = gl_type_end = WINED3D_GL_RES_TYPE_BUFFER; gl_type = gl_type_end = WINED3D_GL_RES_TYPE_BUFFER;
break; break;
@ -1853,6 +1854,9 @@ HRESULT CDECL wined3d_check_device_format(const struct wined3d *wined3d,
format_flags |= WINED3DFMT_FLAG_DEPTH_STENCIL; format_flags |= WINED3DFMT_FLAG_DEPTH_STENCIL;
if (bind_flags & WINED3D_BIND_UNORDERED_ACCESS) if (bind_flags & WINED3D_BIND_UNORDERED_ACCESS)
format_flags |= WINED3DFMT_FLAG_UNORDERED_ACCESS; format_flags |= WINED3DFMT_FLAG_UNORDERED_ACCESS;
if (bind_flags & WINED3D_BIND_VERTEX_BUFFER)
format_flags |= WINED3DFMT_FLAG_VERTEX_ATTRIBUTE;
if (usage & WINED3DUSAGE_QUERY_FILTER) if (usage & WINED3DUSAGE_QUERY_FILTER)
format_flags |= WINED3DFMT_FLAG_FILTERING; format_flags |= WINED3DFMT_FLAG_FILTERING;
if (usage & WINED3DUSAGE_QUERY_POSTPIXELSHADER_BLENDING) if (usage & WINED3DUSAGE_QUERY_POSTPIXELSHADER_BLENDING)