/** * @file * * @ingroup RTEMSScoreStack * * @brief Information About the Thread Stack Handler * * This include file contains all information about the thread * Stack Handler. This Handler provides mechanisms which can be used to * initialize and utilize stacks. */ /* * COPYRIGHT (c) 1989-2006. * On-Line Applications Research Corporation (OAR). * * The license and distribution terms for this file may be * found in the file LICENSE in this distribution or at * http://www.rtems.org/license/LICENSE. */ #ifndef _RTEMS_SCORE_STACK_H #define _RTEMS_SCORE_STACK_H #include #ifdef __cplusplus extern "C" { #endif /** * @defgroup RTEMSScoreStack Stack Handler * * @ingroup RTEMSScore * * @brief Stack Handler * * This handler encapsulates functionality which is used in the management * of thread stacks. * * @{ */ /** * The following constant defines the minimum stack size which every * thread must exceed. */ #define STACK_MINIMUM_SIZE CPU_STACK_MINIMUM_SIZE /** * The following defines the control block used to manage each stack. */ typedef struct { /** This is the stack size. */ size_t size; /** This is the low memory address of stack. */ void *area; } Stack_Control; /** * @brief The stack allocator initialization handler. * * @param stack_space_size The size of the stack space in bytes. */ typedef void ( *Stack_Allocator_initialize )( size_t stack_space_size ); /** * @brief Stack allocator allocate handler. * * @param stack_size The size of the stack area to allocate in bytes. * * @retval NULL Not enough memory. * @retval other Pointer to begin of stack area. */ typedef void *( *Stack_Allocator_allocate )( size_t stack_size ); /** * @brief Stack allocator free handler. * * @param] addr A pointer to previously allocated stack area or NULL. */ typedef void ( *Stack_Allocator_free )( void *addr ); /** * @brief Stack allocator allocate for idle handler. * * The allocate for idle handler is optional even when the user thread stack * allocator and deallocator are configured. * * @param cpu Index of the CPU for the IDLE thread using this stack * @param stack_size The size of the stack area to allocate in bytes. * * @retval NULL Not enough memory. * @retval other Pointer to begin of stack area. */ typedef void *( *Stack_Allocator_allocate_for_idle )( uint32_t cpu, size_t stack_size ); /** * @brief The minimum stack size. * * Application provided via . */ extern uint32_t rtems_minimum_stack_size; /** * @brief The configured stack space size. * * Application provided via . */ extern const uintptr_t _Stack_Space_size; /** * @brief Indicates if the stack allocator avoids the workspace. * * Application provided via . */ extern const bool _Stack_Allocator_avoids_workspace; /** * @brief The stack allocator initialization handler. * * Application provided via . */ extern const Stack_Allocator_initialize _Stack_Allocator_initialize; /** * @brief The stack allocator allocate handler. * * Application provided via . */ extern const Stack_Allocator_allocate _Stack_Allocator_allocate; /** * @brief The stack allocator free handler. * * Application provided via . */ extern const Stack_Allocator_free _Stack_Allocator_free; /** @} */ /** * @brief The stack allocator allocate stack for idle thread handler. * * Application provided via . */ extern const Stack_Allocator_allocate_for_idle _Stack_Allocator_allocate_for_idle; #ifdef __cplusplus } #endif #endif /* end of include file */