d3d11/tests: Add format compatibility tests for DXGI_FORMAT_R9G9B9E5_SHAREDEXP.
Signed-off-by: Henri Verbeet <hverbeet@codeweavers.com> Signed-off-by: Alexandre Julliard <julliard@winehq.org>
This commit is contained in:
parent
4cec31aaad
commit
70c09cd89d
|
@ -27846,6 +27846,13 @@ static void test_format_compatibility(void)
|
||||||
{DXGI_FORMAT_R16G16_SNORM, DXGI_FORMAT_R16G16_SINT, 4, TRUE},
|
{DXGI_FORMAT_R16G16_SNORM, DXGI_FORMAT_R16G16_SINT, 4, TRUE},
|
||||||
{DXGI_FORMAT_R16G16_SINT, DXGI_FORMAT_R16G16_TYPELESS, 4, TRUE},
|
{DXGI_FORMAT_R16G16_SINT, DXGI_FORMAT_R16G16_TYPELESS, 4, TRUE},
|
||||||
{DXGI_FORMAT_R16G16_TYPELESS, DXGI_FORMAT_R32_TYPELESS, 4, FALSE},
|
{DXGI_FORMAT_R16G16_TYPELESS, DXGI_FORMAT_R32_TYPELESS, 4, FALSE},
|
||||||
|
{DXGI_FORMAT_R9G9B9E5_SHAREDEXP, DXGI_FORMAT_R32_TYPELESS, 4, TRUE},
|
||||||
|
{DXGI_FORMAT_R9G9B9E5_SHAREDEXP, DXGI_FORMAT_R32_FLOAT, 4, TRUE},
|
||||||
|
{DXGI_FORMAT_R9G9B9E5_SHAREDEXP, DXGI_FORMAT_R32_UINT, 4, TRUE},
|
||||||
|
{DXGI_FORMAT_R9G9B9E5_SHAREDEXP, DXGI_FORMAT_R32_SINT, 4, TRUE},
|
||||||
|
{DXGI_FORMAT_R9G9B9E5_SHAREDEXP, DXGI_FORMAT_R8G8B8A8_TYPELESS, 4, FALSE},
|
||||||
|
{DXGI_FORMAT_R9G9B9E5_SHAREDEXP, DXGI_FORMAT_B8G8R8A8_TYPELESS, 4, FALSE},
|
||||||
|
{DXGI_FORMAT_R9G9B9E5_SHAREDEXP, DXGI_FORMAT_R16G16_TYPELESS, 4, FALSE},
|
||||||
{DXGI_FORMAT_R32G32_TYPELESS, DXGI_FORMAT_R32G32_FLOAT, 8, TRUE},
|
{DXGI_FORMAT_R32G32_TYPELESS, DXGI_FORMAT_R32G32_FLOAT, 8, TRUE},
|
||||||
{DXGI_FORMAT_R32G32_FLOAT, DXGI_FORMAT_R32G32_UINT, 8, TRUE},
|
{DXGI_FORMAT_R32G32_FLOAT, DXGI_FORMAT_R32G32_UINT, 8, TRUE},
|
||||||
{DXGI_FORMAT_R32G32_UINT, DXGI_FORMAT_R32G32_SINT, 8, TRUE},
|
{DXGI_FORMAT_R32G32_UINT, DXGI_FORMAT_R32G32_SINT, 8, TRUE},
|
||||||
|
@ -27879,6 +27886,7 @@ static void test_format_compatibility(void)
|
||||||
for (i = 0; i < ARRAY_SIZE(test_data); ++i)
|
for (i = 0; i < ARRAY_SIZE(test_data); ++i)
|
||||||
{
|
{
|
||||||
unsigned int x, y, texel_dwords;
|
unsigned int x, y, texel_dwords;
|
||||||
|
BOOL broken = FALSE;
|
||||||
D3D11_BOX box;
|
D3D11_BOX box;
|
||||||
|
|
||||||
texture_desc.Width = sizeof(bitmap_data) / (texture_desc.Height * test_data[i].texel_size);
|
texture_desc.Width = sizeof(bitmap_data) / (texture_desc.Height * test_data[i].texel_size);
|
||||||
|
@ -27906,13 +27914,21 @@ static void test_format_compatibility(void)
|
||||||
|
|
||||||
texel_dwords = test_data[i].texel_size / sizeof(DWORD);
|
texel_dwords = test_data[i].texel_size / sizeof(DWORD);
|
||||||
get_texture_readback(dst_texture, 0, &rb);
|
get_texture_readback(dst_texture, 0, &rb);
|
||||||
for (j = 0; j < ARRAY_SIZE(bitmap_data); ++j)
|
colour = get_readback_color(&rb, 0, 0, 0);
|
||||||
|
if (test_data[i].src_format == DXGI_FORMAT_R9G9B9E5_SHAREDEXP && colour == bitmap_data[0])
|
||||||
|
{
|
||||||
|
win_skip("Broken destination offset for %#x -> %#x copy.\n",
|
||||||
|
test_data[i].src_format, test_data[i].dst_format);
|
||||||
|
broken = TRUE;
|
||||||
|
}
|
||||||
|
for (j = 0; j < ARRAY_SIZE(bitmap_data) && !broken; ++j)
|
||||||
{
|
{
|
||||||
x = j % 4;
|
x = j % 4;
|
||||||
y = j / 4;
|
y = j / 4;
|
||||||
colour = get_readback_color(&rb, x, y, 0);
|
colour = get_readback_color(&rb, x, y, 0);
|
||||||
expected = test_data[i].success && x >= texel_dwords && y
|
expected = test_data[i].success && x >= texel_dwords && y
|
||||||
? bitmap_data[j - (4 + texel_dwords)] : initial_data[j];
|
? bitmap_data[j - (4 + texel_dwords)] : initial_data[j];
|
||||||
|
todo_wine_if(test_data[i].src_format == DXGI_FORMAT_R9G9B9E5_SHAREDEXP && expected)
|
||||||
ok(colour == expected, "Test %u: Got unexpected colour 0x%08x at (%u, %u), expected 0x%08x.\n",
|
ok(colour == expected, "Test %u: Got unexpected colour 0x%08x at (%u, %u), expected 0x%08x.\n",
|
||||||
i, colour, x, y, expected);
|
i, colour, x, y, expected);
|
||||||
}
|
}
|
||||||
|
@ -27927,6 +27943,7 @@ static void test_format_compatibility(void)
|
||||||
y = j / 4;
|
y = j / 4;
|
||||||
colour = get_readback_color(&rb, x, y, 0);
|
colour = get_readback_color(&rb, x, y, 0);
|
||||||
expected = test_data[i].success ? bitmap_data[j] : initial_data[j];
|
expected = test_data[i].success ? bitmap_data[j] : initial_data[j];
|
||||||
|
todo_wine_if(test_data[i].src_format == DXGI_FORMAT_R9G9B9E5_SHAREDEXP && expected)
|
||||||
ok(colour == expected, "Test %u: Got unexpected colour 0x%08x at (%u, %u), expected 0x%08x.\n",
|
ok(colour == expected, "Test %u: Got unexpected colour 0x%08x at (%u, %u), expected 0x%08x.\n",
|
||||||
i, colour, x, y, expected);
|
i, colour, x, y, expected);
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue