wined3d: Move volume DXTn handling to apply_format_fixups.
This commit is contained in:
parent
978fe23218
commit
7109bebd02
|
@ -5953,7 +5953,7 @@ static void test_volume_blocks(void)
|
||||||
D3DLOCKED_BOX locked_box;
|
D3DLOCKED_BOX locked_box;
|
||||||
BYTE *base;
|
BYTE *base;
|
||||||
INT expected_row_pitch, expected_slice_pitch;
|
INT expected_row_pitch, expected_slice_pitch;
|
||||||
BOOL support, support_2d;
|
BOOL support;
|
||||||
BOOL pow2;
|
BOOL pow2;
|
||||||
unsigned int offset, expected_offset;
|
unsigned int offset, expected_offset;
|
||||||
|
|
||||||
|
@ -5977,9 +5977,6 @@ static void test_volume_blocks(void)
|
||||||
hr = IDirect3D8_CheckDeviceFormat(d3d8, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, D3DFMT_X8R8G8B8,
|
hr = IDirect3D8_CheckDeviceFormat(d3d8, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, D3DFMT_X8R8G8B8,
|
||||||
0, D3DRTYPE_VOLUMETEXTURE, formats[i].fmt);
|
0, D3DRTYPE_VOLUMETEXTURE, formats[i].fmt);
|
||||||
support = SUCCEEDED(hr);
|
support = SUCCEEDED(hr);
|
||||||
hr = IDirect3D8_CheckDeviceFormat(d3d8, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, D3DFMT_X8R8G8B8,
|
|
||||||
0, D3DRTYPE_TEXTURE, formats[i].fmt);
|
|
||||||
support_2d = SUCCEEDED(hr);
|
|
||||||
|
|
||||||
/* Test creation restrictions */
|
/* Test creation restrictions */
|
||||||
for (w = 1; w <= 8; w++)
|
for (w = 1; w <= 8; w++)
|
||||||
|
@ -6000,7 +5997,6 @@ static void test_volume_blocks(void)
|
||||||
for (j = 0; j < sizeof(create_tests) / sizeof(*create_tests); j++)
|
for (j = 0; j < sizeof(create_tests) / sizeof(*create_tests); j++)
|
||||||
{
|
{
|
||||||
BOOL may_succeed = FALSE;
|
BOOL may_succeed = FALSE;
|
||||||
BOOL todo = FALSE;
|
|
||||||
|
|
||||||
if (create_tests[j].need_runtime_support && !formats[i].core_fmt && !support)
|
if (create_tests[j].need_runtime_support && !formats[i].core_fmt && !support)
|
||||||
expect_hr = D3DERR_INVALIDCALL;
|
expect_hr = D3DERR_INVALIDCALL;
|
||||||
|
@ -6009,10 +6005,7 @@ static void test_volume_blocks(void)
|
||||||
else if (pow2 && !size_is_pow2 && create_tests[j].need_driver_support)
|
else if (pow2 && !size_is_pow2 && create_tests[j].need_driver_support)
|
||||||
expect_hr = D3DERR_INVALIDCALL;
|
expect_hr = D3DERR_INVALIDCALL;
|
||||||
else if (create_tests[j].need_driver_support && !support)
|
else if (create_tests[j].need_driver_support && !support)
|
||||||
{
|
|
||||||
todo = support_2d;
|
|
||||||
expect_hr = D3DERR_INVALIDCALL;
|
expect_hr = D3DERR_INVALIDCALL;
|
||||||
}
|
|
||||||
else
|
else
|
||||||
expect_hr = D3D_OK;
|
expect_hr = D3D_OK;
|
||||||
|
|
||||||
|
@ -6028,18 +6021,9 @@ static void test_volume_blocks(void)
|
||||||
if (!formats[i].core_fmt && !support && FAILED(expect_hr))
|
if (!formats[i].core_fmt && !support && FAILED(expect_hr))
|
||||||
may_succeed = TRUE;
|
may_succeed = TRUE;
|
||||||
|
|
||||||
if (todo)
|
|
||||||
{
|
|
||||||
todo_wine ok(hr == expect_hr || ((SUCCEEDED(hr) && may_succeed)),
|
|
||||||
"Got unexpected hr %#x for format %s, pool %s, size %ux%ux%u.\n",
|
|
||||||
hr, formats[i].name, create_tests[j].name, w, h, d);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ok(hr == expect_hr || ((SUCCEEDED(hr) && may_succeed)),
|
ok(hr == expect_hr || ((SUCCEEDED(hr) && may_succeed)),
|
||||||
"Got unexpected hr %#x for format %s, pool %s, size %ux%ux%u.\n",
|
"Got unexpected hr %#x for format %s, pool %s, size %ux%ux%u.\n",
|
||||||
hr, formats[i].name, create_tests[j].name, w, h, d);
|
hr, formats[i].name, create_tests[j].name, w, h, d);
|
||||||
}
|
|
||||||
|
|
||||||
if (FAILED(hr))
|
if (FAILED(hr))
|
||||||
ok(texture == NULL, "Got texture ptr %p, expected NULL.\n", texture);
|
ok(texture == NULL, "Got texture ptr %p, expected NULL.\n", texture);
|
||||||
|
|
|
@ -8567,7 +8567,7 @@ static void test_volume_blocks(void)
|
||||||
D3DLOCKED_BOX locked_box;
|
D3DLOCKED_BOX locked_box;
|
||||||
BYTE *base;
|
BYTE *base;
|
||||||
INT expected_row_pitch, expected_slice_pitch;
|
INT expected_row_pitch, expected_slice_pitch;
|
||||||
BOOL support, support_2d;
|
BOOL support;
|
||||||
BOOL pow2;
|
BOOL pow2;
|
||||||
unsigned int offset, expected_offset;
|
unsigned int offset, expected_offset;
|
||||||
|
|
||||||
|
@ -8591,9 +8591,6 @@ static void test_volume_blocks(void)
|
||||||
hr = IDirect3D9_CheckDeviceFormat(d3d9, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, D3DFMT_X8R8G8B8,
|
hr = IDirect3D9_CheckDeviceFormat(d3d9, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, D3DFMT_X8R8G8B8,
|
||||||
0, D3DRTYPE_VOLUMETEXTURE, formats[i].fmt);
|
0, D3DRTYPE_VOLUMETEXTURE, formats[i].fmt);
|
||||||
support = SUCCEEDED(hr);
|
support = SUCCEEDED(hr);
|
||||||
hr = IDirect3D9_CheckDeviceFormat(d3d9, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, D3DFMT_X8R8G8B8,
|
|
||||||
0, D3DRTYPE_TEXTURE, formats[i].fmt);
|
|
||||||
support_2d = SUCCEEDED(hr);
|
|
||||||
|
|
||||||
/* Test creation restrictions */
|
/* Test creation restrictions */
|
||||||
for (w = 1; w <= 8; w++)
|
for (w = 1; w <= 8; w++)
|
||||||
|
@ -8614,7 +8611,6 @@ static void test_volume_blocks(void)
|
||||||
for (j = 0; j < sizeof(create_tests) / sizeof(*create_tests); j++)
|
for (j = 0; j < sizeof(create_tests) / sizeof(*create_tests); j++)
|
||||||
{
|
{
|
||||||
BOOL may_succeed = FALSE;
|
BOOL may_succeed = FALSE;
|
||||||
BOOL todo = FALSE;
|
|
||||||
|
|
||||||
if (create_tests[j].need_runtime_support && !formats[i].core_fmt && !support)
|
if (create_tests[j].need_runtime_support && !formats[i].core_fmt && !support)
|
||||||
expect_hr = D3DERR_INVALIDCALL;
|
expect_hr = D3DERR_INVALIDCALL;
|
||||||
|
@ -8623,10 +8619,7 @@ static void test_volume_blocks(void)
|
||||||
else if (pow2 && !size_is_pow2 && create_tests[j].need_driver_support)
|
else if (pow2 && !size_is_pow2 && create_tests[j].need_driver_support)
|
||||||
expect_hr = D3DERR_INVALIDCALL;
|
expect_hr = D3DERR_INVALIDCALL;
|
||||||
else if (create_tests[j].need_driver_support && !support)
|
else if (create_tests[j].need_driver_support && !support)
|
||||||
{
|
|
||||||
todo = support_2d;
|
|
||||||
expect_hr = D3DERR_INVALIDCALL;
|
expect_hr = D3DERR_INVALIDCALL;
|
||||||
}
|
|
||||||
else
|
else
|
||||||
expect_hr = D3D_OK;
|
expect_hr = D3D_OK;
|
||||||
|
|
||||||
|
@ -8642,18 +8635,9 @@ static void test_volume_blocks(void)
|
||||||
if (!formats[i].core_fmt && !support && FAILED(expect_hr))
|
if (!formats[i].core_fmt && !support && FAILED(expect_hr))
|
||||||
may_succeed = TRUE;
|
may_succeed = TRUE;
|
||||||
|
|
||||||
if (todo)
|
|
||||||
{
|
|
||||||
todo_wine ok(hr == expect_hr || ((SUCCEEDED(hr) && may_succeed)),
|
|
||||||
"Got unexpected hr %#x for format %s, pool %s, size %ux%ux%u.\n",
|
|
||||||
hr, formats[i].name, create_tests[j].name, w, h, d);
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
ok(hr == expect_hr || ((SUCCEEDED(hr) && may_succeed)),
|
ok(hr == expect_hr || ((SUCCEEDED(hr) && may_succeed)),
|
||||||
"Got unexpected hr %#x for format %s, pool %s, size %ux%ux%u.\n",
|
"Got unexpected hr %#x for format %s, pool %s, size %ux%ux%u.\n",
|
||||||
hr, formats[i].name, create_tests[j].name, w, h, d);
|
hr, formats[i].name, create_tests[j].name, w, h, d);
|
||||||
}
|
|
||||||
|
|
||||||
if (FAILED(hr))
|
if (FAILED(hr))
|
||||||
ok(texture == NULL, "Got texture ptr %p, expected NULL.\n", texture);
|
ok(texture == NULL, "Got texture ptr %p, expected NULL.\n", texture);
|
||||||
|
|
|
@ -25,7 +25,7 @@
|
||||||
#include "d3dx9tex.h"
|
#include "d3dx9tex.h"
|
||||||
#include "resources.h"
|
#include "resources.h"
|
||||||
|
|
||||||
static int has_2d_dxt3, has_2d_dxt5, has_cube_dxt5;
|
static int has_2d_dxt3, has_2d_dxt5, has_cube_dxt5, has_3d_dxt3;
|
||||||
|
|
||||||
/* 2x2 16-bit dds, no mipmaps */
|
/* 2x2 16-bit dds, no mipmaps */
|
||||||
static const unsigned char dds_16bit[] = {
|
static const unsigned char dds_16bit[] = {
|
||||||
|
@ -575,6 +575,14 @@ static void test_D3DXCheckVolumeTextureRequirements(IDirect3DDevice9 *device)
|
||||||
ok(hr == D3D_OK, "D3DXCheckVolumeTextureRequirements returned %#x, expected %#x\n", hr, D3D_OK);
|
ok(hr == D3D_OK, "D3DXCheckVolumeTextureRequirements returned %#x, expected %#x\n", hr, D3D_OK);
|
||||||
ok(format == D3DFMT_X8R8G8B8, "Returned format %u, expected %u\n", format, D3DFMT_X8R8G8B8);
|
ok(format == D3DFMT_X8R8G8B8, "Returned format %u, expected %u\n", format, D3DFMT_X8R8G8B8);
|
||||||
|
|
||||||
|
format = D3DFMT_DXT3;
|
||||||
|
hr = D3DXCheckVolumeTextureRequirements(device, NULL, NULL, NULL, NULL, 0, &format, D3DPOOL_DEFAULT);
|
||||||
|
ok(hr == D3D_OK, "D3DXCheckVolumeTextureRequirements returned %#x, expected %#x\n", hr, D3D_OK);
|
||||||
|
if (has_3d_dxt3)
|
||||||
|
ok(format == D3DFMT_DXT3, "Returned format %u, expected %u\n", format, D3DFMT_DXT3);
|
||||||
|
else
|
||||||
|
todo_wine ok(format == D3DFMT_A8R8G8B8, "Returned format %u, expected %u\n", format, D3DFMT_A8R8G8B8);
|
||||||
|
|
||||||
/* mipmaps */
|
/* mipmaps */
|
||||||
if (!(caps.TextureCaps & D3DPTEXTURECAPS_MIPVOLUMEMAP))
|
if (!(caps.TextureCaps & D3DPTEXTURECAPS_MIPVOLUMEMAP))
|
||||||
{
|
{
|
||||||
|
@ -1774,7 +1782,7 @@ static void test_D3DXCreateVolumeTextureFromFileInMemory(IDirect3DDevice9 *devic
|
||||||
ok(hr == D3DERR_INVALIDCALL, "D3DXCreateVolumeTextureFromFileInMemory returned %#x, expected %#x\n", hr, D3DERR_INVALIDCALL);
|
ok(hr == D3DERR_INVALIDCALL, "D3DXCreateVolumeTextureFromFileInMemory returned %#x, expected %#x\n", hr, D3DERR_INVALIDCALL);
|
||||||
|
|
||||||
hr = D3DXCreateVolumeTextureFromFileInMemory(device, dds_volume_map, sizeof(dds_volume_map), &volume_texture);
|
hr = D3DXCreateVolumeTextureFromFileInMemory(device, dds_volume_map, sizeof(dds_volume_map), &volume_texture);
|
||||||
if (has_2d_dxt3)
|
if (has_3d_dxt3)
|
||||||
ok(hr == D3D_OK, "D3DXCreateVolumeTextureFromFileInMemory returned %#x, expected %#x\n", hr, D3D_OK);
|
ok(hr == D3D_OK, "D3DXCreateVolumeTextureFromFileInMemory returned %#x, expected %#x\n", hr, D3D_OK);
|
||||||
else
|
else
|
||||||
todo_wine ok(hr == D3D_OK, "D3DXCreateVolumeTextureFromFileInMemory returned %#x, expected %#x\n", hr, D3D_OK);
|
todo_wine ok(hr == D3D_OK, "D3DXCreateVolumeTextureFromFileInMemory returned %#x, expected %#x\n", hr, D3D_OK);
|
||||||
|
@ -1788,6 +1796,7 @@ static void test_D3DXCreateVolumeTextureFromFileInMemory(IDirect3DDevice9 *devic
|
||||||
ok(volume_desc.Width == 4, "Got width %u, expected 4\n", volume_desc.Width);
|
ok(volume_desc.Width == 4, "Got width %u, expected 4\n", volume_desc.Width);
|
||||||
ok(volume_desc.Height == 4, "Got height %u, expected 4\n", volume_desc.Height);
|
ok(volume_desc.Height == 4, "Got height %u, expected 4\n", volume_desc.Height);
|
||||||
ok(volume_desc.Depth == 2, "Got depth %u, expected 2\n", volume_desc.Depth);
|
ok(volume_desc.Depth == 2, "Got depth %u, expected 2\n", volume_desc.Depth);
|
||||||
|
ok(volume_desc.Pool == D3DPOOL_MANAGED, "Got pool %u, expected D3DPOOL_MANAGED\n", volume_desc.Pool);
|
||||||
|
|
||||||
hr = IDirect3DVolumeTexture9_GetLevelDesc(volume_texture, 1, &volume_desc);
|
hr = IDirect3DVolumeTexture9_GetLevelDesc(volume_texture, 1, &volume_desc);
|
||||||
ok(hr == D3D_OK, "GetLevelDesc returned %#x, expected %#x\n", hr, D3D_OK);
|
ok(hr == D3D_OK, "GetLevelDesc returned %#x, expected %#x\n", hr, D3D_OK);
|
||||||
|
@ -2031,6 +2040,8 @@ START_TEST(texture)
|
||||||
hr = IDirect3D9_CheckDeviceFormat(d3d, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL,
|
hr = IDirect3D9_CheckDeviceFormat(d3d, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL,
|
||||||
D3DFMT_X8R8G8B8, 0, D3DRTYPE_CUBETEXTURE, D3DFMT_DXT5);
|
D3DFMT_X8R8G8B8, 0, D3DRTYPE_CUBETEXTURE, D3DFMT_DXT5);
|
||||||
has_cube_dxt5 = SUCCEEDED(hr);
|
has_cube_dxt5 = SUCCEEDED(hr);
|
||||||
|
has_3d_dxt3 = SUCCEEDED(IDirect3D9_CheckDeviceFormat(d3d, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL,
|
||||||
|
D3DFMT_X8R8G8B8, 0, D3DRTYPE_VOLUMETEXTURE, D3DFMT_DXT3));
|
||||||
|
|
||||||
test_D3DXCheckTextureRequirements(device);
|
test_D3DXCheckTextureRequirements(device);
|
||||||
test_D3DXCheckCubeTextureRequirements(device);
|
test_D3DXCheckCubeTextureRequirements(device);
|
||||||
|
|
|
@ -4490,25 +4490,6 @@ HRESULT CDECL wined3d_check_device_format(const struct wined3d *wined3d, UINT ad
|
||||||
|
|
||||||
case WINED3D_RTYPE_VOLUME_TEXTURE:
|
case WINED3D_RTYPE_VOLUME_TEXTURE:
|
||||||
case WINED3D_RTYPE_VOLUME:
|
case WINED3D_RTYPE_VOLUME:
|
||||||
/* The GL_EXT_texture_compression_s3tc spec requires that loading
|
|
||||||
* an s3tc compressed texture results in an error. While the D3D
|
|
||||||
* refrast does support s3tc volumes, at least the nvidia Windows
|
|
||||||
* driver does not, so we're free not to support this format. */
|
|
||||||
switch (check_format_id)
|
|
||||||
{
|
|
||||||
case WINED3DFMT_DXT1:
|
|
||||||
case WINED3DFMT_DXT2:
|
|
||||||
case WINED3DFMT_DXT3:
|
|
||||||
case WINED3DFMT_DXT4:
|
|
||||||
case WINED3DFMT_DXT5:
|
|
||||||
TRACE("[FAILED] - DXTn does not support 3D textures.\n");
|
|
||||||
return WINED3DERR_NOTAVAILABLE;
|
|
||||||
|
|
||||||
default:
|
|
||||||
/* Do nothing, continue with checking the format below */
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
format_flags |= WINED3DFMT_FLAG_TEXTURE;
|
format_flags |= WINED3DFMT_FLAG_TEXTURE;
|
||||||
allowed_usage = WINED3DUSAGE_DYNAMIC
|
allowed_usage = WINED3DUSAGE_DYNAMIC
|
||||||
| WINED3DUSAGE_SOFTWAREPROCESSING
|
| WINED3DUSAGE_SOFTWAREPROCESSING
|
||||||
|
|
|
@ -2293,6 +2293,22 @@ static void apply_format_fixups(struct wined3d_adapter *adapter, struct wined3d_
|
||||||
|| !adapter->fragment_pipe->color_fixup_supported(format->color_fixup))
|
|| !adapter->fragment_pipe->color_fixup_supported(format->color_fixup))
|
||||||
format_clear_flag(&gl_info->formats[idx], WINED3DFMT_FLAG_TEXTURE);
|
format_clear_flag(&gl_info->formats[idx], WINED3DFMT_FLAG_TEXTURE);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* GL_EXT_texture_compression_s3tc does not support 3D textures. Some Windows drivers
|
||||||
|
* for dx9 GPUs support it, some do not, so not supporting DXTn volumes is OK for d3d9.
|
||||||
|
*
|
||||||
|
* Note that GL_NV_texture_compression_vtc adds this functionality to OpenGL, but the
|
||||||
|
* block layout is not compatible with the one used by d3d. See volume_dxt5_test. */
|
||||||
|
idx = getFmtIdx(WINED3DFMT_DXT1);
|
||||||
|
gl_info->formats[idx].flags[WINED3D_GL_RES_TYPE_TEX_3D] &= ~WINED3DFMT_FLAG_TEXTURE;
|
||||||
|
idx = getFmtIdx(WINED3DFMT_DXT2);
|
||||||
|
gl_info->formats[idx].flags[WINED3D_GL_RES_TYPE_TEX_3D] &= ~WINED3DFMT_FLAG_TEXTURE;
|
||||||
|
idx = getFmtIdx(WINED3DFMT_DXT3);
|
||||||
|
gl_info->formats[idx].flags[WINED3D_GL_RES_TYPE_TEX_3D] &= ~WINED3DFMT_FLAG_TEXTURE;
|
||||||
|
idx = getFmtIdx(WINED3DFMT_DXT4);
|
||||||
|
gl_info->formats[idx].flags[WINED3D_GL_RES_TYPE_TEX_3D] &= ~WINED3DFMT_FLAG_TEXTURE;
|
||||||
|
idx = getFmtIdx(WINED3DFMT_DXT5);
|
||||||
|
gl_info->formats[idx].flags[WINED3D_GL_RES_TYPE_TEX_3D] &= ~WINED3DFMT_FLAG_TEXTURE;
|
||||||
}
|
}
|
||||||
|
|
||||||
static BOOL init_format_vertex_info(struct wined3d_gl_info *gl_info)
|
static BOOL init_format_vertex_info(struct wined3d_gl_info *gl_info)
|
||||||
|
|
Loading…
Reference in New Issue