Mercurial > games > semicongine
annotate semiconginev2/rendering.nim @ 1225:27cd1c21290e compiletime-tests
did: refactor resources
author | sam <sam@basx.dev> |
---|---|
date | Wed, 17 Jul 2024 22:20:59 +0700 |
parents | a3fa15c25026 |
children | c8e3037aca66 |
rev | line source |
---|---|
1192 | 1 # in this file: |
2 # - const defintions for rendering | |
3 # - custom pragma defintions for rendering | |
4 # - type defintions for rendering | |
5 # - some utils code that is used in mutiple rendering files | |
6 # - inclusion of all rendering files | |
7 | |
8 | |
9 # const definitions | |
1197 | 10 const INFLIGHTFRAMES* = 2'u32 |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
11 const BUFFER_ALIGNMENT = 64'u64 # align offsets inside buffers along this alignment |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
12 const MEMORY_BLOCK_ALLOCATION_SIZE = 100_000_000'u64 # ca. 100mb per block, seems reasonable |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
13 const BUFFER_ALLOCATION_SIZE = 9_000_000'u64 # ca. 9mb per block, seems reasonable, can put 10 buffers into one memory block |
1205
f7530247a21f
did: improve descriptor-set handling, add simple descriptor set test
sam <sam@basx.dev>
parents:
1204
diff
changeset
|
14 const MAX_DESCRIPTORSETS = 4 |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
15 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
16 # custom pragmas to classify shader attributes |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
17 template VertexAttribute* {.pragma.} |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
18 template InstanceAttribute* {.pragma.} |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
19 template Pass* {.pragma.} |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
20 template PassFlat* {.pragma.} |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
21 template ShaderOutput* {.pragma.} |
1205
f7530247a21f
did: improve descriptor-set handling, add simple descriptor set test
sam <sam@basx.dev>
parents:
1204
diff
changeset
|
22 template DescriptorSets* {.pragma.} |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
23 |
1193 | 24 # there is a big, bad global vulkan object |
25 # believe me, this makes everything much, much easier | |
26 | |
1224
a3fa15c25026
did: cleanup, add audio, change platform-dependent structure
sam <sam@basx.dev>
parents:
1218
diff
changeset
|
27 when defined(windows): |
a3fa15c25026
did: cleanup, add audio, change platform-dependent structure
sam <sam@basx.dev>
parents:
1218
diff
changeset
|
28 include ./rendering/platform/windows |
a3fa15c25026
did: cleanup, add audio, change platform-dependent structure
sam <sam@basx.dev>
parents:
1218
diff
changeset
|
29 when defined(linux): |
a3fa15c25026
did: cleanup, add audio, change platform-dependent structure
sam <sam@basx.dev>
parents:
1218
diff
changeset
|
30 include ./rendering/platform/linux |
1193 | 31 |
32 type | |
33 VulkanGlobals* = object | |
1195
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
34 # populated through InitVulkan proc |
1193 | 35 instance*: VkInstance |
36 device*: VkDevice | |
37 physicalDevice*: VkPhysicalDevice | |
38 surface: VkSurfaceKHR | |
39 window: NativeWindow | |
40 graphicsQueueFamily*: uint32 | |
41 graphicsQueue*: VkQueue | |
1199 | 42 debugMessenger: VkDebugUtilsMessengerEXT |
1197 | 43 # unclear as of yet |
44 anisotropy*: float32 = 0 # needs to be enable during device creation | |
1203
6360c8d17ce0
did: preprations to add rendering tests
sam <sam@basx.dev>
parents:
1202
diff
changeset
|
45 Swapchain* = object |
1195
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
46 # parameters to InitSwapchain, required for swapchain recreation |
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
47 renderPass: VkRenderPass |
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
48 vSync: bool |
1204 | 49 samples*: VkSampleCountFlagBits |
1195
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
50 # populated through InitSwapchain proc |
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
51 vk: VkSwapchainKHR |
1214
04e446a7eb2b
add: multipass renderer, finish tets for now
sam <sam@basx.dev>
parents:
1212
diff
changeset
|
52 width*: uint32 |
04e446a7eb2b
add: multipass renderer, finish tets for now
sam <sam@basx.dev>
parents:
1212
diff
changeset
|
53 height*: uint32 |
1195
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
54 msaaImage: VkImage |
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
55 msaaMemory: VkDeviceMemory |
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
56 msaaImageView: VkImageView |
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
57 framebuffers: seq[VkFramebuffer] |
cfba2b7e00d0
did: most of swapchain, swap still needs to be done
sam <sam@basx.dev>
parents:
1194
diff
changeset
|
58 framebufferViews: seq[VkImageView] |
1198 | 59 currentFramebufferIndex: uint32 |
60 commandBufferPool: VkCommandPool | |
61 # frame-in-flight handling | |
62 currentFiF: range[0 .. (INFLIGHTFRAMES - 1).int] | |
1197 | 63 queueFinishedFence*: array[INFLIGHTFRAMES.int, VkFence] |
64 imageAvailableSemaphore*: array[INFLIGHTFRAMES.int, VkSemaphore] | |
65 renderFinishedSemaphore*: array[INFLIGHTFRAMES.int, VkSemaphore] | |
1198 | 66 commandBuffers: array[INFLIGHTFRAMES.int, VkCommandBuffer] |
1200
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
67 oldSwapchain: ref Swapchain |
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
68 oldSwapchainCounter: int # swaps until old swapchain will be destroyed |
1193 | 69 |
70 var vulkan*: VulkanGlobals | |
71 | |
1202 | 72 func currentFiF*(swapchain: Swapchain): int = swapchain.currentFiF |
73 | |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
74 type |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
75 # type aliases |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
76 SupportedGPUType = float32 | float64 | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | TVec2[int32] | TVec2[int64] | TVec3[int32] | TVec3[int64] | TVec4[int32] | TVec4[int64] | TVec2[uint32] | TVec2[uint64] | TVec3[uint32] | TVec3[uint64] | TVec4[uint32] | TVec4[uint64] | TVec2[float32] | TVec2[float64] | TVec3[float32] | TVec3[float64] | TVec4[float32] | TVec4[float64] | TMat2[float32] | TMat2[float64] | TMat23[float32] | TMat23[float64] | TMat32[float32] | TMat32[float64] | TMat3[float32] | TMat3[float64] | TMat34[float32] | TMat34[float64] | TMat43[float32] | TMat43[float64] | TMat4[float32] | TMat4[float64] |
1212
518a952eccbf
did: increase texture format compatability
sam <sam@basx.dev>
parents:
1210
diff
changeset
|
77 TextureType = TVec1[uint8] | TVec4[uint8] |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
78 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
79 # shader related types |
1205
f7530247a21f
did: improve descriptor-set handling, add simple descriptor set test
sam <sam@basx.dev>
parents:
1204
diff
changeset
|
80 DescriptorSet*[T: object] = object |
1192 | 81 data*: T |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
82 vk: array[INFLIGHTFRAMES.int, VkDescriptorSet] |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
83 Pipeline*[TShader] = object |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
84 vk: VkPipeline |
1200
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
85 vertexShaderModule: VkShaderModule |
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
86 fragmentShaderModule: VkShaderModule |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
87 layout: VkPipelineLayout |
1205
f7530247a21f
did: improve descriptor-set handling, add simple descriptor set test
sam <sam@basx.dev>
parents:
1204
diff
changeset
|
88 descriptorSetLayouts*: array[MAX_DESCRIPTORSETS, VkDescriptorSetLayout] |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
89 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
90 # memory/buffer related types |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
91 MemoryBlock* = object |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
92 vk: VkDeviceMemory |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
93 size: uint64 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
94 rawPointer: pointer # if not nil, this is mapped memory |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
95 offsetNextFree: uint64 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
96 BufferType* = enum |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
97 VertexBuffer |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
98 VertexBufferMapped |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
99 IndexBuffer |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
100 IndexBufferMapped |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
101 UniformBuffer |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
102 UniformBufferMapped |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
103 Buffer* = object |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
104 vk: VkBuffer |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
105 size: uint64 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
106 rawPointer: pointer # if not nil, buffer is using mapped memory |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
107 offsetNextFree: uint64 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
108 Texture*[T: TextureType] = object |
1210 | 109 width*: uint32 |
110 height*: uint32 | |
111 interpolation*: VkFilter = VK_FILTER_LINEAR | |
112 data*: seq[T] | |
1214
04e446a7eb2b
add: multipass renderer, finish tets for now
sam <sam@basx.dev>
parents:
1212
diff
changeset
|
113 vk*: VkImage |
04e446a7eb2b
add: multipass renderer, finish tets for now
sam <sam@basx.dev>
parents:
1212
diff
changeset
|
114 imageview*: VkImageView |
04e446a7eb2b
add: multipass renderer, finish tets for now
sam <sam@basx.dev>
parents:
1212
diff
changeset
|
115 sampler*: VkSampler |
04e446a7eb2b
add: multipass renderer, finish tets for now
sam <sam@basx.dev>
parents:
1212
diff
changeset
|
116 isRenderTarget*: bool = false |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
117 GPUArray*[T: SupportedGPUType, TBuffer: static BufferType] = object |
1192 | 118 data*: seq[T] |
1202 | 119 buffer*: Buffer |
120 offset*: uint64 | |
1210 | 121 GPUValue*[T: object, TBuffer: static BufferType] = object |
1192 | 122 data*: T |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
123 buffer: Buffer |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
124 offset: uint64 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
125 GPUData = GPUArray | GPUValue |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
126 |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
127 RenderData* = object |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
128 descriptorPool: VkDescriptorPool |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
129 memory: array[VK_MAX_MEMORY_TYPES.int, seq[MemoryBlock]] |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
130 buffers: array[BufferType, seq[Buffer]] |
1200
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
131 images: seq[VkImage] |
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
132 imageViews: seq[VkImageView] |
1201 | 133 samplers: seq[VkSampler] |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
134 |
1192 | 135 template ForDescriptorFields(shader: typed, fieldname, valuename, typename, countname, bindingNumber, body: untyped): untyped = |
1205
f7530247a21f
did: improve descriptor-set handling, add simple descriptor set test
sam <sam@basx.dev>
parents:
1204
diff
changeset
|
136 var `bindingNumber` {.inject.} = 0'u32 |
1192 | 137 for theFieldname, value in fieldPairs(shader): |
138 when typeof(value) is Texture: | |
139 block: | |
140 const `fieldname` {.inject.} = theFieldname | |
141 const `typename` {.inject.} = VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER | |
142 const `countname` {.inject.} = 1'u32 | |
143 let `valuename` {.inject.} = value | |
144 body | |
145 `bindingNumber`.inc | |
1210 | 146 elif typeof(value) is GPUValue: |
1192 | 147 block: |
148 const `fieldname` {.inject.} = theFieldname | |
149 const `typename` {.inject.} = VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER | |
150 const `countname` {.inject.} = 1'u32 | |
151 let `valuename` {.inject.} = value | |
152 body | |
153 `bindingNumber`.inc | |
154 elif typeof(value) is array: | |
155 when elementType(value) is Texture: | |
156 block: | |
157 const `fieldname` {.inject.} = theFieldname | |
158 const `typename` {.inject.} = VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER | |
159 const `countname` {.inject.} = uint32(typeof(value).len) | |
160 let `valuename` {.inject.} = value | |
161 body | |
162 `bindingNumber`.inc | |
1210 | 163 elif elementType(value) is GPUValue: |
1192 | 164 block: |
165 const `fieldname` {.inject.} = theFieldname | |
166 const `typename` {.inject.} = VK_DESCRIPTOR_TYPE_UNIFORM_BUFFER | |
1210 | 167 const `countname` {.inject.} = len(value).uint32 |
1192 | 168 let `valuename` {.inject.} = value |
169 body | |
170 `bindingNumber`.inc | |
171 else: | |
172 {.error: "Unsupported descriptor type: " & typetraits.name(typeof(value)).} | |
1210 | 173 else: |
174 {.error: "Unsupported descriptor type: " & typetraits.name(typeof(value)).} | |
1192 | 175 |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
176 include ./rendering/vulkan_wrappers |
1199 | 177 include ./rendering/renderpasses |
1194 | 178 include ./rendering/swapchain |
1190
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
179 include ./rendering/shaders |
a3eb305bcac2
start of complete and total refactoring: the ULTIMATE
sam <sam@basx.dev>
parents:
diff
changeset
|
180 include ./rendering/renderer |
1193 | 181 |
1199 | 182 proc debugCallback( |
183 messageSeverity: VkDebugUtilsMessageSeverityFlagBitsEXT, | |
184 messageTypes: VkDebugUtilsMessageTypeFlagsEXT, | |
185 pCallbackData: ptr VkDebugUtilsMessengerCallbackDataEXT, | |
186 userData: pointer | |
187 ): VkBool32 {.cdecl.} = | |
188 const LOG_LEVEL_MAPPING = { | |
189 VK_DEBUG_UTILS_MESSAGE_SEVERITY_VERBOSE_BIT_EXT: lvlDebug, | |
190 VK_DEBUG_UTILS_MESSAGE_SEVERITY_INFO_BIT_EXT: lvlInfo, | |
191 VK_DEBUG_UTILS_MESSAGE_SEVERITY_WARNING_BIT_EXT: lvlWarn, | |
192 VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT: lvlError, | |
193 }.toTable | |
194 log LOG_LEVEL_MAPPING[messageSeverity], &"{toEnums messageTypes}: {pCallbackData.pMessage}" | |
195 if messageSeverity == VK_DEBUG_UTILS_MESSAGE_SEVERITY_ERROR_BIT_EXT: | |
196 stderr.writeLine "-----------------------------------" | |
197 stderr.write getStackTrace() | |
198 stderr.writeLine LOG_LEVEL_MAPPING[messageSeverity], &"{toEnums messageTypes}: {pCallbackData.pMessage}" | |
199 stderr.writeLine "-----------------------------------" | |
200 let errorMsg = getStackTrace() & &"\n{toEnums messageTypes}: {pCallbackData.pMessage}" | |
201 raise newException(Exception, errorMsg) | |
202 return false | |
1193 | 203 |
1204 | 204 proc InitVulkan*(appName: string = "semicongine app") = |
1193 | 205 |
206 include ./platform/vulkan_extensions # for REQUIRED_PLATFORM_EXTENSIONS | |
207 | |
208 # instance creation | |
1198 | 209 |
210 # enagle all kind of debug stuff | |
1193 | 211 when not defined(release): |
212 let requiredExtensions = REQUIRED_PLATFORM_EXTENSIONS & @["VK_KHR_surface", "VK_EXT_debug_utils"] | |
213 let layers: seq[string] = if hasValidationLayer(): @["VK_LAYER_KHRONOS_validation"] else: @[] | |
1198 | 214 putEnv("VK_LAYER_ENABLES", "VALIDATION_CHECK_ENABLE_VENDOR_SPECIFIC_AMD,VALIDATION_CHECK_ENABLE_VENDOR_SPECIFIC_NVIDIA,VK_VALIDATION_FEATURE_ENABLE_SYNCHRONIZATION_VALIDATION_EXTVK_VALIDATION_FEATURE_ENABLE_GPU_ASSISTED_EXT,VK_VALIDATION_FEATURE_ENABLE_SYNCHRONIZATION_VALIDATION_EXT") |
1193 | 215 else: |
216 let requiredExtensions = REQUIRED_PLATFORM_EXTENSIONS & @["VK_KHR_surface"] | |
217 let layers: seq[string] | |
218 | |
219 var | |
220 layersC = allocCStringArray(layers) | |
221 instanceExtensionsC = allocCStringArray(requiredExtensions) | |
222 defer: | |
223 deallocCStringArray(layersC) | |
224 deallocCStringArray(instanceExtensionsC) | |
225 | |
226 var | |
227 appinfo = VkApplicationInfo( | |
228 sType: VK_STRUCTURE_TYPE_APPLICATION_INFO, | |
229 pApplicationName: appName, | |
230 pEngineName: "semicongine", | |
231 apiVersion: VK_MAKE_API_VERSION(0, 1, 3, 0), | |
232 ) | |
233 createinfo = VkInstanceCreateInfo( | |
234 sType: VK_STRUCTURE_TYPE_INSTANCE_CREATE_INFO, | |
235 pApplicationInfo: addr(appinfo), | |
236 enabledLayerCount: layers.len.uint32, | |
237 ppEnabledLayerNames: layersC, | |
238 enabledExtensionCount: requiredExtensions.len.uint32, | |
239 ppEnabledExtensionNames: instanceExtensionsC | |
240 ) | |
1204 | 241 checkVkResult vkCreateInstance(addr(createinfo), nil, addr(vulkan.instance)) |
242 loadVulkan(vulkan.instance) | |
1193 | 243 |
244 # load extensions | |
245 # | |
246 for extension in requiredExtensions: | |
1204 | 247 loadExtension(vulkan.instance, $extension) |
248 vulkan.window = CreateWindow(appName) | |
249 vulkan.surface = CreateNativeSurface(vulkan.instance, vulkan.window) | |
1193 | 250 |
251 # logical device creation | |
252 | |
253 # TODO: allowing support for physical devices without hasUniformBufferStandardLayout | |
254 # would require us to ship different shaders, so we don't support standard layout | |
255 # if that will be added, check the function vulkan/shaders.nim:glslUniforms and update accordingly | |
256 # let hasUniformBufferStandardLayout = "VK_KHR_uniform_buffer_standard_layout" in physicalDevice.getExtensions() | |
257 # var deviceExtensions = @["VK_KHR_swapchain", "VK_KHR_uniform_buffer_standard_layout"] | |
258 var deviceExtensions = @["VK_KHR_swapchain"] | |
259 for extension in deviceExtensions: | |
1204 | 260 loadExtension(vulkan.instance, extension) |
1193 | 261 |
1199 | 262 when not defined(release): |
263 var debugMessengerCreateInfo = VkDebugUtilsMessengerCreateInfoEXT( | |
264 sType: VK_STRUCTURE_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT, | |
265 messageSeverity: VkDebugUtilsMessageSeverityFlagBitsEXT.items.toSeq.toBits, | |
266 messageType: VkDebugUtilsMessageTypeFlagBitsEXT.items.toSeq.toBits, | |
267 pfnUserCallback: debugCallback, | |
268 pUserData: nil, | |
269 ) | |
270 checkVkResult vkCreateDebugUtilsMessengerEXT( | |
1204 | 271 vulkan.instance, |
1199 | 272 addr(debugMessengerCreateInfo), |
273 nil, | |
1204 | 274 addr(vulkan.debugMessenger) |
1199 | 275 ) |
276 | |
1193 | 277 # get physical device and graphics queue family |
1204 | 278 vulkan.physicalDevice = GetBestPhysicalDevice(vulkan.instance) |
279 vulkan.graphicsQueueFamily = GetQueueFamily(vulkan.physicalDevice, VK_QUEUE_GRAPHICS_BIT) | |
1193 | 280 |
281 let | |
282 priority = cfloat(1) | |
283 queueInfo = VkDeviceQueueCreateInfo( | |
284 sType: VK_STRUCTURE_TYPE_DEVICE_QUEUE_CREATE_INFO, | |
1204 | 285 queueFamilyIndex: vulkan.graphicsQueueFamily, |
1193 | 286 queueCount: 1, |
287 pQueuePriorities: addr(priority), | |
288 ) | |
289 deviceExtensionsC = allocCStringArray(deviceExtensions) | |
290 defer: deallocCStringArray(deviceExtensionsC) | |
291 var createDeviceInfo = VkDeviceCreateInfo( | |
292 sType: VK_STRUCTURE_TYPE_DEVICE_CREATE_INFO, | |
293 queueCreateInfoCount: 1, | |
294 pQueueCreateInfos: addr(queueInfo), | |
295 enabledLayerCount: 0, | |
296 ppEnabledLayerNames: nil, | |
297 enabledExtensionCount: uint32(deviceExtensions.len), | |
298 ppEnabledExtensionNames: deviceExtensionsC, | |
299 pEnabledFeatures: nil, | |
300 ) | |
301 checkVkResult vkCreateDevice( | |
1204 | 302 physicalDevice = vulkan.physicalDevice, |
1193 | 303 pCreateInfo = addr createDeviceInfo, |
304 pAllocator = nil, | |
1204 | 305 pDevice = addr vulkan.device |
1193 | 306 ) |
1204 | 307 vulkan.graphicsQueue = svkGetDeviceQueue(vulkan.device, vulkan.graphicsQueueFamily, VK_QUEUE_GRAPHICS_BIT) |
1193 | 308 |
1200
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
309 proc DestroyVulkan*() = |
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
310 vkDestroyDevice(vulkan.device, nil) |
1201 | 311 vkDestroySurfaceKHR(vulkan.instance, vulkan.surface, nil) |
312 vkDestroyDebugUtilsMessengerEXT(vulkan.instance, vulkan.debugMessenger, nil) | |
1200
5c6491f28dcd
did: simplify some swapchain stuff, add many destructor calls
sam <sam@basx.dev>
parents:
1199
diff
changeset
|
313 vkDestroyInstance(vulkan.instance, nil) |