Path: blob/master/libs/vkd3d/include/private/vkd3d_debug.h
4393 views
/*1* Copyright 2016 Józef Kucia for CodeWeavers2*3* This library is free software; you can redistribute it and/or4* modify it under the terms of the GNU Lesser General Public5* License as published by the Free Software Foundation; either6* version 2.1 of the License, or (at your option) any later version.7*8* This library is distributed in the hope that it will be useful,9* but WITHOUT ANY WARRANTY; without even the implied warranty of10* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU11* Lesser General Public License for more details.12*13* You should have received a copy of the GNU Lesser General Public14* License along with this library; if not, write to the Free Software15* Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA16*/1718#ifndef __VKD3D_DEBUG_H19#define __VKD3D_DEBUG_H2021#include "vkd3d_common.h"2223#include <stdarg.h>24#include <stdbool.h>25#include <stdint.h>2627#ifdef VKD3D_NO_TRACE_MESSAGES28#define TRACE(args...) do { } while (0)29#define TRACE_ON() (false)30#endif3132#ifdef VKD3D_NO_DEBUG_MESSAGES33#define WARN(args...) do { } while (0)34#define FIXME(args...) do { } while (0)35#endif3637enum vkd3d_dbg_level38{39VKD3D_DBG_LEVEL_NONE,40VKD3D_DBG_LEVEL_ERR,41VKD3D_DBG_LEVEL_FIXME,42VKD3D_DBG_LEVEL_WARN,43VKD3D_DBG_LEVEL_TRACE,44};4546enum vkd3d_dbg_level vkd3d_dbg_get_level(void);4748void vkd3d_dbg_printf(enum vkd3d_dbg_level level, const char *function, const char *fmt, ...) VKD3D_PRINTF_FUNC(3, 4);49void vkd3d_dbg_set_log_callback(PFN_vkd3d_log callback);5051const char *vkd3d_dbg_sprintf(const char *fmt, ...) VKD3D_PRINTF_FUNC(1, 2);52const char *vkd3d_dbg_vsprintf(const char *fmt, va_list args);53const char *debugstr_a(const char *str);54const char *debugstr_an(const char *str, size_t n);55const char *debugstr_w(const WCHAR *wstr, size_t wchar_size);5657#define VKD3D_DBG_LOG(level) \58do { \59const enum vkd3d_dbg_level vkd3d_dbg_level = VKD3D_DBG_LEVEL_##level; \60VKD3D_DBG_PRINTF6162#define VKD3D_DBG_LOG_ONCE(first_time_level, level) \63do { \64static bool vkd3d_dbg_next_time; \65const enum vkd3d_dbg_level vkd3d_dbg_level = vkd3d_dbg_next_time \66? VKD3D_DBG_LEVEL_##level : VKD3D_DBG_LEVEL_##first_time_level; \67vkd3d_dbg_next_time = true; \68VKD3D_DBG_PRINTF6970#define VKD3D_DBG_PRINTF(...) \71vkd3d_dbg_printf(vkd3d_dbg_level, __FUNCTION__, __VA_ARGS__); } while (0)7273#ifndef TRACE74#define TRACE VKD3D_DBG_LOG(TRACE)75#endif7677#ifndef WARN78#define WARN VKD3D_DBG_LOG(WARN)79#endif8081#ifndef FIXME82#define FIXME VKD3D_DBG_LOG(FIXME)83#endif8485#define ERR VKD3D_DBG_LOG(ERR)8687#ifndef TRACE_ON88#define TRACE_ON() (vkd3d_dbg_get_level() == VKD3D_DBG_LEVEL_TRACE)89#endif9091#ifndef WARN_ON92#define WARN_ON() (vkd3d_dbg_get_level() >= VKD3D_DBG_LEVEL_WARN)93#endif9495#define FIXME_ONCE VKD3D_DBG_LOG_ONCE(FIXME, WARN)9697#define VKD3D_DEBUG_ENV_NAME(name) const char *const vkd3d_dbg_env_name = name9899static inline const char *debugstr_guid(const GUID *guid)100{101if (!guid)102return "(null)";103104return vkd3d_dbg_sprintf("{%08lx-%04x-%04x-%02x%02x-%02x%02x%02x%02x%02x%02x}",105(unsigned long)guid->Data1, guid->Data2, guid->Data3, guid->Data4[0],106guid->Data4[1], guid->Data4[2], guid->Data4[3], guid->Data4[4],107guid->Data4[5], guid->Data4[6], guid->Data4[7]);108}109110static inline const char *debugstr_hresult(HRESULT hr)111{112switch (hr)113{114#define TO_STR(u) case u: return #u;115TO_STR(S_OK)116TO_STR(S_FALSE)117TO_STR(E_NOTIMPL)118TO_STR(E_NOINTERFACE)119TO_STR(E_POINTER)120TO_STR(E_ABORT)121TO_STR(E_FAIL)122TO_STR(E_OUTOFMEMORY)123TO_STR(E_INVALIDARG)124TO_STR(DXGI_ERROR_NOT_FOUND)125TO_STR(DXGI_ERROR_MORE_DATA)126TO_STR(DXGI_ERROR_UNSUPPORTED)127#undef TO_STR128default:129return vkd3d_dbg_sprintf("%#x", (int)hr);130}131}132133unsigned int vkd3d_env_var_as_uint(const char *name, unsigned int default_value);134135struct vkd3d_debug_option136{137const char *name;138uint64_t flag;139};140141bool vkd3d_debug_list_has_member(const char *string, const char *member);142uint64_t vkd3d_parse_debug_options(const char *string,143const struct vkd3d_debug_option *options, unsigned int option_count);144void vkd3d_set_thread_name(const char *name);145146#endif /* __VKD3D_DEBUG_H */147148149