mirror of
https://gitlab.winehq.org/wine/vkd3d.git
synced 2024-11-21 16:46:41 -08:00
vkd3d: Init physical device information after checking available extensions.
This commit is contained in:
parent
826b75722b
commit
ea090a34cd
Notes:
Alexandre Julliard
2024-05-08 22:52:26 +02:00
Approved-by: Conor McCarthy (@cmccarthy) 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/852
@ -1596,6 +1596,12 @@ static HRESULT vkd3d_init_device_caps(struct d3d12_device *device,
|
|||||||
|
|
||||||
static const VkSubgroupFeatureFlags required_stages = VK_SHADER_STAGE_COMPUTE_BIT | VK_SHADER_STAGE_FRAGMENT_BIT;
|
static const VkSubgroupFeatureFlags required_stages = VK_SHADER_STAGE_COMPUTE_BIT | VK_SHADER_STAGE_FRAGMENT_BIT;
|
||||||
|
|
||||||
|
if (FAILED(hr = vkd3d_check_device_extensions(device, create_info, &vk_extensions, &vk_extension_count,
|
||||||
|
device_extension_count, user_extension_supported)))
|
||||||
|
return hr;
|
||||||
|
|
||||||
|
vkd3d_physical_device_info_init(physical_device_info, device);
|
||||||
|
|
||||||
vkd3d_trace_physical_device(physical_device, physical_device_info, vk_procs);
|
vkd3d_trace_physical_device(physical_device, physical_device_info, vk_procs);
|
||||||
vkd3d_trace_physical_device_features(physical_device_info);
|
vkd3d_trace_physical_device_features(physical_device_info);
|
||||||
vkd3d_trace_physical_device_limits(physical_device_info);
|
vkd3d_trace_physical_device_limits(physical_device_info);
|
||||||
@ -1686,10 +1692,6 @@ static HRESULT vkd3d_init_device_caps(struct d3d12_device *device,
|
|||||||
device->feature_options5.RenderPassesTier = D3D12_RENDER_PASS_TIER_0;
|
device->feature_options5.RenderPassesTier = D3D12_RENDER_PASS_TIER_0;
|
||||||
device->feature_options5.RaytracingTier = D3D12_RAYTRACING_TIER_NOT_SUPPORTED;
|
device->feature_options5.RaytracingTier = D3D12_RAYTRACING_TIER_NOT_SUPPORTED;
|
||||||
|
|
||||||
if (FAILED(hr = vkd3d_check_device_extensions(device, create_info, &vk_extensions, &vk_extension_count,
|
|
||||||
device_extension_count, user_extension_supported)))
|
|
||||||
return hr;
|
|
||||||
|
|
||||||
fragment_shader_interlock = &physical_device_info->fragment_shader_interlock_features;
|
fragment_shader_interlock = &physical_device_info->fragment_shader_interlock_features;
|
||||||
if (!fragment_shader_interlock->fragmentShaderSampleInterlock
|
if (!fragment_shader_interlock->fragmentShaderSampleInterlock
|
||||||
|| !fragment_shader_interlock->fragmentShaderPixelInterlock)
|
|| !fragment_shader_interlock->fragmentShaderPixelInterlock)
|
||||||
@ -2112,8 +2114,6 @@ static HRESULT vkd3d_create_vk_device(struct d3d12_device *device,
|
|||||||
|
|
||||||
VK_CALL(vkGetPhysicalDeviceMemoryProperties(physical_device, &device->memory_properties));
|
VK_CALL(vkGetPhysicalDeviceMemoryProperties(physical_device, &device->memory_properties));
|
||||||
|
|
||||||
vkd3d_physical_device_info_init(&physical_device_info, device);
|
|
||||||
|
|
||||||
if (FAILED(hr = vkd3d_init_device_caps(device, create_info, &physical_device_info,
|
if (FAILED(hr = vkd3d_init_device_caps(device, create_info, &physical_device_info,
|
||||||
&extension_count, &user_extension_supported)))
|
&extension_count, &user_extension_supported)))
|
||||||
return hr;
|
return hr;
|
||||||
|
Loading…
Reference in New Issue
Block a user