forked from ShuriZma/suyu
video_core: vulkan_device: Change to driver version check.
This commit is contained in:
parent
ddcd89afd4
commit
cef7aaa8ec
|
@ -498,15 +498,19 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR
|
||||||
loaded_extensions.erase(VK_EXT_EXTENDED_DYNAMIC_STATE_2_EXTENSION_NAME);
|
loaded_extensions.erase(VK_EXT_EXTENDED_DYNAMIC_STATE_2_EXTENSION_NAME);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (extensions.extended_dynamic_state2 && is_qualcomm && is_s8gen2) {
|
if (extensions.extended_dynamic_state2 && is_qualcomm) {
|
||||||
// Qualcomm S8gen2 drivers do not properly support extended_dynamic_state2.
|
const u32 version = (properties.properties.driverVersion << 3) >> 3;
|
||||||
LOG_WARNING(Render_Vulkan, "Qualcomm drivers have broken VK_EXT_extended_dynamic_state2");
|
if (version >= VK_MAKE_API_VERSION(0, 0, 676, 0)) {
|
||||||
|
// Qualcomm Adreno 7xx drivers do not properly support extended_dynamic_state2.
|
||||||
|
LOG_WARNING(Render_Vulkan,
|
||||||
|
"Qualcomm Adreno 7xx drivers have broken VK_EXT_extended_dynamic_state2");
|
||||||
features.extended_dynamic_state2.extendedDynamicState2 = false;
|
features.extended_dynamic_state2.extendedDynamicState2 = false;
|
||||||
features.extended_dynamic_state2.extendedDynamicState2LogicOp = false;
|
features.extended_dynamic_state2.extendedDynamicState2LogicOp = false;
|
||||||
features.extended_dynamic_state2.extendedDynamicState2PatchControlPoints = false;
|
features.extended_dynamic_state2.extendedDynamicState2PatchControlPoints = false;
|
||||||
extensions.extended_dynamic_state2 = false;
|
extensions.extended_dynamic_state2 = false;
|
||||||
loaded_extensions.erase(VK_EXT_EXTENDED_DYNAMIC_STATE_2_EXTENSION_NAME);
|
loaded_extensions.erase(VK_EXT_EXTENDED_DYNAMIC_STATE_2_EXTENSION_NAME);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
if (extensions.extended_dynamic_state3 && is_radv) {
|
if (extensions.extended_dynamic_state3 && is_radv) {
|
||||||
LOG_WARNING(Render_Vulkan, "RADV has broken extendedDynamicState3ColorBlendEquation");
|
LOG_WARNING(Render_Vulkan, "RADV has broken extendedDynamicState3ColorBlendEquation");
|
||||||
features.extended_dynamic_state3.extendedDynamicState3ColorBlendEnable = false;
|
features.extended_dynamic_state3.extendedDynamicState3ColorBlendEnable = false;
|
||||||
|
@ -534,14 +538,18 @@ Device::Device(VkInstance instance_, vk::PhysicalDevice physical_, VkSurfaceKHR
|
||||||
loaded_extensions.erase(VK_EXT_VERTEX_INPUT_DYNAMIC_STATE_EXTENSION_NAME);
|
loaded_extensions.erase(VK_EXT_VERTEX_INPUT_DYNAMIC_STATE_EXTENSION_NAME);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if (extensions.vertex_input_dynamic_state && is_qualcomm && is_s8gen2) {
|
if (extensions.vertex_input_dynamic_state && is_qualcomm) {
|
||||||
// Qualcomm S8gen2 drivers do not properly support vertex_input_dynamic_state.
|
const u32 version = (properties.properties.driverVersion << 3) >> 3;
|
||||||
LOG_WARNING(Render_Vulkan,
|
if (version >= VK_MAKE_API_VERSION(0, 0, 676, 0)) {
|
||||||
"Qualcomm drivers have broken VK_EXT_vertex_input_dynamic_state");
|
// Qualcomm Adreno 7xx drivers do not properly support vertex_input_dynamic_state.
|
||||||
|
LOG_WARNING(
|
||||||
|
Render_Vulkan,
|
||||||
|
"Qualcomm Adreno 7xx drivers have broken VK_EXT_vertex_input_dynamic_state");
|
||||||
features.vertex_input_dynamic_state.vertexInputDynamicState = false;
|
features.vertex_input_dynamic_state.vertexInputDynamicState = false;
|
||||||
extensions.vertex_input_dynamic_state = false;
|
extensions.vertex_input_dynamic_state = false;
|
||||||
loaded_extensions.erase(VK_EXT_VERTEX_INPUT_DYNAMIC_STATE_EXTENSION_NAME);
|
loaded_extensions.erase(VK_EXT_VERTEX_INPUT_DYNAMIC_STATE_EXTENSION_NAME);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
sets_per_pool = 64;
|
sets_per_pool = 64;
|
||||||
if (is_amd_driver) {
|
if (is_amd_driver) {
|
||||||
|
|
Loading…
Reference in New Issue