RTEMS CPU Kit with SuperCore  4.11.3
Macros | Functions
rtl-allocator.c File Reference

RTEMS Run-Time Linker Allocator. More...

#include <stdio.h>
#include <rtems/rtl/rtl.h>
#include "rtl-alloc-heap.h"
#include "rtl-trace.h"
Include dependency graph for rtl-allocator.c:

Macros

#define rtems_rtl_trace_tag_label(_l)   tag_labels[_l]
 

Functions

void rtems_rtl_alloc_initialise (rtems_rtl_alloc_data_t *data)
 Initialise the allocate data. More...
 
void * rtems_rtl_alloc_new (rtems_rtl_alloc_tag_t tag, size_t size, bool zero)
 The Runtime Loader allocator new allocates new memory and optionally clear the memory if requested. More...
 
void rtems_rtl_alloc_del (rtems_rtl_alloc_tag_t tag, void *address)
 The Runtime Loader allocator delete deletes allocated memory. More...
 
rtems_rtl_allocator_t rtems_rtl_alloc_hook (rtems_rtl_allocator_t handler)
 Hook the Runtime Loader allocatior. More...
 
void rtems_rtl_alloc_indirect_new (rtems_rtl_alloc_tag_t tag, rtems_rtl_ptr_t *handle, size_t size)
 Allocate memory to an indirect handle. More...
 
void rtems_rtl_alloc_indirect_del (rtems_rtl_alloc_tag_t tag, rtems_rtl_ptr_t *handle)
 Free memory from an indirect handle. More...
 
bool rtems_rtl_alloc_module_new (void **text_base, size_t text_size, void **const_base, size_t const_size, void **eh_base, size_t eh_size, void **data_base, size_t data_size, void **bss_base, size_t bss_size)
 Allocate the memory for a module given the size of the text, const, data and bss sections. More...
 
void rtems_rtl_alloc_module_del (void **text_base, void **const_base, void **eh_base, void **data_base, void **bss_base)
 Free the memory allocated to a module. More...
 

Detailed Description

RTEMS Run-Time Linker Allocator.

Function Documentation

◆ rtems_rtl_alloc_del()

void rtems_rtl_alloc_del ( rtems_rtl_alloc_tag_t  tag,
void *  address 
)

The Runtime Loader allocator delete deletes allocated memory.

Parameters
tagThe type of allocation request.
addressThe memory address to delete. A NULL is ignored.

Referenced by rtems_rtl_alloc_module_del(), rtems_rtl_obj_comp_close(), rtems_rtl_obj_erase_sections(), rtems_rtl_symbol_obj_erase_local(), and rtems_rtl_symbol_table_close().

◆ rtems_rtl_alloc_hook()

rtems_rtl_allocator_t rtems_rtl_alloc_hook ( rtems_rtl_allocator_t  handler)

Hook the Runtime Loader allocatior.

A handler can call the previous handler in the chain to use it for specific tags. The default handler uses the system heap. Do not unhook your handler if memory it allocates has not been returned.

Parameters
handlerThe handler to use as the allocator.
Returns
rtems_rtl_alloc_handler_t The previous handler.

◆ rtems_rtl_alloc_indirect_del()

void rtems_rtl_alloc_indirect_del ( rtems_rtl_alloc_tag_t  tag,
rtems_rtl_ptr_t handle 
)

Free memory from an indirect handle.

Parameters
tagThe type of allocation request.
handleThe handle to free the memory from.

◆ rtems_rtl_alloc_indirect_new()

void rtems_rtl_alloc_indirect_new ( rtems_rtl_alloc_tag_t  tag,
rtems_rtl_ptr_t handle,
size_t  size 
)

Allocate memory to an indirect handle.

Parameters
tagThe type of allocation request.
handleThe handle to allocate the memory to.
sizeThe size of the allocation.

◆ rtems_rtl_alloc_initialise()

void rtems_rtl_alloc_initialise ( rtems_rtl_alloc_data_t data)

Initialise the allocate data.

Parameters
dataThe data to initialise.

References rtems_rtl_alloc_data_s::allocator, rtems_chain_initialize_empty(), rtems_rtl_alloc_heap(), and RTEMS_RTL_ALLOC_TAGS.

◆ rtems_rtl_alloc_module_del()

void rtems_rtl_alloc_module_del ( void **  text_base,
void **  const_base,
void **  eh_base,
void **  data_base,
void **  bss_base 
)

Free the memory allocated to a module.

Parameters
text_basePointer to the text base pointer.
const_basePointer to the const base pointer.
eh_basePointer to the eh base pointer.
data_basePointer to the data base pointer.
bss_basePointer to the bss base pointer.

References rtems_rtl_alloc_del(), RTEMS_RTL_ALLOC_READ, RTEMS_RTL_ALLOC_READ_EXEC, and RTEMS_RTL_ALLOC_READ_WRITE.

Referenced by rtems_rtl_alloc_module_new(), and rtems_rtl_obj_free().

◆ rtems_rtl_alloc_module_new()

bool rtems_rtl_alloc_module_new ( void **  text_base,
size_t  text_size,
void **  const_base,
size_t  const_size,
void **  eh_base,
size_t  eh_size,
void **  data_base,
size_t  data_size,
void **  bss_base,
size_t  bss_size 
)

Allocate the memory for a module given the size of the text, const, data and bss sections.

If any part of the allocation fails the no memory is allocated.

Parameters
text_basePointer to the text base pointer.
text_sizeThe size of the read/exec section.
const_basePointer to the const base pointer.
const_sizeThe size of the read only section.
eh_basePointer to the eh base pointer.
eh_sizeThe size of the eh section.
data_basePointer to the data base pointer.
data_sizeThe size of the read/write secton.
bss_basePointer to the bss base pointer.
bss_sizeThe size of the read/write.
Return values
trueThe memory has been allocated.
falseThe allocation of memory has failed.

References rtems_rtl_alloc_module_del(), rtems_rtl_alloc_new(), RTEMS_RTL_ALLOC_READ, RTEMS_RTL_ALLOC_READ_EXEC, and RTEMS_RTL_ALLOC_READ_WRITE.

Referenced by rtems_rtl_obj_load_sections().

◆ rtems_rtl_alloc_new()

void* rtems_rtl_alloc_new ( rtems_rtl_alloc_tag_t  tag,
size_t  size,
bool  zero 
)

The Runtime Loader allocator new allocates new memory and optionally clear the memory if requested.

Parameters
tagThe type of allocation request.
sizeThe size of the allocation.
zeroIf true the memory is cleared.
Returns
void* The memory address or NULL is not memory available.

Referenced by rtems_rtl_alloc_module_new(), rtems_rtl_obj_alloc(), and rtems_rtl_symbol_table_open().