/* ChibiOS - Copyright (C) 2006..2015 Giovanni Di Sirio. This file is part of ChibiOS. ChibiOS is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 3 of the License, or (at your option) any later version. ChibiOS is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. You should have received a copy of the GNU General Public License along with this program. If not, see . */ /** * @file chdebug.h * @brief Debug macros and structures. * * @addtogroup debug * @{ */ #ifndef _CHDEBUG_H_ #define _CHDEBUG_H_ /*===========================================================================*/ /* Module constants. */ /*===========================================================================*/ /*===========================================================================*/ /* Module pre-compile time settings. */ /*===========================================================================*/ /** * @name Debug related settings * @{ */ /** * @brief Trace buffer entries. */ #ifndef CH_DBG_TRACE_BUFFER_SIZE #define CH_DBG_TRACE_BUFFER_SIZE 64 #endif /** * @brief Fill value for thread stack area in debug mode. */ #ifndef CH_DBG_STACK_FILL_VALUE #define CH_DBG_STACK_FILL_VALUE 0x55 #endif /** * @brief Fill value for thread area in debug mode. * @note The chosen default value is 0xFF in order to make evident which * thread fields were not initialized when inspecting the memory with * a debugger. A uninitialized field is not an error in itself but it * better to know it. */ #ifndef CH_DBG_THREAD_FILL_VALUE #define CH_DBG_THREAD_FILL_VALUE 0xFF #endif /** @} */ /*===========================================================================*/ /* Derived constants and error checks. */ /*===========================================================================*/ /*===========================================================================*/ /* Module data structures and types. */ /*===========================================================================*/ #if (CH_DBG_ENABLE_TRACE == TRUE) || defined(__DOXYGEN__) /** * @brief Trace buffer record. */ typedef struct { /** * @brief Time of the switch event. */ systime_t se_time; /** * @brief Switched in thread. */ thread_t *se_tp; /** * @brief Object where going to sleep. */ void *se_wtobjp; /** * @brief Switched out thread state. */ uint8_t se_state; } ch_swc_event_t; /** * @brief Trace buffer header. */ typedef struct { /** * @brief Trace buffer size (entries). */ unsigned tb_size; /** * @brief Pointer to the buffer front. */ ch_swc_event_t *tb_ptr; /** * @brief Ring buffer. */ ch_swc_event_t tb_buffer[CH_DBG_TRACE_BUFFER_SIZE]; } ch_trace_buffer_t; #endif /* CH_DBG_ENABLE_TRACE */ /*===========================================================================*/ /* Module macros. */ /*===========================================================================*/ #if CH_DBG_SYSTEM_STATE_CHECK == TRUE #define _dbg_enter_lock() (ch.dbg.lock_cnt = 1) #define _dbg_leave_lock() (ch.dbg.lock_cnt = 0) #endif /* When the state checker feature is disabled then the following functions are replaced by an empty macro.*/ #if CH_DBG_SYSTEM_STATE_CHECK == FALSE #define _dbg_enter_lock() #define _dbg_leave_lock() #define _dbg_check_disable() #define _dbg_check_suspend() #define _dbg_check_enable() #define _dbg_check_lock() #define _dbg_check_unlock() #define _dbg_check_lock_from_isr() #define _dbg_check_unlock_from_isr() #define _dbg_check_enter_isr() #define _dbg_check_leave_isr() #define chDbgCheckClassI() #define chDbgCheckClassS() #endif /* When the trace feature is disabled this function is replaced by an empty macro.*/ #if CH_DBG_ENABLE_TRACE == FALSE #define _dbg_trace(otp) #endif /** * @name Macro Functions * @{ */ /** * @brief Function parameters check. * @details If the condition check fails then the kernel panics and halts. * @note The condition is tested only if the @p CH_DBG_ENABLE_CHECKS switch * is specified in @p chconf.h else the macro does nothing. * * @param[in] c the condition to be verified to be true * * @api */ #if !defined(chDbgCheck) #if CH_DBG_ENABLE_CHECKS #define chDbgCheck(c) do { \ if (!(c)) { \ chSysHalt(__func__); \ } \ } while (false) #else #define chDbgCheck(c) #endif #endif /* !defined(chDbgCheck) */ /** * @brief Condition assertion. * @details If the condition check fails then the kernel panics with a * message and halts. * @note The condition is tested only if the @p CH_DBG_ENABLE_ASSERTS switch * is specified in @p chconf.h else the macro does nothing. * @note The remark string is not currently used except for putting a * comment in the code about the assertion. * * @param[in] c the condition to be verified to be true * @param[in] r a remark string * * @api */ #if !defined(chDbgAssert) #if CH_DBG_ENABLE_ASSERTS == TRUE #define chDbgAssert(c, r) do { \ /*lint -save -e506 -e774 [2.1, 14.3] Can be a constant.*/ \ if (!(c)) { \ /*lint -restore*/ \ chSysHalt(__func__); \ } \ } while (false) #else #define chDbgAssert(c, r) #endif #endif /* !defined(chDbgAssert) */ /** @} */ /*===========================================================================*/ /* External declarations. */ /*===========================================================================*/ #ifdef __cplusplus extern "C" { #endif #if CH_DBG_SYSTEM_STATE_CHECK == TRUE void _dbg_check_disable(void); void _dbg_check_suspend(void); void _dbg_check_enable(void); void _dbg_check_lock(void); void _dbg_check_unlock(void); void _dbg_check_lock_from_isr(void); void _dbg_check_unlock_from_isr(void); void _dbg_check_enter_isr(void); void _dbg_check_leave_isr(void); void chDbgCheckClassI(void); void chDbgCheckClassS(void); #endif #if (CH_DBG_ENABLE_TRACE == TRUE) || defined(__DOXYGEN__) void _dbg_trace_init(void); void _dbg_trace(thread_t *otp); #endif #ifdef __cplusplus } #endif /*===========================================================================*/ /* Module inline functions. */ /*===========================================================================*/ #endif /* _CHDEBUG_H_ */ /** @} */