1 /**************************************************************************
5 * Copyright 2015 Samsung Electronics co., Ltd. All Rights Reserved.
7 * Contact: Eunchul Kim <chulspro.kim@samsung.com>,
8 * JinYoung Jeon <jy0.jeon@samsung.com>,
9 * Taeheon Kim <th908.kim@samsung.com>,
10 * YoungJun Cho <yj44.cho@samsung.com>,
11 * SooChan Lim <sc1.lim@samsung.com>,
12 * Boram Park <sc1.lim@samsung.com>
14 * Permission is hereby granted, free of charge, to any person obtaining a
15 * copy of this software and associated documentation files (the
16 * "Software"), to deal in the Software without restriction, including
17 * without limitation the rights to use, copy, modify, merge, publish,
18 * distribute, sub license, and/or sell copies of the Software, and to
19 * permit persons to whom the Software is furnished to do so, subject to
20 * the following conditions:
22 * The above copyright notice and this permission notice (including the
23 * next paragraph) shall be included in all copies or substantial portions
26 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
27 * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
28 * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NON-INFRINGEMENT.
29 * IN NO EVENT SHALL PRECISION INSIGHT AND/OR ITS SUPPLIERS BE LIABLE FOR
30 * ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
31 * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
32 * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
34 **************************************************************************/
47 #include <sys/syscall.h>
52 * @brief The header file to print logs in frontend and backend modules
54 * The TDM debug log can be enable by setting "TDM_DEBUG" enviroment
57 * $ export TDM_DEBUG=1
62 //#define TDM_CONFIG_DLOG
63 //#define TDM_CONFIG_ASSERT
66 #ifdef TDM_CONFIG_ASSERT
67 #define TDM_ASSERT(o) assert(o)
72 #ifdef TDM_CONFIG_DLOG
81 #define TDM_DBG(fmt, args...) \
85 clock_gettime(CLOCK_MONOTONIC, &ts); \
86 LOGD("[%d.%06d] "fmt"\n", (int)ts.tv_sec, (int)ts.tv_nsec / 1000, ##args); \
87 printf("[TDM_DBG][%d.%06d][%d][%s %d] "fmt"\n", (int)ts.tv_sec, \
88 (int)ts.tv_nsec / 1000, (int)syscall(SYS_gettid), __func__, __LINE__, ##args); \
91 #define TDM_INFO(fmt, args...) \
94 clock_gettime(CLOCK_MONOTONIC, &ts); \
95 LOGI("[%d.%06d] "fmt"\n", (int)ts.tv_sec, (int)ts.tv_nsec / 1000, ##args); \
96 printf("[TDM_INF][%d.%06d][%d][%s %d] "fmt"\n", (int)ts.tv_sec, \
97 (int)ts.tv_nsec / 1000, (int)syscall(SYS_gettid), __func__, __LINE__, ##args); \
100 #define TDM_WRN(fmt, args...) \
102 struct timespec ts; \
103 clock_gettime(CLOCK_MONOTONIC, &ts); \
104 LOGI("[%d.%06d] "fmt"\n", (int)ts.tv_sec, (int)ts.tv_nsec / 1000, ##args); \
105 printf("[TDM_WRN][%d.%06d][%d][%s %d] "fmt"\n", (int)ts.tv_sec, \
106 (int)ts.tv_nsec / 1000, (int)syscall(SYS_gettid), __func__, __LINE__, ##args); \
109 #define TDM_ERR(fmt, args...) \
111 struct timespec ts; \
112 clock_gettime(CLOCK_MONOTONIC, &ts); \
113 LOGE("[%d.%06d] "fmt"\n", (int)ts.tv_sec, (int)ts.tv_nsec / 1000, ##args); \
114 printf("[TDM_ERR][%d.%06d][%d][%s %d] "fmt"\n", (int)ts.tv_sec, \
115 (int)ts.tv_nsec / 1000, (int)syscall(SYS_gettid), __func__, __LINE__, ##args); \
118 #else /* TDM_CONFIG_DLOG */
122 #define COLOR_RED "\x1b[31m" /* for error */
123 #define COLOR_YELLOW "\x1b[33m" /* for warning */
124 #define COLOR_GREEN "\x1b[32m" /* for info */
125 #define COLOR_RESET "\x1b[0m"
127 #define TDM_DBG(fmt, args...) \
130 struct timespec ts; \
131 clock_gettime(CLOCK_MONOTONIC, &ts); \
132 printf("[TDM_DBG][%d.%06d][%d][%s %d] "fmt"\n", (int)ts.tv_sec, \
133 (int)ts.tv_nsec / 1000, (int)syscall(SYS_gettid), __func__, __LINE__, ##args); \
136 #define TDM_INFO(fmt, args...) \
138 struct timespec ts; \
139 clock_gettime(CLOCK_MONOTONIC, &ts); \
140 printf(COLOR_GREEN"[TDM_INF]"COLOR_RESET"[%d.%06d][%d][%s %d] "fmt"\n", (int)ts.tv_sec, \
141 (int)ts.tv_nsec / 1000, (int)syscall(SYS_gettid), __func__, __LINE__, ##args); \
144 #define TDM_WRN(fmt, args...) \
146 struct timespec ts; \
147 clock_gettime(CLOCK_MONOTONIC, &ts); \
148 printf(COLOR_YELLOW"[TDM_WRN]"COLOR_RESET"[%d.%06d][%d][%s %d] "fmt"\n", (int)ts.tv_sec, \
149 (int)ts.tv_nsec / 1000, (int)syscall(SYS_gettid), __func__, __LINE__, ##args); \
153 #define TDM_ERR(fmt, args...) \
155 struct timespec ts; \
156 clock_gettime(CLOCK_MONOTONIC, &ts); \
157 printf(COLOR_RED"[TDM_ERR]"COLOR_RESET"[%d.%06d][%d][%s %d] "fmt"\n", (int)ts.tv_sec, \
158 (int)ts.tv_nsec / 1000, (int)syscall(SYS_gettid), __func__, __LINE__, ##args); \
162 #endif /* TDM_CONFIG_DLOG */
168 #endif /* _TDM_LOG_H_ */