/** * @file * * @ingroup RTEMSScoreProtHeap * * @brief This header file provides the interfaces of the * @ref RTEMSScoreProtHeap. */ /* * COPYRIGHT (c) 1989-2007. * 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_PROTECTED_HEAP_H #define _RTEMS_SCORE_PROTECTED_HEAP_H #include #include #ifdef __cplusplus extern "C" { #endif /** * @defgroup RTEMSScoreProtHeap Protected Heap Handler * * @ingroup RTEMSScoreHeap * * @brief This group contains the Protected Heap Handler implementation. * * The @ref ScoreAllocatorMutex is used to protect the heap accesses. * * @{ */ /** * @brief Initializes the protected heap. * * @param[out] heap The heap to initialize. * @param area_begin The starting address of the heap area. * @param area_size The size of the heap area. * @param page_size The page size for the heap. */ RTEMS_INLINE_ROUTINE uintptr_t _Protected_heap_Initialize( Heap_Control *heap, void *area_begin, uintptr_t area_size, uintptr_t page_size ) { return _Heap_Initialize( heap, area_begin, area_size, page_size ); } /** * @brief Extends the protected heap. * * @param[in, out] heap The heap to extend. * @param area_begin The starting addres of the area to extend @a heap with. * @param area_size The size of the heap area. * * @retval true The operation succeeded. * @retval false The operation failed. */ bool _Protected_heap_Extend( Heap_Control *heap, void *area_begin, uintptr_t area_size ); /** * @brief Allocates an aligned memory area with boundary constraint for the protected heap. * * A size value of zero will return a unique address which may be freed with * _Heap_Free(). This method first locks the allocator and after the allocation of the memory * area, unlocks it again. * * @param[in, out] heap The heap to allocate a memory are from. * @param size The size of the desired memory are in bytes. * @param alignment The allocated memory area will begin at an address aligned by this value. * @param boundary The allocated memory area will fulfill a boundary constraint, * if this value is not equal to zero. The boundary value specifies * the set of addresses which are aligned by the boundary value. The * interior of the allocated memory area will not contain an element of this * set. The begin or end address of the area may be a member of the set. * * @retval pointer The starting address of the allocated memory area. * @retval NULL No memory is available of the parameters are inconsistent. */ void *_Protected_heap_Allocate_aligned_with_boundary( Heap_Control *heap, uintptr_t size, uintptr_t alignment, uintptr_t boundary ); /** * @brief Allocates an aligned memory area. * * A size value of zero will return a unique address which may be freed with * _Heap_Free(). This method first locks the allocator and after the allocation of the memory * area, unlocks it again. * * @param[in, out] heap The heap to allocate a memory are from. * @param size The size of the desired memory are in bytes. * @param alignment The allocated memory area will begin at an address aligned by this value. * * @retval pointer The starting address of the allocated memory area. * @retval NULL No memory is available of the parameters are inconsistent. */ RTEMS_INLINE_ROUTINE void *_Protected_heap_Allocate_aligned( Heap_Control *heap, uintptr_t size, uintptr_t alignment ) { return _Protected_heap_Allocate_aligned_with_boundary( heap, size, alignment, 0 ); } /** * @brief Allocates a memory area. * * A size value of zero will return a unique address which may be freed with * _Heap_Free(). This method first locks the allocator and after the allocation of the memory * area, unlocks it again. * * @param[in, out] heap The heap to allocate a memory are from. * @param size The size of the desired memory are in bytes. * * @retval pointer The starting address of the allocated memory area. * @retval NULL No memory is available of the parameters are inconsistent. */ RTEMS_INLINE_ROUTINE void *_Protected_heap_Allocate( Heap_Control *heap, uintptr_t size ) { return _Protected_heap_Allocate_aligned_with_boundary( heap, size, 0, 0 ); } /** * @brief Returns the size of the allocatable memory area. * * The size value may be greater than the initially requested size in * _Heap_Allocate_aligned_with_boundary(). * * Inappropriate values for @a addr will not corrupt the heap, but may yield * invalid size values. * * This method first locks the allocator and after the operation, unlocks it again. * * @param heap The heap to operate upon. * @param addr The starting address of the allocatable memory area. * @param[out] size Stores the size of the allocatable memory area after the method call. * * @retval true The operation was successful. * @retval false The operation was not successful. */ bool _Protected_heap_Get_block_size( Heap_Control *heap, void *addr, uintptr_t *size ); /** * @brief Resizes the block of the allocated memory area. * * Inappropriate values for @a addr may corrupt the heap. * * This method first locks the allocator and after the resize, unlocks it again. * * @param[in, out] heap The heap to operate upon. * @param addr The starting address of the allocated memory area to be resized. * @param size The least possible size for the new memory area. Resize may be * impossible and depends on the current heap usage. * @param[out] old_size Stores the size available for allocation in the current * block before the resize after the method call. * @param[out] new_size Stores the size available for allocation in the resized * block after the method call. In the case of an unsuccessful resize, * zero is returned in this parameter * * @retval HEAP_RESIZE_SUCCESSFUL The resize was successful. * @retval HEAP_RESIZE_UNSATISFIED The least possible size @a size was too big. * Resize not possible. * @retval HEAP_RESIZE_FATAL_ERROR The block starting at @a addr is not part of * the heap. */ bool _Protected_heap_Resize_block( Heap_Control *heap, void *addr, uintptr_t size ); /** * @brief Frees the allocated memory area. * * Inappropriate values for @a addr may corrupt the heap. This method first locks * the allocator and after the free operation, unlocks it again. * * @param[in, out] heap The heap of the allocated memory area. * @param addr The starting address of the memory area to be freed. * * @retval true The allocated memory area was successfully freed. * @retval false The method failed. */ bool _Protected_heap_Free( Heap_Control *heap, void *addr ); /** * @brief Verifies the integrity of the heap. * * Walks the heap to verify its integrity. This method first locks * the allocator and after the operation, unlocks it again, if the thread dispatch is enabled. * * @param heap The heap whose integrity is to be verified. * @param source If @a dump is @c true, this is used to mark the output lines. * @param dump Indicates whether diagnostic messages will be printed to standard output. * * @retval true No errors occured, the heapĀ“s integrity is not violated. * @retval false The heap is corrupt. */ bool _Protected_heap_Walk( Heap_Control *heap, int source, bool dump ); /** * @brief Iterates over all blocks of the heap. * * This method first locks the allocator and after the operation, unlocks it again. * * @param[in, out] heap The heap to iterate over. * @param visitor This will be called for each heap block with * the argument @a visitor_arg. * @param[in, out] visitor_arg The argument for all calls of @a visitor. */ void _Protected_heap_Iterate( Heap_Control *heap, Heap_Block_visitor visitor, void *visitor_arg ); /** * @brief Returns information about used and free blocks for the heap. * * This method first locks the allocator and after the operation, unlocks it again. * * @param heap The heap to get the information from. * @param[out] info Stores the information of the @a heap after the method call. */ bool _Protected_heap_Get_information( Heap_Control *heap, Heap_Information_block *info ); /** * @brief Returns information about free blocks for the heap. * * This method first locks the allocator and after the operation, unlocks it again. * * @param heap The heap to get the information from. * @param[out] info Stores the information about free blocks of @a heap after the * method call. */ bool _Protected_heap_Get_free_information( Heap_Control *heap, Heap_Information *info ); /** * @brief Returns the size of the allocatable area in bytes. * * This value is an integral multiple of the page size. * * @param heap The heap to get the allocatable area from. * * @return The size of the allocatable area in @a heap in bytes. */ uintptr_t _Protected_heap_Get_size( Heap_Control *heap ); /** @} */ #ifdef __cplusplus } #endif #endif /* end of include file */