| /************************************************************************** |
| * |
| * Copyright (C) 2019 Chromium. |
| * |
| * Permission is hereby granted, free of charge, to any person obtaining a |
| * copy of this software and associated documentation files (the "Software"), |
| * to deal in the Software without restriction, including without limitation |
| * the rights to use, copy, modify, merge, publish, distribute, sublicense, |
| * and/or sell copies of the Software, and to permit persons to whom the |
| * Software is furnished to do so, subject to the following conditions: |
| * |
| * The above copyright notice and this permission notice shall be included |
| * in all copies or substantial portions of the Software. |
| * |
| * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS |
| * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, |
| * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL |
| * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR |
| * OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, |
| * ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR |
| * OTHER DEALINGS IN THE SOFTWARE. |
| * |
| **************************************************************************/ |
| |
| #ifndef VIRGL_UTIL_H |
| #define VIRGL_UTIL_H |
| |
| #include <stdarg.h> |
| #include <stdbool.h> |
| #include <stdint.h> |
| |
| #ifdef HAVE_CONFIG_H |
| #include "config.h" |
| #endif |
| |
| #include "util/macros.h" |
| |
| #include "virglrenderer.h" |
| |
| #define TRACE_WITH_PERFETTO 1 |
| #define TRACE_WITH_STDERR 2 |
| #define TRACE_WITH_PERCETTO 3 |
| #define TRACE_WITH_SYSPROF 4 |
| |
| #define BIT(n) (UINT32_C(1) << (n)) |
| |
| static inline bool has_bit(uint32_t mask, uint32_t bit) |
| { |
| return !!(mask & bit); |
| } |
| |
| static inline bool has_bits(uint32_t mask, uint32_t bits) |
| { |
| return !!((mask & bits) == bits); |
| } |
| |
| static inline bool is_only_bit(uint32_t mask, uint32_t bit) |
| { |
| return (mask == bit); |
| } |
| |
| uint32_t hash_func_u32(const void *key); |
| |
| bool equal_func(const void *key1, const void *key2); |
| |
| bool has_eventfd(void); |
| int create_eventfd(unsigned int initval); |
| int write_eventfd(int fd, uint64_t val); |
| void flush_eventfd(int fd); |
| |
| virgl_debug_callback_type virgl_log_set_logger(virgl_debug_callback_type logger); |
| void virgl_logv(const char *fmt, va_list va); |
| |
| static inline void PRINTFLIKE(1, 2) virgl_log(const char *fmt, ...) |
| { |
| va_list va; |
| va_start(va, fmt); |
| virgl_logv(fmt, va); |
| va_end(va); |
| } |
| |
| #ifdef ENABLE_TRACING |
| void trace_init(void); |
| |
| #define TRACE_INIT() trace_init() |
| #define TRACE_FUNC() TRACE_SCOPE(__func__) |
| |
| #if ENABLE_TRACING == TRACE_WITH_PERCETTO |
| |
| #include <percetto.h> |
| |
| #define VIRGL_PERCETTO_CATEGORIES(C, G) \ |
| C(virgl, "virglrenderer") \ |
| C(virgls, "virglrenderer detailed events", "slow") |
| |
| PERCETTO_CATEGORY_DECLARE(VIRGL_PERCETTO_CATEGORIES) |
| |
| static inline void * |
| trace_begin(const char *scope) |
| { |
| TRACE_EVENT_BEGIN(virgl, scope); |
| return NULL; |
| } |
| |
| static inline void |
| trace_end(UNUSED void **scope) |
| { |
| TRACE_EVENT_END(virgl); |
| } |
| |
| #else |
| |
| void *trace_begin(const char *scope); |
| void trace_end(void **scope); |
| |
| #endif /* ENABLE_TRACING == TRACE_WITH_PERCETTO */ |
| |
| #define TRACE_SCOPE(SCOPE) \ |
| void *trace_dummy __attribute__((cleanup (trace_end), unused)) = \ |
| trace_begin(SCOPE) |
| #define TRACE_SCOPE_SLOW(SCOPE) TRACE_SCOPE(SCOPE) |
| #define TRACE_SCOPE_BEGIN(SCOPE) trace_begin(SCOPE) |
| #define TRACE_SCOPE_END(SCOPE_OBJ) trace_end(&SCOPE_OBJ) |
| |
| #else |
| #define TRACE_INIT() |
| #define TRACE_FUNC() |
| #define TRACE_SCOPE(SCOPE) |
| #define TRACE_SCOPE_SLOW(SCOPE) |
| #define TRACE_SCOPE_BEGIN(SCOPE) NULL |
| #define TRACE_SCOPE_END(SCOPE_OBJ) (void)SCOPE_OBJ |
| #endif /* ENABLE_TRACING */ |
| |
| #endif /* VIRGL_UTIL_H */ |