From 9172c7bf11a3dbb663e170f57692e68891e891c9 Mon Sep 17 00:00:00 2001 From: Mark Lobodzinski Date: Tue, 28 Feb 2017 15:09:31 -0700 Subject: layers: Special-case threading GetSwapchainImages This API is a special-case for the code-gen in that it sometimes returns an array of images. These do not need to be counted by start/finishReadObject and so were moved into the non-generated part of the layer source. Change-Id: Iaaab9143abadbf025b5f3c118aa26dae3c6f1bec --- layers/threading.cpp | 21 +++++++++++++++++++++ 1 file changed, 21 insertions(+) (limited to 'layers/threading.cpp') diff --git a/layers/threading.cpp b/layers/threading.cpp index 0c46ef03..5984c4c8 100644 --- a/layers/threading.cpp +++ b/layers/threading.cpp @@ -171,6 +171,27 @@ VKAPI_ATTR void VKAPI_CALL DestroyDevice(VkDevice device, const VkAllocationCall layer_data_map.erase(key); } +VKAPI_ATTR VkResult VKAPI_CALL GetSwapchainImagesKHR(VkDevice device, VkSwapchainKHR swapchain, uint32_t *pSwapchainImageCount, + VkImage *pSwapchainImages) { + dispatch_key key = get_dispatch_key(device); + layer_data *my_data = GetLayerDataPtr(key, layer_data_map); + VkLayerDispatchTable *pTable = my_data->device_dispatch_table; + VkResult result; + bool threadChecks = startMultiThread(); + if (threadChecks) { + startReadObject(my_data, device); + startReadObject(my_data, swapchain); + } + result = pTable->GetSwapchainImagesKHR(device, swapchain, pSwapchainImageCount, pSwapchainImages); + if (threadChecks) { + finishReadObject(my_data, device); + finishReadObject(my_data, swapchain); + } else { + finishMultiThread(); + } + return result; +} + static const VkExtensionProperties threading_extensions[] = { {VK_EXT_DEBUG_REPORT_EXTENSION_NAME, VK_EXT_DEBUG_REPORT_SPEC_VERSION}}; -- cgit v1.2.3