]> git.tdb.fi Git - libs/gl.git/blobdiff - source/backends/vulkan/texturecube_backend.cpp
Add a wrapper class for recording Vulkan commands
[libs/gl.git] / source / backends / vulkan / texturecube_backend.cpp
index a92247d56746ed22426cf90a2e26867b718e3b35..f0b941bfbe14e32d9e222db6e80cf0f940d5835a 100644 (file)
@@ -37,9 +37,7 @@ void VulkanTextureCube::sub_image(unsigned face, unsigned level, int x, int y, u
                [this, level, discard](){
                        change_layout(level, VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL, discard);
                },
-               [this, face, level, x, y, wd, ht](VkCommandBuffer cmd_buf, VkBuffer staging_buf, size_t src_off){
-                       const VulkanFunctions &vk = device.get_functions();
-
+               [this, face, level, x, y, wd, ht](const VulkanCommandRecorder &vkCmd, VkBuffer staging_buf, size_t src_off){
                        VkBufferImageCopy region = { };
                        region.bufferOffset = src_off;
                        region.imageSubresource.aspectMask = get_vulkan_aspect(get_components(storage_fmt));
@@ -48,7 +46,7 @@ void VulkanTextureCube::sub_image(unsigned face, unsigned level, int x, int y, u
                        region.imageSubresource.layerCount = 1;
                        region.imageOffset = { x, y, 0 };
                        region.imageExtent = { wd, ht, 1 };
-                       vk.CmdCopyBufferToImage(cmd_buf, staging_buf, handle, VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL, 1, &region);
+                       vkCmd.CopyBufferToImage(staging_buf, handle, VK_IMAGE_LAYOUT_TRANSFER_DST_OPTIMAL, 1, &region);
                });
 
        stage_pixels(staging, data, wd*ht);