2019-03-18 05:52:32 +00:00
|
|
|
// Copyright 2019, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Debug messaging entrypoints for the OpenXR state tracker.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup oxr_api
|
|
|
|
*/
|
|
|
|
|
2021-02-22 20:35:16 +00:00
|
|
|
#include "util/u_trace_marker.h"
|
|
|
|
|
2019-03-18 05:52:32 +00:00
|
|
|
#include "oxr_objects.h"
|
|
|
|
#include "oxr_logger.h"
|
|
|
|
|
|
|
|
#include "oxr_api_funcs.h"
|
|
|
|
#include "oxr_api_verify.h"
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
XrResult
|
2021-01-14 14:13:48 +00:00
|
|
|
oxr_xrSetDebugUtilsObjectNameEXT(XrInstance instance, const XrDebugUtilsObjectNameInfoEXT *nameInfo)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2021-02-22 20:35:16 +00:00
|
|
|
OXR_TRACE_MARKER();
|
|
|
|
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst, "xrSetDebugUtilsObjectNameEXT");
|
2019-08-19 17:37:50 +00:00
|
|
|
OXR_VERIFY_EXTENSION(&log, inst, EXT_debug_utils);
|
2019-03-18 05:52:32 +00:00
|
|
|
return oxr_error(&log, XR_ERROR_RUNTIME_FAILURE, " not implemented");
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
2021-01-14 14:13:48 +00:00
|
|
|
oxr_xrCreateDebugUtilsMessengerEXT(XrInstance instance,
|
|
|
|
const XrDebugUtilsMessengerCreateInfoEXT *createInfo,
|
|
|
|
XrDebugUtilsMessengerEXT *messenger)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2021-02-22 20:35:16 +00:00
|
|
|
OXR_TRACE_MARKER();
|
|
|
|
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
|
|
|
struct oxr_debug_messenger *mssngr;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst, "xrCreateDebugUtilsMessengerEXT");
|
2019-08-19 17:37:50 +00:00
|
|
|
OXR_VERIFY_EXTENSION(&log, inst, EXT_debug_utils);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_VERIFY_ARG_TYPE_AND_NOT_NULL(&log, createInfo, XR_TYPE_DEBUG_UTILS_MESSENGER_CREATE_INFO_EXT);
|
2019-04-04 22:56:31 +00:00
|
|
|
OXR_VERIFY_ARG_NOT_NULL(&log, messenger);
|
|
|
|
|
|
|
|
XrResult ret = oxr_create_messenger(&log, inst, createInfo, &mssngr);
|
|
|
|
if (ret != XR_SUCCESS) {
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
|
|
|
*messenger = oxr_messenger_to_openxr(mssngr);
|
|
|
|
|
|
|
|
return XR_SUCCESS;
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrDestroyDebugUtilsMessengerEXT(XrDebugUtilsMessengerEXT messenger)
|
|
|
|
{
|
2021-02-22 20:35:16 +00:00
|
|
|
OXR_TRACE_MARKER();
|
|
|
|
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_debug_messenger *mssngr;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_VERIFY_MESSENGER_AND_INIT_LOG(&log, messenger, mssngr, "xrDestroyDebugUtilsMessengerEXT");
|
2019-08-19 17:37:50 +00:00
|
|
|
OXR_VERIFY_EXTENSION(&log, mssngr->inst, EXT_debug_utils);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2019-04-04 22:56:31 +00:00
|
|
|
return oxr_handle_destroy(&log, &mssngr->handle);
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
2021-01-14 14:13:48 +00:00
|
|
|
oxr_xrSubmitDebugUtilsMessageEXT(XrInstance instance,
|
|
|
|
XrDebugUtilsMessageSeverityFlagsEXT messageSeverity,
|
|
|
|
XrDebugUtilsMessageTypeFlagsEXT messageTypes,
|
|
|
|
const XrDebugUtilsMessengerCallbackDataEXT *callbackData)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2021-02-22 20:35:16 +00:00
|
|
|
OXR_TRACE_MARKER();
|
|
|
|
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_instance *inst;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_VERIFY_INSTANCE_AND_INIT_LOG(&log, instance, inst, "xrSubmitDebugUtilsMessageEXT");
|
2019-08-19 17:37:50 +00:00
|
|
|
OXR_VERIFY_EXTENSION(&log, inst, EXT_debug_utils);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
2019-04-04 22:56:31 +00:00
|
|
|
oxr_warn(&log, " not fully implemented");
|
|
|
|
return XR_SUCCESS;
|
2019-03-18 05:52:32 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
2021-01-14 14:13:48 +00:00
|
|
|
oxr_xrSessionBeginDebugUtilsLabelRegionEXT(XrSession session, const XrDebugUtilsLabelEXT *labelInfo)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2021-02-22 20:35:16 +00:00
|
|
|
OXR_TRACE_MARKER();
|
|
|
|
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_session *sess;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_VERIFY_SESSION_AND_INIT_LOG(&log, session, sess, "xrSessionBeginDebugUtilsLabelRegionEXT");
|
2019-08-19 17:37:50 +00:00
|
|
|
OXR_VERIFY_EXTENSION(&log, sess->sys->inst, EXT_debug_utils);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
return oxr_error(&log, XR_ERROR_RUNTIME_FAILURE, " not implemented");
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
|
|
|
oxr_xrSessionEndDebugUtilsLabelRegionEXT(XrSession session)
|
|
|
|
{
|
2021-02-22 20:35:16 +00:00
|
|
|
OXR_TRACE_MARKER();
|
|
|
|
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_session *sess;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_VERIFY_SESSION_AND_INIT_LOG(&log, session, sess, "xrSessionEndDebugUtilsLabelRegionEXT");
|
2019-08-19 17:37:50 +00:00
|
|
|
OXR_VERIFY_EXTENSION(&log, sess->sys->inst, EXT_debug_utils);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
return oxr_error(&log, XR_ERROR_RUNTIME_FAILURE, " not implemented");
|
|
|
|
}
|
|
|
|
|
|
|
|
XrResult
|
2021-01-14 14:13:48 +00:00
|
|
|
oxr_xrSessionInsertDebugUtilsLabelEXT(XrSession session, const XrDebugUtilsLabelEXT *labelInfo)
|
2019-03-18 05:52:32 +00:00
|
|
|
{
|
2021-02-22 20:35:16 +00:00
|
|
|
OXR_TRACE_MARKER();
|
|
|
|
|
2019-09-29 10:43:45 +00:00
|
|
|
struct oxr_session *sess;
|
2019-03-18 05:52:32 +00:00
|
|
|
struct oxr_logger log;
|
2021-01-14 14:13:48 +00:00
|
|
|
OXR_VERIFY_SESSION_AND_INIT_LOG(&log, session, sess, "xrSessionInsertDebugUtilsLabelEXT");
|
2019-08-19 17:37:50 +00:00
|
|
|
OXR_VERIFY_EXTENSION(&log, sess->sys->inst, EXT_debug_utils);
|
2019-03-18 05:52:32 +00:00
|
|
|
|
|
|
|
return oxr_error(&log, XR_ERROR_RUNTIME_FAILURE, " not implemented");
|
|
|
|
}
|