bsps: Rework work area initialization

The work area initialization was done by the BSP through
bsp_work_area_initialize(). This approach predated the system
initialization through the system initialization linker set. The
workspace and C program heap were unconditionally initialized.  The aim
is to support RTEMS application configurations which do not need the
workspace and C program heap.  In these configurations, the workspace
and C prgram heap should not get initialized.

Change all bsp_work_area_initialize() to implement _Memory_Get()
instead.  Move the dirty memory, sbrk(), per-CPU data, workspace, and
malloc() heap initialization into separate system initialization steps.
This makes it also easier to test the individual initialization steps.

This change adds a dependency to _Heap_Extend() to all BSPs.  This
dependency will be removed in a follow up change.

Update #3838.
This commit is contained in:
Sebastian Huber
2019-12-13 06:18:36 +01:00
parent 07e2eacf89
commit eea21eaca1
26 changed files with 557 additions and 378 deletions

View File

@@ -1,7 +1,7 @@
/**
* @file
*
* This routine is an implementation of the bsp_work_area_initialize()
* This routine is an implementation of the _Memory_Get()
* that can be used by all BSPs following linkcmds conventions
* regarding heap, stack, and workspace allocation.
*/
@@ -33,23 +33,37 @@ extern char WorkAreaBase[];
* We may get the size information from U-Boot or the linker scripts.
*/
#ifdef USE_UBOOT
#include <bsp/u-boot.h>
#else
extern char RamBase[];
extern char RamSize[];
#endif
#include <bsp/u-boot.h>
#include <rtems/sysinit.h>
void bsp_work_area_initialize(void)
static Memory_Area _Memory_Areas[ 1 ];
static void bsp_memory_initialize( void )
{
uintptr_t work_base = (uintptr_t) WorkAreaBase;
uintptr_t ram_end;
char *end;
#ifdef USE_UBOOT
ram_end = (uintptr_t) bsp_uboot_board_info.bi_memstart +
bsp_uboot_board_info.bi_memsize;
#else
ram_end = (uintptr_t)RamBase + (uintptr_t)RamSize;
#endif
bsp_work_area_initialize_default( (void *) work_base, ram_end - work_base );
end = (char *) bsp_uboot_board_info.bi_memstart
+ bsp_uboot_board_info.bi_memsize;
_Memory_Initialize( &_Memory_Areas[ 0 ], WorkAreaBase, end );
}
RTEMS_SYSINIT_ITEM(
bsp_memory_initialize,
RTEMS_SYSINIT_MEMORY,
RTEMS_SYSINIT_ORDER_MIDDLE
);
#else /* !USE_UBOOT */
extern char RamEnd[];
static Memory_Area _Memory_Areas[] = {
MEMORY_INITIALIZER(WorkAreaBase, RamEnd)
};
#endif /* USE_UBOOT */
static const Memory_Information _Memory_Information =
MEMORY_INFORMATION_INITIALIZER( _Memory_Areas );
const Memory_Information *_Memory_Get( void )
{
return &_Memory_Information;
}