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