/* ChibiOS/RT - Copyright (C) 2006,2007,2008,2009,2010, 2011,2012 Giovanni Di Sirio. This file is part of ChibiOS/RT. ChibiOS/RT 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/RT 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_USE_REGISTRY || defined(__DOXYGEN__) /** * @name Macro Functions * @{ */ /** * @brief Sets the current thread name. * @pre This function only stores the pointer to the name if the option * @p CH_USE_REGISTRY is enabled else no action is performed. * * @param[in] p thread name as a zero terminated string * * @api */ #define chRegSetThreadName(p) (currp->p_name = (p)) /** * @brief Returns the name of the specified thread. * @pre This function only returns the pointer to the name if the option * @p CH_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. */ #define chRegGetThreadName(tp) ((tp)->p_name) /** @} */ #else /* !CH_USE_REGISTRY */ #define chRegSetThreadName(p) #define chRegGetThreadName(tp) NULL #endif /* !CH_USE_REGISTRY */ #if CH_USE_REGISTRY || defined(__DOXYGEN__) /** * @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)->p_older->p_newer = (tp)->p_newer; \ (tp)->p_newer->p_older = (tp)->p_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)->p_newer = (Thread *)&rlist; \ (tp)->p_older = rlist.r_older; \ (tp)->p_older->p_newer = rlist.r_older = (tp); \ } #ifdef __cplusplus extern "C" { #endif Thread *chRegFirstThread(void); Thread *chRegNextThread(Thread *tp); #ifdef __cplusplus } #endif #endif /* CH_USE_REGISTRY */ #endif /* _CHREGISTRY_H_ */ /** @} */