summaryrefslogtreecommitdiffstats
path: root/bsps/sparc/shared/start/start.S
diff options
context:
space:
mode:
authorSebastian Huber <sebastian.huber@embedded-brains.de>2021-06-08 08:08:43 +0200
committerSebastian Huber <sebastian.huber@embedded-brains.de>2021-06-10 07:53:04 +0200
commitb823c9843dabbf81eec26b1042a3b8ec65690441 (patch)
tree5ce8767291d4bb3c0430d8a3a9e2e0fb75611e47 /bsps/sparc/shared/start/start.S
parentbsps/sparc: Remove support to load data section (diff)
downloadrtems-b823c9843dabbf81eec26b1042a3b8ec65690441.tar.bz2
bsps/sparc: Unify stack initialization
Initialize the stacks in start.S in one place and identical to _CPU_Context_Initialize().
Diffstat (limited to 'bsps/sparc/shared/start/start.S')
-rw-r--r--bsps/sparc/shared/start/start.S14
1 files changed, 6 insertions, 8 deletions
diff --git a/bsps/sparc/shared/start/start.S b/bsps/sparc/shared/start/start.S
index 369ef72a94..a9669bbc94 100644
--- a/bsps/sparc/shared/start/start.S
+++ b/bsps/sparc/shared/start/start.S
@@ -306,13 +306,12 @@ SYM(hard_reset):
nop
ld [%g6 + PER_CPU_INTERRUPT_STACK_HIGH], %sp ! set stack pointer
- sub %sp, 4, %sp ! stack starts at end of area - 4
- andn %sp, 0x0f, %sp ! align stack on 16-byte boundary
+ andn %sp, CPU_STACK_ALIGNMENT - 1, %sp
+ sub %sp, SPARC_MINIMUM_STACK_FRAME_SIZE, %sp
mov %sp, %fp ! set frame pointer
- mov %g6, %o0
call SYM(bsp_start_on_secondary_processor) ! does not return
- sub %sp, SPARC_MINIMUM_STACK_FRAME_SIZE, %sp
+ mov %g6, %o0
.Lbootcpu:
st %o0, [%o1]
#endif
@@ -326,8 +325,8 @@ SYM(hard_reset):
#endif
set SYM(_ISR_Stack_area_begin), %sp
add %sp, %g5, %sp
- sub %sp, 4, %sp ! stack starts at end of area - 4
- andn %sp, 0x0f, %sp ! align stack on 16-byte boundary
+ andn %sp, CPU_STACK_ALIGNMENT - 1, %sp
+ sub %sp, SPARC_MINIMUM_STACK_FRAME_SIZE, %sp
mov %sp, %fp ! Set frame pointer
nop
@@ -346,8 +345,7 @@ SYM(hard_reset):
bleu,a .Lzerobss
nop
- mov %g0, %o0 ! command line
call SYM(boot_card) ! does not return
- sub %sp, 0x60, %sp ! room for boot_card to save args
+ mov %g0, %o0 ! command line
/* end of file */