From 15715692d231fb7542c18dc1d4ef25eb2571d2d4 Mon Sep 17 00:00:00 2001 From: SummerGift Date: Thu, 21 Dec 2017 10:11:55 +0800 Subject: [PATCH] [libcpu]: add 8-byte alignment for armv6 architecture --- libcpu/arm/armv6/stack.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/libcpu/arm/armv6/stack.c b/libcpu/arm/armv6/stack.c index ceb04f098..d84bb60d3 100644 --- a/libcpu/arm/armv6/stack.c +++ b/libcpu/arm/armv6/stack.c @@ -50,8 +50,10 @@ rt_uint8_t *rt_hw_stack_init(void *tentry, void *parameter, { rt_uint32_t *stk; + stack_addr += sizeof(rt_uint32_t); + stack_addr = (rt_uint8_t *)RT_ALIGN_DOWN((rt_uint32_t)stack_addr, 8); stk = (rt_uint32_t*)stack_addr; - *(stk) = (rt_uint32_t)tentry; /* entry point */ + *(--stk) = (rt_uint32_t)tentry; /* entry point */ *(--stk) = (rt_uint32_t)texit; /* lr */ *(--stk) = 0; /* r12 */ *(--stk) = 0; /* r11 */ -- GitLab