mirror of
https://gitlab.freedesktop.org/mesa/mesa.git
synced 2026-05-07 22:18:13 +02:00
vulkan: Make vk_debug_report_callback derive from vk_object_base
Fixes:51c6bc13ce"anv,vulkan: Implement VK_EXT_private_data" Reviewed-by: Bas Nieuwenhuizen <bas@basnieuwenhuizen.nl> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/8676> (cherry picked from commitbd1705a480)
This commit is contained in:
parent
a181bc63ae
commit
ca39949a27
3 changed files with 17 additions and 7 deletions
|
|
@ -3991,7 +3991,7 @@
|
|||
"description": "vulkan: Make vk_debug_report_callback derive from vk_object_base",
|
||||
"nominated": true,
|
||||
"nomination_type": 1,
|
||||
"resolution": 0,
|
||||
"resolution": 1,
|
||||
"master_sha": null,
|
||||
"because_sha": "51c6bc13ce3a70b1948ce5c4edbc1d29c5460986"
|
||||
},
|
||||
|
|
|
|||
|
|
@ -58,6 +58,9 @@ vk_create_debug_report_callback(struct vk_debug_report_instance *instance,
|
|||
if (!cb)
|
||||
return VK_ERROR_OUT_OF_HOST_MEMORY;
|
||||
|
||||
vk_object_base_init(NULL, &cb->base,
|
||||
VK_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT);
|
||||
|
||||
cb->flags = pCreateInfo->flags;
|
||||
cb->callback = pCreateInfo->pfnCallback;
|
||||
cb->data = pCreateInfo->pUserData;
|
||||
|
|
@ -66,7 +69,7 @@ vk_create_debug_report_callback(struct vk_debug_report_instance *instance,
|
|||
list_addtail(&cb->link, &instance->callbacks);
|
||||
mtx_unlock(&instance->callbacks_mutex);
|
||||
|
||||
*pCallback = (VkDebugReportCallbackEXT)(uintptr_t)cb;
|
||||
*pCallback = vk_debug_report_callback_to_handle(cb);
|
||||
|
||||
return VK_SUCCESS;
|
||||
}
|
||||
|
|
@ -77,19 +80,19 @@ vk_destroy_debug_report_callback(struct vk_debug_report_instance *instance,
|
|||
const VkAllocationCallbacks* pAllocator,
|
||||
const VkAllocationCallbacks* instance_allocator)
|
||||
{
|
||||
if (_callback == VK_NULL_HANDLE)
|
||||
return;
|
||||
VK_FROM_HANDLE(vk_debug_report_callback, callback, _callback);
|
||||
|
||||
struct vk_debug_report_callback *callback =
|
||||
(struct vk_debug_report_callback *)(uintptr_t)_callback;
|
||||
if (callback == NULL)
|
||||
return;
|
||||
|
||||
/* Remove from list and destroy given callback. */
|
||||
mtx_lock(&instance->callbacks_mutex);
|
||||
list_del(&callback->link);
|
||||
vk_free2(instance_allocator, pAllocator, callback);
|
||||
mtx_unlock(&instance->callbacks_mutex);
|
||||
}
|
||||
|
||||
vk_object_base_finish(&callback->base);
|
||||
}
|
||||
|
||||
void
|
||||
vk_debug_report(struct vk_debug_report_instance *instance,
|
||||
|
|
|
|||
|
|
@ -26,11 +26,15 @@
|
|||
#ifndef VK_DEBUG_REPORT_H
|
||||
#define VK_DEBUG_REPORT_H
|
||||
|
||||
#include "vk_object.h"
|
||||
|
||||
#include "c11/threads.h"
|
||||
#include "util/list.h"
|
||||
#include <vulkan/vulkan.h>
|
||||
|
||||
struct vk_debug_report_callback {
|
||||
struct vk_object_base base;
|
||||
|
||||
/* Link in the 'callbacks' list in anv_instance struct. */
|
||||
struct list_head link;
|
||||
VkDebugReportFlagsEXT flags;
|
||||
|
|
@ -38,6 +42,9 @@ struct vk_debug_report_callback {
|
|||
void * data;
|
||||
};
|
||||
|
||||
VK_DEFINE_HANDLE_CASTS(vk_debug_report_callback, base, VkDebugReportCallbackEXT,
|
||||
VK_OBJECT_TYPE_DEBUG_REPORT_CALLBACK_EXT)
|
||||
|
||||
struct vk_debug_report_instance {
|
||||
/* VK_EXT_debug_report debug callbacks */
|
||||
mtx_t callbacks_mutex;
|
||||
|
|
|
|||
Loading…
Add table
Reference in a new issue