From 33ff7eb3f54e6f46d53156f3f7c5f830c2f4d6fa Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Pablo=20Delgado=20Kr=C3=A4mer?= Date: Fri, 26 Jul 2024 17:58:30 +0200 Subject: [PATCH] cgpu: use Vulkan pipeline cache --- src/cgpu/src/Cgpu.cpp | 34 +++++++++++++++++++++++++++++++--- 1 file changed, 31 insertions(+), 3 deletions(-) diff --git a/src/cgpu/src/Cgpu.cpp b/src/cgpu/src/Cgpu.cpp index 576b2f09..9db55449 100644 --- a/src/cgpu/src/Cgpu.cpp +++ b/src/cgpu/src/Cgpu.cpp @@ -71,6 +71,7 @@ namespace gtl CgpuPhysicalDeviceFeatures features; CgpuPhysicalDeviceProperties properties; VmaAllocator allocator; + VkPipelineCache pipelineCache; }; struct CgpuIBuffer @@ -1040,6 +1041,28 @@ namespace gtl CGPU_RETURN_ERROR("failed to create vma allocator"); } + VkPipelineCacheCreateInfo cacheCreateInfo = { + .sType = VK_STRUCTURE_TYPE_PIPELINE_CACHE_CREATE_INFO, + .pNext = nullptr, + .flags = VK_PIPELINE_CACHE_CREATE_EXTERNALLY_SYNCHRONIZED_BIT, // no MT access + .initialDataSize = 0, + .pInitialData = nullptr + }; + + result = idevice->table.vkCreatePipelineCache( + idevice->logicalDevice, + &cacheCreateInfo, + nullptr, + &idevice->pipelineCache + ); + + if (result != VK_SUCCESS) + { + CGPU_RETURN_ERROR("failed to create pipeline cache"); + + idevice->pipelineCache = VK_NULL_HANDLE; + } + device->handle = handle; return true; } @@ -1048,12 +1071,17 @@ namespace gtl { CGPU_RESOLVE_OR_RETURN_DEVICE(device, idevice); - vmaDestroyAllocator(idevice->allocator); + if (idevice->pipelineCache != VK_NULL_HANDLE) + { + idevice->table.vkDestroyPipelineCache(idevice->logicalDevice, idevice->pipelineCache, nullptr); + } idevice->table.vkDestroyQueryPool(idevice->logicalDevice, idevice->timestamp_pool, nullptr); idevice->table.vkDestroyCommandPool(idevice->logicalDevice, idevice->commandPool, nullptr); idevice->table.vkDestroyDevice(idevice->logicalDevice, nullptr); + vmaDestroyAllocator(idevice->allocator); + iinstance->ideviceStore.free(device.handle); return true; } @@ -1716,7 +1744,7 @@ namespace gtl VkResult result = idevice->table.vkCreateComputePipelines( idevice->logicalDevice, - VK_NULL_HANDLE, + idevice->pipelineCache, 1, &pipelineCreateInfo, nullptr, @@ -2002,7 +2030,7 @@ namespace gtl if (idevice->table.vkCreateRayTracingPipelinesKHR(idevice->logicalDevice, VK_NULL_HANDLE, - VK_NULL_HANDLE, + idevice->pipelineCache, 1, &rtPipelineCreateInfo, nullptr,