blob: 0cb713c4c3c19f8eaf8d0e68bf3676ce4550f4a0 [file] [log] [blame] [edit]
// 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 <vulkan/vulkan.h>
#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 <typename VkObjectT, typename... T>
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<VkObjectT, VkBuffer>) {
objectType = VK_OBJECT_TYPE_BUFFER;
} else if constexpr (std::is_same_v<VkObjectT, VkCommandBuffer>) {
objectType = VK_OBJECT_TYPE_COMMAND_BUFFER;
} else if constexpr (std::is_same_v<VkObjectT, VkCommandPool>) {
objectType = VK_OBJECT_TYPE_COMMAND_POOL;
} else if constexpr (std::is_same_v<VkObjectT, VkDescriptorSet>) {
objectType = VK_OBJECT_TYPE_DESCRIPTOR_SET;
} else if constexpr (std::is_same_v<VkObjectT, VkDevice>) {
objectType = VK_OBJECT_TYPE_DEVICE;
} else if constexpr (std::is_same_v<VkObjectT, VkDeviceMemory>) {
objectType = VK_OBJECT_TYPE_DEVICE_MEMORY;
} else if constexpr (std::is_same_v<VkObjectT, VkFence>) {
objectType = VK_OBJECT_TYPE_FENCE;
} else if constexpr (std::is_same_v<VkObjectT, VkFramebuffer>) {
objectType = VK_OBJECT_TYPE_FRAMEBUFFER;
} else if constexpr (std::is_same_v<VkObjectT, VkImage>) {
objectType = VK_OBJECT_TYPE_IMAGE;
} else if constexpr (std::is_same_v<VkObjectT, VkImageView>) {
objectType = VK_OBJECT_TYPE_IMAGE_VIEW;
} else if constexpr (std::is_same_v<VkObjectT, VkInstance>) {
objectType = VK_OBJECT_TYPE_INSTANCE;
} else if constexpr (std::is_same_v<VkObjectT, VkPipeline>) {
objectType = VK_OBJECT_TYPE_PIPELINE;
} else if constexpr (std::is_same_v<VkObjectT, VkSampler>) {
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<T>(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