forked from Imagelibrary/rtems
bsps: Move stackalloc.c to bsps
This patch is a part of the BSP source reorganization. Update #3285.
This commit is contained in:
@@ -85,7 +85,7 @@ librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/timerstub.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/bsp-fdt.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-exception-handler.c
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-ttb-entries.c
|
||||
|
||||
@@ -39,7 +39,7 @@ librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
|
||||
# libchip
|
||||
librtemsbsp_a_SOURCES += libraries/libchip/source/acc.c
|
||||
|
||||
@@ -43,7 +43,7 @@ librtemsbsp_a_SOURCES += ../../shared/bspclean.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/gpio.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/timerstub.c
|
||||
|
||||
@@ -37,7 +37,7 @@ librtemsbsp_a_SOURCES += ../../shared/getentropy-cpucounter.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/timerstub.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/bsp-fdt.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-exception-handler.c
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-ttb-entries.c
|
||||
|
||||
@@ -38,7 +38,7 @@ librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterread.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
|
||||
# Startup
|
||||
librtemsbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S
|
||||
|
||||
@@ -45,7 +45,7 @@ librtemsbsp_a_SOURCES += ../../shared/bspclean.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/uart-output-char.c
|
||||
|
||||
# Startup
|
||||
|
||||
@@ -54,7 +54,7 @@ librtemsbsp_a_SOURCES += ../../shared/bspclean.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/uart-output-char.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
|
||||
|
||||
@@ -46,7 +46,7 @@ librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/uart-output-char.c
|
||||
librtemsbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-ttb-entries.c
|
||||
|
||||
@@ -43,7 +43,7 @@ librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterread.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-ttb-entries.c
|
||||
if BSP_START_IN_HYP_SUPPORT
|
||||
|
||||
@@ -44,7 +44,7 @@ librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/timerstub.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-exception-handler.c
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-ttb-entries.c
|
||||
|
||||
@@ -37,7 +37,7 @@ librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterread.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
|
||||
# Startup
|
||||
librtemsbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S
|
||||
|
||||
@@ -44,7 +44,7 @@ librtemsbsp_a_SOURCES += ../../shared/bspclean.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-exception-handler.c
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-ttb-entries.c
|
||||
|
||||
@@ -42,7 +42,7 @@ librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/cpucounterdiff.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/timerstub.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../shared/startup/bsp-start-memcpy.S
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-exception-handler.c
|
||||
librtemsbsp_a_SOURCES += ../shared/arm-cp15-set-ttb-entries.c
|
||||
|
||||
@@ -39,7 +39,7 @@ librtemsbsp_a_SOURCES += ../../shared/getentropy-cpucounter.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspclean.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
|
||||
# clock
|
||||
|
||||
@@ -46,7 +46,7 @@ librtemsbsp_a_SOURCES += ../../shared/bspclean.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
|
||||
# Console
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/dev/serial/legacy-console.c
|
||||
|
||||
@@ -43,7 +43,7 @@ librtemsbsp_a_SOURCES =
|
||||
librtemsbsp_a_SOURCES += ../../shared/getentropy-cpucounter.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspclean.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../shared/src/bsp-start-zero.S
|
||||
librtemsbsp_a_SOURCES += ../shared/src/memcpy.c
|
||||
librtemsbsp_a_SOURCES += ../shared/src/tictac.c
|
||||
|
||||
@@ -40,7 +40,7 @@ librtemsbsp_a_SOURCES += ../../shared/bspclean.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bsppredriverhook.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/getentropy-cpucounter.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/sbrk.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/src/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../../../../../bsps/shared/start/stackalloc.c
|
||||
librtemsbsp_a_SOURCES += ../../shared/bspgetworkarea.c
|
||||
|
||||
# clock
|
||||
|
||||
@@ -1,65 +0,0 @@
|
||||
/**
|
||||
* @file
|
||||
*
|
||||
* @ingroup bsp_shared
|
||||
*
|
||||
* @brief Stack initialization, allocation and free functions.
|
||||
*/
|
||||
|
||||
/*
|
||||
* Copyright (c) 2009-2013 embedded brains GmbH. All rights reserved.
|
||||
*
|
||||
* embedded brains GmbH
|
||||
* Obere Lagerstr. 30
|
||||
* 82178 Puchheim
|
||||
* Germany
|
||||
* <rtems@embedded-brains.de>
|
||||
*
|
||||
* 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.
|
||||
*/
|
||||
|
||||
#include <bsp/stackalloc.h>
|
||||
|
||||
#include <rtems.h>
|
||||
#include <rtems/score/heapimpl.h>
|
||||
#include <rtems/score/wkspace.h>
|
||||
|
||||
#include <bsp/linker-symbols.h>
|
||||
|
||||
static Heap_Control bsp_stack_heap;
|
||||
|
||||
void bsp_stack_allocate_init(size_t stack_space_size)
|
||||
{
|
||||
_Heap_Initialize(
|
||||
&bsp_stack_heap,
|
||||
bsp_section_stack_begin,
|
||||
(uintptr_t) bsp_section_stack_size,
|
||||
CPU_STACK_ALIGNMENT
|
||||
);
|
||||
}
|
||||
|
||||
void *bsp_stack_allocate(size_t size)
|
||||
{
|
||||
void *stack = NULL;
|
||||
|
||||
if (bsp_stack_heap.area_begin != 0) {
|
||||
stack = _Heap_Allocate(&bsp_stack_heap, size);
|
||||
}
|
||||
|
||||
if (stack == NULL) {
|
||||
stack = _Workspace_Allocate(size);
|
||||
}
|
||||
|
||||
return stack;
|
||||
}
|
||||
|
||||
void bsp_stack_free(void *stack)
|
||||
{
|
||||
bool ok = _Heap_Free(&bsp_stack_heap, stack);
|
||||
|
||||
if (!ok) {
|
||||
_Workspace_Free(stack);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user