69 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * Copyright (c) 2006-2021, RT-Thread Development Team
 | |
|  *
 | |
|  * SPDX-License-Identifier: Apache-2.0
 | |
|  *
 | |
|  * Change Logs:
 | |
|  * Date           Author       Notes
 | |
|  * 2011-01-13     weety      copy from mini2440
 | |
|  */
 | |
| #include <rtthread.h>
 | |
| 
 | |
| /*****************************/
 | |
| /* CPU Mode                  */
 | |
| /*****************************/
 | |
| #define USERMODE        0x10
 | |
| #define FIQMODE         0x11
 | |
| #define IRQMODE         0x12
 | |
| #define SVCMODE         0x13
 | |
| #define ABORTMODE       0x17
 | |
| #define UNDEFMODE       0x1b
 | |
| #define MODEMASK        0x1f
 | |
| #define NOINT           0xc0
 | |
| 
 | |
| /**
 | |
|  * This function will initialize thread stack
 | |
|  *
 | |
|  * @param tentry the entry of thread
 | |
|  * @param parameter the parameter of entry
 | |
|  * @param stack_addr the beginning stack address
 | |
|  * @param texit the function will be called when thread exit
 | |
|  *
 | |
|  * @return stack address
 | |
|  */
 | |
| rt_uint8_t *rt_hw_stack_init(void *tentry, void *parameter,
 | |
|                              rt_uint8_t *stack_addr, void *texit)
 | |
| {
 | |
|     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)texit;          /* lr */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r12 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r11 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r10 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r9 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r8 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r7 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r6 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r5 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r4 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r3 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r2 */
 | |
|     *(--stk) = 0xdeadbeef;                  /* r1 */
 | |
|     *(--stk) = (rt_uint32_t)parameter;      /* r0 : argument */
 | |
| 
 | |
|     /* cpsr */
 | |
|     if ((rt_uint32_t)tentry & 0x01)
 | |
|         *(--stk) = SVCMODE | 0x20;          /* thumb mode */
 | |
|     else
 | |
|         *(--stk) = SVCMODE;                 /* arm mode   */
 | |
| 
 | |
|     /* return task's current stack address */
 | |
|     return (rt_uint8_t *)stk;
 | |
| }
 | |
| 
 | 
