[PATCH 3/6] d3d9/tests: Use create_device for test_swvp_buffer.
Stefan Dösinger
stefan at codeweavers.com
Mon Oct 20 06:08:52 CDT 2014
---
dlls/d3d9/tests/device.c | 21 ++++++++++-----------
1 file changed, 10 insertions(+), 11 deletions(-)
diff --git a/dlls/d3d9/tests/device.c b/dlls/d3d9/tests/device.c
index 5a55fcb..5a206e5 100644
--- a/dlls/d3d9/tests/device.c
+++ b/dlls/d3d9/tests/device.c
@@ -35,6 +35,7 @@ struct vec3
#define CREATE_DEVICE_NOWINDOWCHANGES 0x02
#define CREATE_DEVICE_FPU_PRESERVE 0x04
#define CREATE_DEVICE_HWVP_ONLY 0x08
+#define CREATE_DEVICE_SWVP_ONLY 0x10
struct device_desc
{
@@ -151,6 +152,8 @@ static IDirect3DDevice9 *create_device(IDirect3D9 *d3d9, HWND focus_window, cons
present_parameters.BackBufferHeight = desc->height;
present_parameters.hDeviceWindow = desc->device_window;
present_parameters.Windowed = !(desc->flags & CREATE_DEVICE_FULLSCREEN);
+ if (desc->flags & CREATE_DEVICE_SWVP_ONLY)
+ behavior_flags = D3DCREATE_SOFTWARE_VERTEXPROCESSING;
if (desc->flags & CREATE_DEVICE_NOWINDOWCHANGES)
behavior_flags |= D3DCREATE_NOWINDOWCHANGES;
if (desc->flags & CREATE_DEVICE_FPU_PRESERVE)
@@ -166,7 +169,7 @@ static IDirect3DDevice9 *create_device(IDirect3D9 *d3d9, HWND focus_window, cons
behavior_flags, &present_parameters, &device)))
return device;
- if (desc && desc->flags & CREATE_DEVICE_HWVP_ONLY)
+ if (desc && desc->flags & (CREATE_DEVICE_HWVP_ONLY | CREATE_DEVICE_SWVP_ONLY))
return NULL;
behavior_flags ^= (D3DCREATE_HARDWARE_VERTEXPROCESSING | D3DCREATE_SOFTWARE_VERTEXPROCESSING);
@@ -7243,7 +7246,7 @@ static void test_swvp_buffer(void)
IDirect3DVertexBuffer9 *buffer;
static const unsigned int bufsize = 1024;
D3DVERTEXBUFFER_DESC desc;
- D3DPRESENT_PARAMETERS present_parameters = {0};
+ struct device_desc device_desc;
struct
{
float x, y, z;
@@ -7254,15 +7257,11 @@ static void test_swvp_buffer(void)
d3d9 = Direct3DCreate9(D3D_SDK_VERSION);
ok(!!d3d9, "Failed to create a D3D object.\n");
- present_parameters.Windowed = TRUE;
- present_parameters.hDeviceWindow = window;
- present_parameters.SwapEffect = D3DSWAPEFFECT_DISCARD;
- present_parameters.BackBufferWidth = screen_width;
- present_parameters.BackBufferHeight = screen_height;
- present_parameters.BackBufferFormat = D3DFMT_A8R8G8B8;
- present_parameters.EnableAutoDepthStencil = FALSE;
- if (FAILED(IDirect3D9_CreateDevice(d3d9, D3DADAPTER_DEFAULT, D3DDEVTYPE_HAL, window,
- D3DCREATE_SOFTWARE_VERTEXPROCESSING, &present_parameters, &device)))
+ device_desc.device_window = window;
+ device_desc.width = 640;
+ device_desc.height = 480;
+ device_desc.flags = CREATE_DEVICE_SWVP_ONLY;
+ if (!(device = create_device(d3d9, window, &device_desc)))
{
skip("Failed to create a D3D device, skipping tests.\n");
DestroyWindow(window);
--
2.0.4
More information about the wine-patches
mailing list