forked from eden-emu/eden
		
	renderer_vulkan/wrapper: Add pool handles
This commit is contained in:
		
							parent
							
								
									affee77b70
								
							
						
					
					
						commit
						397f53dea1
					
				
					 2 changed files with 47 additions and 0 deletions
				
			
		|  | @ -428,4 +428,36 @@ void Image::BindMemory(VkDeviceMemory memory, VkDeviceSize offset) const { | ||||||
|     Check(dld->vkBindImageMemory(owner, handle, memory, offset)); |     Check(dld->vkBindImageMemory(owner, handle, memory, offset)); | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
|  | DescriptorSets DescriptorPool::Allocate(const VkDescriptorSetAllocateInfo& ai) const { | ||||||
|  |     const std::size_t num = ai.descriptorSetCount; | ||||||
|  |     std::unique_ptr sets = std::make_unique<VkDescriptorSet[]>(num); | ||||||
|  |     switch (const VkResult result = dld->vkAllocateDescriptorSets(owner, &ai, sets.get())) { | ||||||
|  |     case VK_SUCCESS: | ||||||
|  |         return DescriptorSets(std::move(sets), num, owner, handle, *dld); | ||||||
|  |     case VK_ERROR_OUT_OF_POOL_MEMORY: | ||||||
|  |         return {}; | ||||||
|  |     default: | ||||||
|  |         throw Exception(result); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | CommandBuffers CommandPool::Allocate(std::size_t num_buffers, VkCommandBufferLevel level) const { | ||||||
|  |     VkCommandBufferAllocateInfo ai; | ||||||
|  |     ai.sType = VK_STRUCTURE_TYPE_COMMAND_BUFFER_ALLOCATE_INFO; | ||||||
|  |     ai.pNext = nullptr; | ||||||
|  |     ai.commandPool = handle; | ||||||
|  |     ai.level = level; | ||||||
|  |     ai.commandBufferCount = static_cast<u32>(num_buffers); | ||||||
|  | 
 | ||||||
|  |     std::unique_ptr buffers = std::make_unique<VkCommandBuffer[]>(num_buffers); | ||||||
|  |     switch (const VkResult result = dld->vkAllocateCommandBuffers(owner, &ai, buffers.get())) { | ||||||
|  |     case VK_SUCCESS: | ||||||
|  |         return CommandBuffers(std::move(buffers), num_buffers, owner, handle, *dld); | ||||||
|  |     case VK_ERROR_OUT_OF_POOL_MEMORY: | ||||||
|  |         return {}; | ||||||
|  |     default: | ||||||
|  |         throw Exception(result); | ||||||
|  |     } | ||||||
|  | } | ||||||
|  | 
 | ||||||
| } // namespace Vulkan::vk
 | } // namespace Vulkan::vk
 | ||||||
|  |  | ||||||
|  | @ -600,4 +600,19 @@ public: | ||||||
|     void BindMemory(VkDeviceMemory memory, VkDeviceSize offset) const; |     void BindMemory(VkDeviceMemory memory, VkDeviceSize offset) const; | ||||||
| }; | }; | ||||||
| 
 | 
 | ||||||
|  | class DescriptorPool : public Handle<VkDescriptorPool, VkDevice, DeviceDispatch> { | ||||||
|  |     using Handle<VkDescriptorPool, VkDevice, DeviceDispatch>::Handle; | ||||||
|  | 
 | ||||||
|  | public: | ||||||
|  |     DescriptorSets Allocate(const VkDescriptorSetAllocateInfo& ai) const; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
|  | class CommandPool : public Handle<VkCommandPool, VkDevice, DeviceDispatch> { | ||||||
|  |     using Handle<VkCommandPool, VkDevice, DeviceDispatch>::Handle; | ||||||
|  | 
 | ||||||
|  | public: | ||||||
|  |     CommandBuffers Allocate(std::size_t num_buffers, | ||||||
|  |                             VkCommandBufferLevel level = VK_COMMAND_BUFFER_LEVEL_PRIMARY) const; | ||||||
|  | }; | ||||||
|  | 
 | ||||||
| } // namespace Vulkan::vk
 | } // namespace Vulkan::vk
 | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue
	
	 ReinUsesLisp
						ReinUsesLisp