/* ChibiOS - Copyright (C) 2006..2016 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 chregistry.h * @brief Threads registry macros and structures. * * @addtogroup registry * @{ */ #ifndef CHREGISTRY_H #define CHREGISTRY_H #if (CH_CFG_USE_REGISTRY == TRUE) || defined(__DOXYGEN__) /*===========================================================================*/ /* Module constants. */ /*===========================================================================*/ /*===========================================================================*/ /* Module pre-compile time settings. */ /*===========================================================================*/ /*===========================================================================*/ /* Derived constants and error checks. */ /*===========================================================================*/ /*===========================================================================*/ /* Module data structures and types. */ /*===========================================================================*/ /** * @brief ChibiOS/RT memory signature record. */ typedef struct { char identifier[4]; /**< @brief Always set to "main". */ uint8_t zero; /**< @brief Must be zero. */ uint8_t size; /**< @brief Size of this structure. */ uint16_t version; /**< @brief Encoded ChibiOS/RT version. */ uint8_t ptrsize; /**< @brief Size of a pointer. */ uint8_t timesize; /**< @brief Size of a @p systime_t. */ uint8_t threadsize; /**< @brief Size of a @p thread_t. */ uint8_t off_prio; /**< @brief Offset of @p prio field. */ uint8_t off_ctx; /**< @brief Offset of @p ctx field. */ uint8_t off_newer; /**< @brief Offset of @p newer field. */ uint8_t off_older; /**< @brief Offset of @p older field. */ uint8_t off_name; /**< @brief Offset of @p name field. */ uint8_t off_stklimit; /**< @brief Offset of @p stklimit field.*/ uint8_t off_state; /**< @brief Offset of @p state field. */ uint8_t off_flags; /**< @brief Offset of @p flags field. */ uint8_t off_refs; /**< @brief Offset of @p refs field. */ uint8_t off_preempt; /**< @brief Offset of @p preempt field. */ uint8_t off_time; /**< @brief Offset of @p time field. */ } chdebug_t; /*===========================================================================*/ /* Module macros. */ /*===========================================================================*/ /** * @brief Removes a thread from the registry list. * @note This macro is not meant for use in application code. * * @param[in] tp thread to remove from the registry */ #define REG_REMOVE(tp) { \ (tp)->older->newer = (tp)->newer; \ (tp)->newer->older = (tp)->older; \ } /** * @brief Adds a thread to the registry list. * @note This macro is not meant for use in application code. * * @param[in] tp thread to add to the registry */ #define REG_INSERT(tp) { \ (tp)->newer = (thread_t *)&ch.rlist; \ (tp)->older = ch.rlist.older; \ (tp)->older->newer = (tp); \ ch.rlist.older = (tp); \ } /*===========================================================================*/ /* External declarations. */ /*===========================================================================*/ #ifdef __cplusplus extern "C" { #endif extern ROMCONST chdebug_t ch_debug; thread_t *chRegFirstThread(void); thread_t *chRegNextThread(thread_t *tp); thread_t *chRegFindThreadByName(const char *name); thread_t *chRegFindThreadByPointer(thread_t *tp); thread_t *chRegFindThreadByWorkingArea(stkalign_t *wa); #ifdef __cplusplus } #endif #endif /* CH_CFG_USE_REGISTRY == TRUE */ /*===========================================================================*/ /* Module inline functions. */ /*===========================================================================*/ /** * @brief Sets the current thread name. * @pre This function only stores the pointer to the name if the option * @p CH_CFG_USE_REGISTRY is enabled else no action is performed. * * @param[in] name thread name as a zero terminated string * * @api */ static inline void chRegSetThreadName(const char *name) { #if CH_CFG_USE_REGISTRY == TRUE ch.rlist.current->name = name; #else (void)name; #endif } /** * @brief Returns the name of the specified thread. * @pre This function only returns the pointer to the name if the option * @p CH_CFG_USE_REGISTRY is enabled else @p NULL is returned. * * @param[in] tp pointer to the thread * * @return Thread name as a zero terminated string. * @retval NULL if the thread name has not been set. * */ static inline const char *chRegGetThreadNameX(thread_t *tp) { #if CH_CFG_USE_REGISTRY == TRUE return tp->name; #else (void)tp; return NULL; #endif } /** * @brief Changes the name of the specified thread. * @pre This function only stores the pointer to the name if the option * @p CH_CFG_USE_REGISTRY is enabled else no action is performed. * * @param[in] tp pointer to the thread * @param[in] name thread name as a zero terminated string * * @xclass */ static inline void chRegSetThreadNameX(thread_t *tp, const char *name) { #if CH_CFG_USE_REGISTRY == TRUE tp->name = name; #else (void)tp; (void)name; #endif } #endif /* CHREGISTRY_H */ /** @} */