mirror of
https://gitlab.winehq.org/wine/vkd3d.git
synced 2025-01-28 13:05:02 -08:00
tests/shader-runner: Introduce a 'float64' requirement directive.
This commit is contained in:
parent
95c48eb98e
commit
8a1eb306e8
Notes:
Alexandre Julliard
2023-12-12 23:15:46 +01:00
Approved-by: Giovanni Mascellani (@giomasce) Approved-by: Henri Verbeet (@hverbeet) Approved-by: Alexandre Julliard (@julliard) Merge-Request: https://gitlab.winehq.org/wine/vkd3d/-/merge_requests/489
@ -1,5 +1,6 @@
|
|||||||
[require]
|
[require]
|
||||||
shader model >= 5.0
|
shader model >= 5.0
|
||||||
|
float64
|
||||||
|
|
||||||
[pixel shader todo]
|
[pixel shader todo]
|
||||||
uniform double2 d;
|
uniform double2 d;
|
||||||
|
@ -191,6 +191,10 @@ static void parse_require_directive(struct shader_runner *runner, const char *li
|
|||||||
runner->compile_options |= options[i].option;
|
runner->compile_options |= options[i].option;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (match_string(line, "float64", &line))
|
||||||
|
{
|
||||||
|
runner->require_float64 = true;
|
||||||
|
}
|
||||||
else if (match_string(line, "int64", &line))
|
else if (match_string(line, "int64", &line))
|
||||||
{
|
{
|
||||||
runner->require_int64 = true;
|
runner->require_int64 = true;
|
||||||
@ -1315,6 +1319,7 @@ void run_shader_tests(struct shader_runner *runner, const struct shader_runner_o
|
|||||||
state = STATE_REQUIRE;
|
state = STATE_REQUIRE;
|
||||||
runner->minimum_shader_model = minimum_shader_model;
|
runner->minimum_shader_model = minimum_shader_model;
|
||||||
runner->maximum_shader_model = maximum_shader_model;
|
runner->maximum_shader_model = maximum_shader_model;
|
||||||
|
runner->require_float64 = false;
|
||||||
runner->require_int64 = false;
|
runner->require_int64 = false;
|
||||||
runner->compile_options = 0;
|
runner->compile_options = 0;
|
||||||
skip_tests = false;
|
skip_tests = false;
|
||||||
|
@ -122,6 +122,7 @@ struct shader_runner
|
|||||||
char *fx_source;
|
char *fx_source;
|
||||||
enum shader_model minimum_shader_model;
|
enum shader_model minimum_shader_model;
|
||||||
enum shader_model maximum_shader_model;
|
enum shader_model maximum_shader_model;
|
||||||
|
bool require_float64;
|
||||||
bool require_int64;
|
bool require_int64;
|
||||||
|
|
||||||
bool last_render_failed;
|
bool last_render_failed;
|
||||||
|
@ -53,6 +53,7 @@ struct d3d12_shader_runner
|
|||||||
|
|
||||||
IDxcCompiler3 *dxc_compiler;
|
IDxcCompiler3 *dxc_compiler;
|
||||||
|
|
||||||
|
D3D12_FEATURE_DATA_D3D12_OPTIONS options;
|
||||||
D3D12_FEATURE_DATA_D3D12_OPTIONS1 options1;
|
D3D12_FEATURE_DATA_D3D12_OPTIONS1 options1;
|
||||||
};
|
};
|
||||||
|
|
||||||
@ -102,6 +103,9 @@ static bool d3d12_runner_check_requirements(struct shader_runner *r)
|
|||||||
{
|
{
|
||||||
struct d3d12_shader_runner *runner = d3d12_shader_runner(r);
|
struct d3d12_shader_runner *runner = d3d12_shader_runner(r);
|
||||||
|
|
||||||
|
if (runner->r.require_float64 && !runner->options.DoublePrecisionFloatShaderOps)
|
||||||
|
return false;
|
||||||
|
|
||||||
if (runner->r.require_int64 && !runner->options1.Int64ShaderOps)
|
if (runner->r.require_int64 && !runner->options1.Int64ShaderOps)
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
@ -615,6 +619,11 @@ void run_shader_tests_d3d12(void *dxc_compiler, enum shader_model minimum_shader
|
|||||||
runner.compute_allocator, NULL, &IID_ID3D12GraphicsCommandList, (void **)&runner.compute_list);
|
runner.compute_allocator, NULL, &IID_ID3D12GraphicsCommandList, (void **)&runner.compute_list);
|
||||||
ok(hr == S_OK, "Failed to create command list, hr %#x.\n", hr);
|
ok(hr == S_OK, "Failed to create command list, hr %#x.\n", hr);
|
||||||
|
|
||||||
|
hr = ID3D12Device_CheckFeatureSupport(device, D3D12_FEATURE_D3D12_OPTIONS,
|
||||||
|
&runner.options, sizeof(runner.options));
|
||||||
|
ok(hr == S_OK, "Failed to check feature options support, hr %#x.\n", hr);
|
||||||
|
trace("DoublePrecisionFloatShaderOps: %u.\n", runner.options.DoublePrecisionFloatShaderOps);
|
||||||
|
|
||||||
hr = ID3D12Device_CheckFeatureSupport(device, D3D12_FEATURE_D3D12_OPTIONS1,
|
hr = ID3D12Device_CheckFeatureSupport(device, D3D12_FEATURE_D3D12_OPTIONS1,
|
||||||
&runner.options1, sizeof(runner.options1));
|
&runner.options1, sizeof(runner.options1));
|
||||||
ok(hr == S_OK, "Failed to check feature options1 support, hr %#x.\n", hr);
|
ok(hr == S_OK, "Failed to check feature options1 support, hr %#x.\n", hr);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user