From 5fbb3817ba71cbc479d0eb5e06f6800532eee7fa Mon Sep 17 00:00:00 2001 From: Serdar Kocdemir Date: Mon, 9 Jun 2025 11:19:00 +0000 Subject: [PATCH] gfxstream: Small optimization on transformDescriptorSetList Reduce number of possible allocations and remove unnecessary memory initialization which will be overwritten immediately. Test: dEQP-GLES31.functional.ssbo.layout.* Reviewed-by: Marcin Radomski Part-of: --- src/gfxstream/guest/vulkan/gfxstream_vk_device.cpp | 14 ++++++++------ 1 file changed, 8 insertions(+), 6 deletions(-) diff --git a/src/gfxstream/guest/vulkan/gfxstream_vk_device.cpp b/src/gfxstream/guest/vulkan/gfxstream_vk_device.cpp index 3c815724b34..2a943c0ec29 100644 --- a/src/gfxstream/guest/vulkan/gfxstream_vk_device.cpp +++ b/src/gfxstream/guest/vulkan/gfxstream_vk_device.cpp @@ -729,6 +729,7 @@ static std::vector transformDescriptorSetList( const VkWriteDescriptorSet* pDescriptorSets, uint32_t descriptorSetCount, std::vector>& bufferInfos) { std::vector outDescriptorSets(descriptorSetCount); + bufferInfos.resize(descriptorSetCount); for (uint32_t i = 0; i < descriptorSetCount; ++i) { const auto& srcDescriptorSet = pDescriptorSets[i]; const uint32_t descriptorCount = srcDescriptorSet.descriptorCount; @@ -736,19 +737,20 @@ static std::vector transformDescriptorSetList( VkWriteDescriptorSet& outDescriptorSet = outDescriptorSets[i]; outDescriptorSet = srcDescriptorSet; - bufferInfos.push_back(std::vector()); - bufferInfos[i].resize(descriptorCount); - memset(&bufferInfos[i][0], 0, sizeof(VkDescriptorBufferInfo) * descriptorCount); + std::vector& bufferInfo = bufferInfos[i]; + bufferInfo.resize(descriptorCount); for (uint32_t j = 0; j < descriptorCount; ++j) { const auto* srcBufferInfo = srcDescriptorSet.pBufferInfo; if (srcBufferInfo) { - bufferInfos[i][j] = srcBufferInfo[j]; - bufferInfos[i][j].buffer = VK_NULL_HANDLE; + bufferInfo[j] = srcBufferInfo[j]; + bufferInfo[j].buffer = VK_NULL_HANDLE; if (vk_descriptor_type_has_descriptor_buffer(srcDescriptorSet.descriptorType) && srcBufferInfo[j].buffer) { VK_FROM_HANDLE(gfxstream_vk_buffer, gfxstreamBuffer, srcBufferInfo[j].buffer); - bufferInfos[i][j].buffer = gfxstreamBuffer->internal_object; + bufferInfo[j].buffer = gfxstreamBuffer->internal_object; } + } else { + memset(&bufferInfo[j], 0, sizeof(VkDescriptorBufferInfo)); } } outDescriptorSet.pBufferInfo = bufferInfos[i].data();