[vulkan] Fix conditional rendering enable
This commit is contained in:
parent
707bc3ddd4
commit
6408867c6c
|
|
@ -1212,13 +1212,18 @@ struct QueryCacheRuntimeImpl {
|
||||||
conditional_resolve_pass = std::make_unique<ConditionalRenderingResolvePass>(
|
conditional_resolve_pass = std::make_unique<ConditionalRenderingResolvePass>(
|
||||||
device, scheduler, descriptor_pool, compute_pass_descriptor_queue);
|
device, scheduler, descriptor_pool, compute_pass_descriptor_queue);
|
||||||
|
|
||||||
|
VkBufferUsageFlags conditional_usage =
|
||||||
|
VK_BUFFER_USAGE_TRANSFER_DST_BIT | VK_BUFFER_USAGE_STORAGE_BUFFER_BIT;
|
||||||
|
if (device.IsExtConditionalRendering()) {
|
||||||
|
conditional_usage |= VK_BUFFER_USAGE_CONDITIONAL_RENDERING_BIT_EXT;
|
||||||
|
}
|
||||||
|
|
||||||
const VkBufferCreateInfo buffer_ci = {
|
const VkBufferCreateInfo buffer_ci = {
|
||||||
.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO,
|
.sType = VK_STRUCTURE_TYPE_BUFFER_CREATE_INFO,
|
||||||
.pNext = nullptr,
|
.pNext = nullptr,
|
||||||
.flags = 0,
|
.flags = 0,
|
||||||
.size = sizeof(u32),
|
.size = sizeof(u32),
|
||||||
.usage = VK_BUFFER_USAGE_TRANSFER_DST_BIT | VK_BUFFER_USAGE_STORAGE_BUFFER_BIT |
|
.usage = conditional_usage,
|
||||||
VK_BUFFER_USAGE_CONDITIONAL_RENDERING_BIT_EXT,
|
|
||||||
.sharingMode = VK_SHARING_MODE_EXCLUSIVE,
|
.sharingMode = VK_SHARING_MODE_EXCLUSIVE,
|
||||||
.queueFamilyIndexCount = 0,
|
.queueFamilyIndexCount = 0,
|
||||||
.pQueueFamilyIndices = nullptr,
|
.pQueueFamilyIndices = nullptr,
|
||||||
|
|
|
||||||
|
|
@ -1224,6 +1224,12 @@ void Device::RemoveUnsuitableExtensions() {
|
||||||
features.provoking_vertex,
|
features.provoking_vertex,
|
||||||
VK_EXT_PROVOKING_VERTEX_EXTENSION_NAME);
|
VK_EXT_PROVOKING_VERTEX_EXTENSION_NAME);
|
||||||
|
|
||||||
|
// VK_EXT_conditional_rendering
|
||||||
|
extensions.conditional_rendering = features.conditional_rendering.conditionalRendering;
|
||||||
|
RemoveExtensionFeatureIfUnsuitable(extensions.conditional_rendering,
|
||||||
|
features.conditional_rendering,
|
||||||
|
VK_EXT_CONDITIONAL_RENDERING_EXTENSION_NAME);
|
||||||
|
|
||||||
// VK_EXT_multi_draw
|
// VK_EXT_multi_draw
|
||||||
extensions.multi_draw = features.multi_draw.multiDraw;
|
extensions.multi_draw = features.multi_draw.multiDraw;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -73,7 +73,6 @@ VK_DEFINE_HANDLE(VmaAllocator)
|
||||||
|
|
||||||
// Define miscellaneous extensions which may be used by the implementation here.
|
// Define miscellaneous extensions which may be used by the implementation here.
|
||||||
#define FOR_EACH_VK_EXTENSION(EXTENSION) \
|
#define FOR_EACH_VK_EXTENSION(EXTENSION) \
|
||||||
EXTENSION(EXT, CONDITIONAL_RENDERING, conditional_rendering) \
|
|
||||||
EXTENSION(EXT, CONSERVATIVE_RASTERIZATION, conservative_rasterization) \
|
EXTENSION(EXT, CONSERVATIVE_RASTERIZATION, conservative_rasterization) \
|
||||||
EXTENSION(EXT, DEPTH_RANGE_UNRESTRICTED, depth_range_unrestricted) \
|
EXTENSION(EXT, DEPTH_RANGE_UNRESTRICTED, depth_range_unrestricted) \
|
||||||
EXTENSION(EXT, MEMORY_BUDGET, memory_budget) \
|
EXTENSION(EXT, MEMORY_BUDGET, memory_budget) \
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue