xref: /optee_os/lib/libutils/ext/include/trace.h (revision ea4ae5cd45aa2cc78975c7d90f228f3b04d8b4e6)
11bb92983SJerome Forissier /* SPDX-License-Identifier: BSD-2-Clause */
24de4bebcSJens Wiklander /*
34de4bebcSJens Wiklander  * Copyright (c) 2014, STMicroelectronics International N.V.
44de4bebcSJens Wiklander  */
54de4bebcSJens Wiklander #ifndef TRACE_H
64de4bebcSJens Wiklander #define TRACE_H
74de4bebcSJens Wiklander 
83dd0e94eSJens Wiklander #include <compiler.h>
93dd0e94eSJens Wiklander #include <stdarg.h>
104de4bebcSJens Wiklander #include <stdbool.h>
114de4bebcSJens Wiklander #include <stddef.h>
124de4bebcSJens Wiklander #include <trace_levels.h>
134de4bebcSJens Wiklander 
144de4bebcSJens Wiklander #define MAX_PRINT_SIZE      256
154de4bebcSJens Wiklander #define MAX_FUNC_PRINT_SIZE 32
164de4bebcSJens Wiklander 
178a1e7b89SJerome Forissier #ifndef TRACE_LEVEL
188a1e7b89SJerome Forissier #define TRACE_LEVEL TRACE_MAX
194de4bebcSJens Wiklander #endif
204de4bebcSJens Wiklander 
214de4bebcSJens Wiklander /*
224de4bebcSJens Wiklander  * Symbols provided by the entity that uses this API.
234de4bebcSJens Wiklander  */
240e91d797SJean-Michel Delorme extern int trace_level;
254de4bebcSJens Wiklander extern const char trace_ext_prefix[];
26bfc6487bSJerome Forissier void trace_ext_puts(const char *str);
274de4bebcSJens Wiklander int trace_ext_get_thread_id(void);
28e5dc28ccSPascal Brand void trace_set_level(int level);
29e5dc28ccSPascal Brand int trace_get_level(void);
30*ea4ae5cdSSheetal Tigadoli void plat_trace_ext_puts(const char *str);
314de4bebcSJens Wiklander 
324de4bebcSJens Wiklander /* Internal functions used by the macros below */
333dd0e94eSJens Wiklander void trace_vprintf(const char *func, int line, int level, bool level_ok,
343dd0e94eSJens Wiklander 		   const char *fmt, va_list args) __printf(5, 0);
3544202a48SPascal Brand void trace_printf(const char *func, int line, int level, bool level_ok,
36bfc6487bSJerome Forissier 		  const char *fmt, ...) __printf(5, 6);
374de4bebcSJens Wiklander 
3844202a48SPascal Brand #define trace_printf_helper(level, level_ok, ...) \
3944202a48SPascal Brand 	trace_printf(__func__, __LINE__, (level), (level_ok), \
40bfc6487bSJerome Forissier 		     __VA_ARGS__)
4144202a48SPascal Brand 
4244202a48SPascal Brand /* Formatted trace tagged with level independent */
438a1e7b89SJerome Forissier #if (TRACE_LEVEL <= 0)
4444202a48SPascal Brand #define MSG(...)   (void)0
4544202a48SPascal Brand #else
4644202a48SPascal Brand #define MSG(...)   trace_printf_helper(0, false, __VA_ARGS__)
4744202a48SPascal Brand #endif
484de4bebcSJens Wiklander 
494de4bebcSJens Wiklander /* Formatted trace tagged with TRACE_ERROR level */
508a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_ERROR)
514de4bebcSJens Wiklander #define EMSG(...)   (void)0
524de4bebcSJens Wiklander #else
5344202a48SPascal Brand #define EMSG(...)   trace_printf_helper(TRACE_ERROR, true, __VA_ARGS__)
544de4bebcSJens Wiklander #endif
554de4bebcSJens Wiklander 
564de4bebcSJens Wiklander /* Formatted trace tagged with TRACE_INFO level */
578a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_INFO)
584de4bebcSJens Wiklander #define IMSG(...)   (void)0
594de4bebcSJens Wiklander #else
6044202a48SPascal Brand #define IMSG(...)   trace_printf_helper(TRACE_INFO, true, __VA_ARGS__)
614de4bebcSJens Wiklander #endif
624de4bebcSJens Wiklander 
634de4bebcSJens Wiklander /* Formatted trace tagged with TRACE_DEBUG level */
648a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_DEBUG)
654de4bebcSJens Wiklander #define DMSG(...)   (void)0
664de4bebcSJens Wiklander #else
6744202a48SPascal Brand #define DMSG(...)   trace_printf_helper(TRACE_DEBUG, true, __VA_ARGS__)
684de4bebcSJens Wiklander #endif
694de4bebcSJens Wiklander 
704de4bebcSJens Wiklander /* Formatted trace tagged with TRACE_FLOW level */
718a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_FLOW)
724de4bebcSJens Wiklander #define FMSG(...)   (void)0
734de4bebcSJens Wiklander #else
7444202a48SPascal Brand #define FMSG(...)   trace_printf_helper(TRACE_FLOW, true, __VA_ARGS__)
754de4bebcSJens Wiklander #endif
764de4bebcSJens Wiklander 
774de4bebcSJens Wiklander /* Formatted trace tagged with TRACE_FLOW level and prefix with '> ' */
784de4bebcSJens Wiklander #define INMSG(...)     FMSG("> " __VA_ARGS__)
794de4bebcSJens Wiklander /* Formatted trace tagged with TRACE_FLOW level and prefix with '< ' */
804de4bebcSJens Wiklander #define OUTMSG(...)    FMSG("< " __VA_ARGS__)
814de4bebcSJens Wiklander /* Formatted trace tagged with TRACE_FLOW level and prefix with '< ' and print
824de4bebcSJens Wiklander  * an error message if r != 0 */
834de4bebcSJens Wiklander #define OUTRMSG(r)			\
844de4bebcSJens Wiklander 	do {				\
854de4bebcSJens Wiklander 		OUTMSG("r=[%x]", r);	\
864de4bebcSJens Wiklander 		return r;		\
874de4bebcSJens Wiklander 	} while (0)
884de4bebcSJens Wiklander 
89e5dc28ccSPascal Brand void dhex_dump(const char *function, int line, int level,
90e5dc28ccSPascal Brand 	       const void *buf, int len);
918a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_DEBUG)
924de4bebcSJens Wiklander #define DHEXDUMP(buf, len) (void)0
934de4bebcSJens Wiklander #else
944de4bebcSJens Wiklander #define DHEXDUMP(buf, len) dhex_dump(__func__, __LINE__, TRACE_DEBUG, \
954de4bebcSJens Wiklander 				     buf, len)
964de4bebcSJens Wiklander #endif
974de4bebcSJens Wiklander 
9844202a48SPascal Brand 
994de4bebcSJens Wiklander /* Trace api without trace formatting */
1004de4bebcSJens Wiklander 
10144202a48SPascal Brand #define trace_printf_helper_raw(level, level_ok, ...) \
102bfc6487bSJerome Forissier 	trace_printf(NULL, 0, (level), (level_ok), __VA_ARGS__)
10344202a48SPascal Brand 
10444202a48SPascal Brand /* No formatted trace tagged with level independent */
1058a1e7b89SJerome Forissier #if (TRACE_LEVEL <= 0)
10644202a48SPascal Brand #define MSG_RAW(...)   (void)0
10744202a48SPascal Brand #else
10844202a48SPascal Brand #define MSG_RAW(...)   trace_printf_helper_raw(0, false, __VA_ARGS__)
10944202a48SPascal Brand #endif
11044202a48SPascal Brand 
1114de4bebcSJens Wiklander /* No formatted trace tagged with TRACE_ERROR level */
1128a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_ERROR)
1134de4bebcSJens Wiklander #define EMSG_RAW(...)   (void)0
1144de4bebcSJens Wiklander #else
11544202a48SPascal Brand #define EMSG_RAW(...)   trace_printf_helper_raw(TRACE_ERROR, true, __VA_ARGS__)
1164de4bebcSJens Wiklander #endif
1174de4bebcSJens Wiklander 
1184de4bebcSJens Wiklander /* No formatted trace tagged with TRACE_INFO level */
1198a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_INFO)
1204de4bebcSJens Wiklander #define IMSG_RAW(...)   (void)0
1214de4bebcSJens Wiklander #else
12244202a48SPascal Brand #define IMSG_RAW(...)   trace_printf_helper_raw(TRACE_INFO, true, __VA_ARGS__)
1234de4bebcSJens Wiklander #endif
1244de4bebcSJens Wiklander 
1254de4bebcSJens Wiklander /* No formatted trace tagged with TRACE_DEBUG level */
1268a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_DEBUG)
1274de4bebcSJens Wiklander #define DMSG_RAW(...)   (void)0
1284de4bebcSJens Wiklander #else
12944202a48SPascal Brand #define DMSG_RAW(...)   trace_printf_helper_raw(TRACE_DEBUG, true, __VA_ARGS__)
1304de4bebcSJens Wiklander #endif
1314de4bebcSJens Wiklander 
1324de4bebcSJens Wiklander /* No formatted trace tagged with TRACE_FLOW level */
1338a1e7b89SJerome Forissier #if (TRACE_LEVEL < TRACE_FLOW)
1344de4bebcSJens Wiklander #define FMSG_RAW(...)   (void)0
1354de4bebcSJens Wiklander #else
13644202a48SPascal Brand #define FMSG_RAW(...)   trace_printf_helper_raw(TRACE_FLOW, true, __VA_ARGS__)
1374de4bebcSJens Wiklander #endif
1384de4bebcSJens Wiklander 
1398a1e7b89SJerome Forissier #if (TRACE_LEVEL <= 0)
1404de4bebcSJens Wiklander #define SMSG(...)   (void)0
1414de4bebcSJens Wiklander #else
1424de4bebcSJens Wiklander /*
1434de4bebcSJens Wiklander  * Synchronised flushed trace, an Always message straight to HW trace IP.
1444de4bebcSJens Wiklander  * Current only supported inside OP-TEE kernel, will be just like an EMSG()
1454de4bebcSJens Wiklander  * in another context.
1464de4bebcSJens Wiklander  */
1474de4bebcSJens Wiklander #define SMSG(...)   \
148bfc6487bSJerome Forissier 	trace_printf(__func__, __LINE__, TRACE_ERROR, true, __VA_ARGS__)
1494de4bebcSJens Wiklander 
1508a1e7b89SJerome Forissier #endif /* TRACE_LEVEL */
1514de4bebcSJens Wiklander 
15231a29642SJerome Forissier #if defined(__KERNEL__) && defined(CFG_UNWIND)
153a681fabaSJerome Forissier #include <kernel/unwind.h>
154a681fabaSJerome Forissier #define _PRINT_STACK
155a681fabaSJerome Forissier #endif
156a681fabaSJerome Forissier 
157a681fabaSJerome Forissier #if defined(_PRINT_STACK) && (TRACE_LEVEL >= TRACE_ERROR)
15831a29642SJerome Forissier #define EPRINT_STACK() print_kernel_stack(TRACE_ERROR)
159a681fabaSJerome Forissier #else
160a681fabaSJerome Forissier #define EPRINT_STACK() (void)0
161a681fabaSJerome Forissier #endif
162a681fabaSJerome Forissier 
163a681fabaSJerome Forissier #if defined(_PRINT_STACK) && (TRACE_LEVEL >= TRACE_INFO)
16431a29642SJerome Forissier #define IPRINT_STACK() print_kernel_stack(TRACE_INFO)
165a681fabaSJerome Forissier #else
166a681fabaSJerome Forissier #define IPRINT_STACK() (void)0
167a681fabaSJerome Forissier #endif
168a681fabaSJerome Forissier 
169a681fabaSJerome Forissier #if defined(_PRINT_STACK) && (TRACE_LEVEL >= TRACE_DEBUG)
17031a29642SJerome Forissier #define DPRINT_STACK() print_kernel_stack(TRACE_DEBUG)
171a681fabaSJerome Forissier #else
172a681fabaSJerome Forissier #define DPRINT_STACK() (void)0
173a681fabaSJerome Forissier #endif
174a681fabaSJerome Forissier 
175a681fabaSJerome Forissier #if defined(_PRINT_STACK) && (TRACE_LEVEL >= TRACE_FLOW)
17631a29642SJerome Forissier #define FPRINT_STACK() print_kernel_stack(TRACE_FLOW)
177a681fabaSJerome Forissier #else
178a681fabaSJerome Forissier #define FPRINT_STACK() (void)0
179a681fabaSJerome Forissier #endif
180a681fabaSJerome Forissier 
18131a29642SJerome Forissier #if defined(__KERNEL__) && defined(CFG_UNWIND)
182a681fabaSJerome Forissier #undef _PRINT_STACK
183a681fabaSJerome Forissier #endif
184a681fabaSJerome Forissier 
1854de4bebcSJens Wiklander #endif /* TRACE_H */
186