/* * Copyright (c) 2014, STMicroelectronics International N.V. * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions are met: * * 1. Redistributions of source code must retain the above copyright notice, * this list of conditions and the following disclaimer. * * 2. Redistributions in binary form must reproduce the above copyright notice, * this list of conditions and the following disclaimer in the documentation * and/or other materials provided with the distribution. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE * POSSIBILITY OF SUCH DAMAGE. */ #ifndef TRACE_H #define TRACE_H #include #include #include #include #define MAX_PRINT_SIZE 256 #define MAX_FUNC_PRINT_SIZE 32 #ifndef TRACE_LEVEL #define TRACE_LEVEL TRACE_MAX #endif /* * Symbols provided by the entity that uses this API. */ extern int trace_level; extern const char trace_ext_prefix[]; void trace_ext_puts(const char *str); int trace_ext_get_thread_id(void); void trace_set_level(int level); int trace_get_level(void); /* Internal functions used by the macros below */ void trace_printf(const char *func, int line, int level, bool level_ok, const char *fmt, ...) __printf(5, 6); #define trace_printf_helper(level, level_ok, ...) \ trace_printf(__func__, __LINE__, (level), (level_ok), \ __VA_ARGS__) /* Formatted trace tagged with level independent */ #if (TRACE_LEVEL <= 0) #define MSG(...) (void)0 #else #define MSG(...) trace_printf_helper(0, false, __VA_ARGS__) #endif /* Formatted trace tagged with TRACE_ERROR level */ #if (TRACE_LEVEL < TRACE_ERROR) #define EMSG(...) (void)0 #else #define EMSG(...) trace_printf_helper(TRACE_ERROR, true, __VA_ARGS__) #endif /* Formatted trace tagged with TRACE_INFO level */ #if (TRACE_LEVEL < TRACE_INFO) #define IMSG(...) (void)0 #else #define IMSG(...) trace_printf_helper(TRACE_INFO, true, __VA_ARGS__) #endif /* Formatted trace tagged with TRACE_DEBUG level */ #if (TRACE_LEVEL < TRACE_DEBUG) #define DMSG(...) (void)0 #else #define DMSG(...) trace_printf_helper(TRACE_DEBUG, true, __VA_ARGS__) #endif /* Formatted trace tagged with TRACE_FLOW level */ #if (TRACE_LEVEL < TRACE_FLOW) #define FMSG(...) (void)0 #else #define FMSG(...) trace_printf_helper(TRACE_FLOW, true, __VA_ARGS__) #endif /* Formatted trace tagged with TRACE_FLOW level and prefix with '> ' */ #define INMSG(...) FMSG("> " __VA_ARGS__) /* Formatted trace tagged with TRACE_FLOW level and prefix with '< ' */ #define OUTMSG(...) FMSG("< " __VA_ARGS__) /* Formatted trace tagged with TRACE_FLOW level and prefix with '< ' and print * an error message if r != 0 */ #define OUTRMSG(r) \ do { \ OUTMSG("r=[%x]", r); \ return r; \ } while (0) void dhex_dump(const char *function, int line, int level, const void *buf, int len); #if (TRACE_LEVEL < TRACE_DEBUG) #define DHEXDUMP(buf, len) (void)0 #else #define DHEXDUMP(buf, len) dhex_dump(__func__, __LINE__, TRACE_DEBUG, \ buf, len) #endif /* Trace api without trace formatting */ #define trace_printf_helper_raw(level, level_ok, ...) \ trace_printf(NULL, 0, (level), (level_ok), __VA_ARGS__) /* No formatted trace tagged with level independent */ #if (TRACE_LEVEL <= 0) #define MSG_RAW(...) (void)0 #else #define MSG_RAW(...) trace_printf_helper_raw(0, false, __VA_ARGS__) #endif /* No formatted trace tagged with TRACE_ERROR level */ #if (TRACE_LEVEL < TRACE_ERROR) #define EMSG_RAW(...) (void)0 #else #define EMSG_RAW(...) trace_printf_helper_raw(TRACE_ERROR, true, __VA_ARGS__) #endif /* No formatted trace tagged with TRACE_INFO level */ #if (TRACE_LEVEL < TRACE_INFO) #define IMSG_RAW(...) (void)0 #else #define IMSG_RAW(...) trace_printf_helper_raw(TRACE_INFO, true, __VA_ARGS__) #endif /* No formatted trace tagged with TRACE_DEBUG level */ #if (TRACE_LEVEL < TRACE_DEBUG) #define DMSG_RAW(...) (void)0 #else #define DMSG_RAW(...) trace_printf_helper_raw(TRACE_DEBUG, true, __VA_ARGS__) #endif /* No formatted trace tagged with TRACE_FLOW level */ #if (TRACE_LEVEL < TRACE_FLOW) #define FMSG_RAW(...) (void)0 #else #define FMSG_RAW(...) trace_printf_helper_raw(TRACE_FLOW, true, __VA_ARGS__) #endif #if (TRACE_LEVEL <= 0) #define SMSG(...) (void)0 #else /* * Synchronised flushed trace, an Always message straight to HW trace IP. * Current only supported inside OP-TEE kernel, will be just like an EMSG() * in another context. */ #define SMSG(...) \ trace_printf(__func__, __LINE__, TRACE_ERROR, true, __VA_ARGS__) #endif /* TRACE_LEVEL */ #endif /* TRACE_H */