// Copyright 2022 The Android Open Source Project // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either expresso or implied. // See the License for the specific language governing permissions and // limitations under the License. #pragma once #include #include "goldfish_vk_dispatch.h" namespace gfxstream { namespace vk { class DebugUtilsHelper { public: static DebugUtilsHelper withUtilsEnabled(VkDevice device, const VulkanDispatch* dispatch); static DebugUtilsHelper withUtilsDisabled(); ~DebugUtilsHelper() = default; template void addDebugLabel(VkObjectT object, const char* format, T&&... formatArgs) const { if (!m_debugUtilsEnabled) { return; } VkObjectType objectType = VK_OBJECT_TYPE_UNKNOWN; if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_BUFFER; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_COMMAND_BUFFER; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_COMMAND_POOL; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_DESCRIPTOR_SET; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_DEVICE; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_DEVICE_MEMORY; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_FENCE; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_FRAMEBUFFER; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_IMAGE; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_IMAGE_VIEW; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_INSTANCE; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_PIPELINE; } else if constexpr (std::is_same_v) { objectType = VK_OBJECT_TYPE_SAMPLER; } else { static_assert(sizeof(VkObjectT) == 0, "Unhandled VkObjectT. Please update DebugUtilsHelper.h."); } addDebugLabelToHandle((uint64_t)object, objectType, format, std::forward(formatArgs)...); } void cmdBeginDebugLabel(VkCommandBuffer commandBuffer, const char* format, ...) const; void cmdEndDebugLabel(VkCommandBuffer commandBuffer) const; bool isEnabled() const { return m_debugUtilsEnabled; } private: DebugUtilsHelper(bool enabled, VkDevice device, const VulkanDispatch* dispatch); void addDebugLabelToHandle(uint64_t object, VkObjectType objectType, const char* format, ...) const; bool m_debugUtilsEnabled = false; VkDevice m_vkDevice = VK_NULL_HANDLE; const VulkanDispatch* m_vk = nullptr; }; } // namespace vk } // namespace gfxstream