2020-07-03 13:27:39 +00:00
|
|
|
// Copyright 2019-2020, Collabora, Ltd.
|
|
|
|
// SPDX-License-Identifier: BSL-1.0
|
|
|
|
/*!
|
|
|
|
* @file
|
|
|
|
* @brief Logging functions.
|
|
|
|
* @author Jakob Bornecrantz <jakob@collabora.com>
|
|
|
|
* @ingroup aux_util
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "util/u_logging.h"
|
2020-09-02 16:31:39 +00:00
|
|
|
#include "xrt/xrt_config_os.h"
|
2020-12-18 10:17:48 +00:00
|
|
|
#include "xrt/xrt_config_build.h"
|
2020-07-03 13:27:39 +00:00
|
|
|
|
2020-12-18 14:30:19 +00:00
|
|
|
#include "util/u_debug.h"
|
|
|
|
|
2020-07-03 13:27:39 +00:00
|
|
|
#include <assert.h>
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <stdarg.h>
|
|
|
|
|
2020-12-18 14:30:19 +00:00
|
|
|
DEBUG_GET_ONCE_LOG_OPTION(global_log, "XRT_LOG", U_LOGGING_WARN)
|
|
|
|
|
|
|
|
enum u_logging_level global_log_level;
|
|
|
|
|
|
|
|
static bool _is_log_level_initialized;
|
|
|
|
|
|
|
|
void
|
|
|
|
_log_level_init()
|
|
|
|
{
|
|
|
|
if (!_is_log_level_initialized) {
|
|
|
|
global_log_level = debug_get_log_option_global_log();
|
|
|
|
_is_log_level_initialized = true;
|
|
|
|
}
|
|
|
|
}
|
2020-07-03 13:27:39 +00:00
|
|
|
|
2020-11-20 16:11:17 +00:00
|
|
|
#if defined(XRT_OS_ANDROID)
|
2020-09-02 16:31:39 +00:00
|
|
|
|
|
|
|
#include <android/log.h>
|
|
|
|
|
|
|
|
static android_LogPriority
|
|
|
|
u_log_convert_priority(enum u_logging_level level)
|
|
|
|
{
|
|
|
|
switch (level) {
|
|
|
|
case U_LOGGING_TRACE: return ANDROID_LOG_VERBOSE;
|
|
|
|
case U_LOGGING_DEBUG: return ANDROID_LOG_DEBUG;
|
|
|
|
case U_LOGGING_INFO: return ANDROID_LOG_INFO;
|
|
|
|
case U_LOGGING_WARN: return ANDROID_LOG_WARN;
|
|
|
|
case U_LOGGING_ERROR: return ANDROID_LOG_ERROR;
|
|
|
|
case U_LOGGING_RAW: return ANDROID_LOG_INFO;
|
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
return ANDROID_LOG_INFO;
|
|
|
|
}
|
|
|
|
void
|
|
|
|
u_log(const char *file,
|
|
|
|
int line,
|
|
|
|
const char *func,
|
|
|
|
enum u_logging_level level,
|
|
|
|
const char *format,
|
|
|
|
...)
|
|
|
|
{
|
2020-12-18 14:30:19 +00:00
|
|
|
_log_level_init();
|
2020-09-02 16:31:39 +00:00
|
|
|
// print_prefix(func, level);
|
|
|
|
android_LogPriority prio = u_log_convert_priority(level);
|
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
|
|
|
__android_log_vprint(prio, func, format, args);
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
u_log_xdev(const char *file,
|
|
|
|
int line,
|
|
|
|
const char *func,
|
|
|
|
enum u_logging_level level,
|
|
|
|
struct xrt_device *xdev,
|
|
|
|
const char *format,
|
|
|
|
...)
|
|
|
|
{
|
2020-12-18 14:30:19 +00:00
|
|
|
_log_level_init();
|
2020-09-02 16:31:39 +00:00
|
|
|
android_LogPriority prio = u_log_convert_priority(level);
|
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
|
|
|
__android_log_vprint(prio, func, format, args);
|
|
|
|
va_end(args);
|
|
|
|
}
|
|
|
|
|
2020-11-20 16:11:17 +00:00
|
|
|
|
|
|
|
#elif defined(XRT_OS_WINDOWS)
|
|
|
|
|
|
|
|
#include <debugapi.h>
|
|
|
|
|
|
|
|
static int
|
|
|
|
print_prefix(int remainingBuf,
|
|
|
|
char *buf,
|
|
|
|
const char *func,
|
|
|
|
enum u_logging_level level)
|
|
|
|
{
|
|
|
|
int printed = 0;
|
|
|
|
switch (level) {
|
|
|
|
case U_LOGGING_TRACE:
|
|
|
|
printed = sprintf_s(buf, remainingBuf, "TRACE ");
|
|
|
|
break;
|
|
|
|
case U_LOGGING_DEBUG:
|
|
|
|
printed = sprintf_s(buf, remainingBuf, "DEBUG ");
|
|
|
|
break;
|
|
|
|
case U_LOGGING_INFO:
|
2020-12-17 12:02:10 +00:00
|
|
|
printed = sprintf_s(buf, remainingBuf, " INFO ");
|
2020-11-20 16:11:17 +00:00
|
|
|
break;
|
|
|
|
case U_LOGGING_WARN:
|
2020-12-17 12:02:10 +00:00
|
|
|
printed = sprintf_s(buf, remainingBuf, " WARN ");
|
2020-11-20 16:11:17 +00:00
|
|
|
break;
|
|
|
|
case U_LOGGING_ERROR:
|
|
|
|
printed = sprintf_s(buf, remainingBuf, "ERROR ");
|
|
|
|
break;
|
|
|
|
case U_LOGGING_RAW: break;
|
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (level != U_LOGGING_RAW && func != NULL) {
|
|
|
|
printed = sprintf_s(buf + printed, remainingBuf - printed,
|
|
|
|
"[%s] ", func);
|
|
|
|
}
|
|
|
|
return printed;
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
u_log(const char *file,
|
|
|
|
int line,
|
|
|
|
const char *func,
|
|
|
|
enum u_logging_level level,
|
|
|
|
const char *format,
|
|
|
|
...)
|
|
|
|
{
|
2020-12-18 14:30:19 +00:00
|
|
|
_log_level_init();
|
|
|
|
|
2020-11-20 16:11:17 +00:00
|
|
|
char buf[16384] = {0};
|
|
|
|
|
|
|
|
int remainingBuffer = sizeof(buf) - 2;
|
|
|
|
int printed = print_prefix(remainingBuffer, buf, func, level);
|
|
|
|
|
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
|
|
|
printed +=
|
|
|
|
vsprintf_s(buf + printed, remainingBuffer - printed, format, args);
|
|
|
|
va_end(args);
|
|
|
|
*(buf + printed) = '\n';
|
|
|
|
OutputDebugStringA(buf);
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
u_log_xdev(const char *file,
|
|
|
|
int line,
|
|
|
|
const char *func,
|
|
|
|
enum u_logging_level level,
|
|
|
|
struct xrt_device *xdev,
|
|
|
|
const char *format,
|
|
|
|
...)
|
|
|
|
{
|
2020-12-18 14:30:19 +00:00
|
|
|
_log_level_init();
|
|
|
|
|
2020-11-20 16:11:17 +00:00
|
|
|
char buf[16384] = {0};
|
|
|
|
|
|
|
|
int remainingBuffer = sizeof(buf) - 1;
|
|
|
|
int printed = print_prefix(remainingBuffer, buf, func, level);
|
|
|
|
|
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
|
|
|
vsprintf_s(buf + printed, remainingBuffer - printed, format, args);
|
|
|
|
va_end(args);
|
|
|
|
OutputDebugStringA(buf);
|
|
|
|
}
|
|
|
|
|
|
|
|
|
2020-09-02 16:31:39 +00:00
|
|
|
#else
|
2020-12-18 10:17:48 +00:00
|
|
|
|
|
|
|
#include <unistd.h>
|
|
|
|
|
2020-07-03 13:27:39 +00:00
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Helper functions.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2020-12-18 10:17:48 +00:00
|
|
|
|
|
|
|
#ifdef XRT_FEATURE_COLOR_LOG
|
|
|
|
#define COLOR_TRACE "\033[2m"
|
|
|
|
#define COLOR_DEBUG "\033[36m"
|
|
|
|
#define COLOR_INFO "\033[32m"
|
|
|
|
#define COLOR_WARN "\033[33m"
|
|
|
|
#define COLOR_ERROR "\033[31m"
|
|
|
|
#define COLOR_RESET "\033[0m"
|
|
|
|
|
2020-07-03 13:27:39 +00:00
|
|
|
static void
|
2020-12-18 10:17:48 +00:00
|
|
|
print_prefix_color(const char *func, enum u_logging_level level)
|
|
|
|
{
|
|
|
|
switch (level) {
|
|
|
|
case U_LOGGING_TRACE:
|
|
|
|
fprintf(stderr, COLOR_TRACE "TRACE " COLOR_RESET);
|
|
|
|
break;
|
|
|
|
case U_LOGGING_DEBUG:
|
|
|
|
fprintf(stderr, COLOR_DEBUG "DEBUG " COLOR_RESET);
|
|
|
|
break;
|
|
|
|
case U_LOGGING_INFO:
|
|
|
|
fprintf(stderr, COLOR_INFO " INFO " COLOR_RESET);
|
|
|
|
break;
|
|
|
|
case U_LOGGING_WARN:
|
|
|
|
fprintf(stderr, COLOR_WARN " WARN " COLOR_RESET);
|
|
|
|
break;
|
|
|
|
case U_LOGGING_ERROR:
|
|
|
|
fprintf(stderr, COLOR_ERROR "ERROR " COLOR_RESET);
|
|
|
|
break;
|
|
|
|
case U_LOGGING_RAW: break;
|
|
|
|
default: break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static void
|
|
|
|
print_prefix_mono(const char *func, enum u_logging_level level)
|
2020-07-03 13:27:39 +00:00
|
|
|
{
|
|
|
|
switch (level) {
|
2020-07-09 11:17:48 +00:00
|
|
|
case U_LOGGING_TRACE: fprintf(stderr, "TRACE "); break;
|
|
|
|
case U_LOGGING_DEBUG: fprintf(stderr, "DEBUG "); break;
|
2020-12-17 12:02:10 +00:00
|
|
|
case U_LOGGING_INFO: fprintf(stderr, " INFO "); break;
|
|
|
|
case U_LOGGING_WARN: fprintf(stderr, " WARN "); break;
|
2020-07-09 11:17:48 +00:00
|
|
|
case U_LOGGING_ERROR: fprintf(stderr, "ERROR "); break;
|
2020-07-03 13:27:39 +00:00
|
|
|
case U_LOGGING_RAW: break;
|
|
|
|
default: break;
|
|
|
|
}
|
2020-12-18 10:17:48 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
print_prefix(const char *func, enum u_logging_level level)
|
|
|
|
{
|
|
|
|
#ifdef XRT_FEATURE_COLOR_LOG
|
|
|
|
if (isatty(STDERR_FILENO)) {
|
|
|
|
print_prefix_color(func, level);
|
|
|
|
} else {
|
|
|
|
print_prefix_mono(func, level);
|
|
|
|
}
|
|
|
|
#else
|
|
|
|
print_prefix_mono(func, level);
|
|
|
|
#endif
|
2020-07-09 11:17:48 +00:00
|
|
|
|
|
|
|
if (level != U_LOGGING_RAW && func != NULL) {
|
|
|
|
fprintf(stderr, "[%s] ", func);
|
|
|
|
}
|
2020-07-03 13:27:39 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* 'Exported' functions.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
void
|
|
|
|
u_log(const char *file,
|
|
|
|
int line,
|
|
|
|
const char *func,
|
|
|
|
enum u_logging_level level,
|
|
|
|
const char *format,
|
|
|
|
...)
|
|
|
|
{
|
2020-12-18 14:30:19 +00:00
|
|
|
_log_level_init();
|
|
|
|
|
2020-07-03 13:27:39 +00:00
|
|
|
print_prefix(func, level);
|
|
|
|
|
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
|
|
|
vfprintf(stderr, format, args);
|
|
|
|
va_end(args);
|
|
|
|
|
|
|
|
fprintf(stderr, "\n");
|
|
|
|
}
|
|
|
|
|
|
|
|
void
|
|
|
|
u_log_xdev(const char *file,
|
|
|
|
int line,
|
|
|
|
const char *func,
|
|
|
|
enum u_logging_level level,
|
|
|
|
struct xrt_device *xdev,
|
|
|
|
const char *format,
|
|
|
|
...)
|
|
|
|
{
|
2020-12-18 14:30:19 +00:00
|
|
|
_log_level_init();
|
|
|
|
|
2020-07-03 13:27:39 +00:00
|
|
|
print_prefix(func, level);
|
|
|
|
|
|
|
|
va_list args;
|
|
|
|
va_start(args, format);
|
|
|
|
vfprintf(stderr, format, args);
|
|
|
|
va_end(args);
|
|
|
|
|
|
|
|
fprintf(stderr, "\n");
|
|
|
|
}
|
2020-09-02 16:31:39 +00:00
|
|
|
#endif
|