This group contains the Protected Heap Handler implementation.
More...
|
bool | _Protected_heap_Extend (Heap_Control *heap, void *area_begin, uintptr_t area_size) |
| Extends the protected heap. More...
|
|
void * | _Protected_heap_Allocate_aligned_with_boundary (Heap_Control *heap, uintptr_t size, uintptr_t alignment, uintptr_t boundary) |
| Allocates an aligned memory area with boundary constraint for the protected heap. More...
|
|
bool | _Protected_heap_Free (Heap_Control *heap, void *addr) |
| Frees the allocated memory area. More...
|
|
bool | _Protected_heap_Walk (Heap_Control *heap, int source, bool dump) |
| Verifies the integrity of the heap. More...
|
|
bool | _Protected_heap_Get_information (Heap_Control *heap, Heap_Information_block *info) |
| Returns information about used and free blocks for the heap. More...
|
|
bool | _Protected_heap_Get_free_information (Heap_Control *heap, Heap_Information *info) |
| Returns information about free blocks for the heap. More...
|
|
uintptr_t | _Protected_heap_Get_size (Heap_Control *heap) |
| Returns the size of the allocatable area in bytes. More...
|
|
This group contains the Protected Heap Handler implementation.
The ScoreAllocatorMutex is used to protect the heap accesses.
◆ _Protected_heap_Allocate_aligned_with_boundary()
void * _Protected_heap_Allocate_aligned_with_boundary |
( |
Heap_Control * |
heap, |
|
|
uintptr_t |
size, |
|
|
uintptr_t |
alignment, |
|
|
uintptr_t |
boundary |
|
) |
| |
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.
- Parameters
-
[in,out] | heap | The heap to allocate a memory are from. |
| size | The size of the desired memory are in bytes. |
| alignment | The allocated memory area will begin at an address aligned by this value. |
| 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. |
- Return values
-
pointer | The starting address of the allocated memory area. |
NULL | No memory is available of the parameters are inconsistent. |
◆ _Protected_heap_Extend()
bool _Protected_heap_Extend |
( |
Heap_Control * |
heap, |
|
|
void * |
area_begin, |
|
|
uintptr_t |
area_size |
|
) |
| |
Extends the protected heap.
- Parameters
-
[in,out] | heap | The heap to extend. |
| area_begin | The starting addres of the area to extend heap with. |
| area_size | The size of the heap area. |
- Return values
-
true | The operation succeeded. |
false | The operation failed. |
◆ _Protected_heap_Free()
bool _Protected_heap_Free |
( |
Heap_Control * |
heap, |
|
|
void * |
addr |
|
) |
| |
Frees the allocated memory area.
Inappropriate values for addr may corrupt the heap. This method first locks the allocator and after the free operation, unlocks it again.
- Parameters
-
[in,out] | heap | The heap of the allocated memory area. |
| addr | The starting address of the memory area to be freed. |
- Return values
-
true | The allocated memory area was successfully freed. |
false | The method failed. |
◆ _Protected_heap_Get_free_information()
Returns information about free blocks for the heap.
This method first locks the allocator and after the operation, unlocks it again.
- Parameters
-
| heap | The heap to get the information from. |
[out] | info | Stores the information about free blocks of heap after the method call. |
◆ _Protected_heap_Get_information()
Returns information about used and free blocks for the heap.
This method first locks the allocator and after the operation, unlocks it again.
- Parameters
-
| heap | The heap to get the information from. |
[out] | info | Stores the information of the heap after the method call. |
◆ _Protected_heap_Get_size()
Returns the size of the allocatable area in bytes.
This value is an integral multiple of the page size.
- Parameters
-
heap | The heap to get the allocatable area from. |
- Returns
- The size of the allocatable area in heap in bytes.
◆ _Protected_heap_Walk()
bool _Protected_heap_Walk |
( |
Heap_Control * |
heap, |
|
|
int |
source, |
|
|
bool |
dump |
|
) |
| |
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.
- Parameters
-
heap | The heap whose integrity is to be verified. |
source | If dump is true , this is used to mark the output lines. |
dump | Indicates whether diagnostic messages will be printed to standard output. |
- Return values
-
true | No errors occurred, the heap´s integrity is not violated. |
false | The heap is corrupt. |