changeset 1090:450b8a5042cd

add: check for uniform buffer layout, seem not be available on some older devices
author sam <sam@basx.dev>
date Sat, 06 Apr 2024 16:41:26 +0700
parents 8abbcdd4d58c
children b9401944ba0a
files semicongine/resources.nim semicongine/vulkan/descriptor.nim semicongine/vulkan/device.nim
diffstat 3 files changed, 7 insertions(+), 4 deletions(-) [+]
line wrap: on
line diff
--- a/semicongine/resources.nim	Sat Apr 06 15:46:41 2024 +0700
+++ b/semicongine/resources.nim	Sat Apr 06 16:41:26 2024 +0700
@@ -121,7 +121,6 @@
 
   import std/compilesettings
   import std/tables
-  import std/sequtils
 
   const BUILD_RESOURCEROOT* {.strdefine.}: string = ""
 
--- a/semicongine/vulkan/descriptor.nim	Sat Apr 06 15:46:41 2024 +0700
+++ b/semicongine/vulkan/descriptor.nim	Sat Apr 06 16:41:26 2024 +0700
@@ -70,7 +70,6 @@
   descriptorSetLayout.device.vk.vkDestroyDescriptorSetLayout(descriptorSetLayout.vk, nil)
   descriptorSetLayout.vk.reset
 
-
 proc createDescriptorSetPool*(device: Device, counts: seq[(VkDescriptorType, uint32)], maxSets = 1000): DescriptorPool =
   assert device.vk.valid
 
--- a/semicongine/vulkan/device.nim	Sat Apr 06 15:46:41 2024 +0700
+++ b/semicongine/vulkan/device.nim	Sat Apr 06 16:41:26 2024 +0700
@@ -32,9 +32,14 @@
   assert queueFamilies.len > 0
 
   result.physicalDevice = physicalDevice
-  var allExtensions = enabledExtensions & @["VK_KHR_swapchain", "VK_KHR_uniform_buffer_standard_layout"]
+  let hasUniformBufferStandardLayout = "VK_KHR_uniform_buffer_standard_layout" in physicalDevice.getExtensions()
+
+  var allExtensions = enabledExtensions & @["VK_KHR_swapchain"]
+  if hasUniformBufferStandardLayout:
+    allExtensions.add "VK_KHR_uniform_buffer_standard_layout"
   for extension in allExtensions:
     instance.vk.loadExtension(extension)
+
   var
     enabledExtensionsC = allocCStringArray(allExtensions)
     priority = 1'f32
@@ -55,7 +60,7 @@
   var features2 = VkPhysicalDeviceFeatures2(
     stype: VK_STRUCTURE_TYPE_PHYSICAL_DEVICE_FEATURES_2,
     features: result.enabledFeatures,
-    pnext: addr uniformBufferLayoutFeature,
+    pnext: if hasUniformBufferStandardLayout: addr uniformBufferLayoutFeature else: nil,
   )
   var createInfo = VkDeviceCreateInfo(
     sType: VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO,