You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							61 lines
						
					
					
						
							1.4 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							61 lines
						
					
					
						
							1.4 KiB
						
					
					
				| /* | |
|  * Copyright (c) 2006-2021, RT-Thread Development Team | |
|  * | |
|  * SPDX-License-Identifier: Apache-2.0 | |
|  * | |
|  * Change Logs: | |
|  * Date           Author       Notes | |
|  * 2019-12-04     Jiaxun Yang  Initial version | |
|  */ | |
| 
 | |
| #include <rtthread.h> | |
|  | |
| #include "mips.h" | |
|  | |
| register rt_uint32_t $GP __asm__ ("$28"); | |
| 
 | |
| rt_uint8_t *rt_hw_stack_init(void *tentry, void *parameter, rt_uint8_t *stack_addr, void *texit) | |
| { | |
|     static rt_ubase_t wSR=0; | |
|     static rt_ubase_t wGP; | |
|     rt_uint8_t *stk; | |
| 
 | |
|     struct pt_regs *pt; | |
| 
 | |
|     rt_uint32_t i; | |
| 
 | |
|     /* Get stack aligned */ | |
|     stk = (rt_uint8_t *)RT_ALIGN_DOWN((rt_ubase_t)stack_addr, 8); | |
|     stk -= sizeof(struct pt_regs); | |
|     pt =  (struct pt_regs*)stk; | |
| 
 | |
| #ifndef ARCH_MIPS64 | |
|     for (i = 0; i < 8; ++i) | |
|     { | |
|         pt->pad0[i] = 0xdeadbeef; | |
|     } | |
| #endif | |
|     /* Fill Stack register numbers */ | |
|     for (i = 0; i < 32; ++i) | |
|     { | |
|         pt->regs[i] = 0xdeadbeef; | |
|     } | |
| 
 | |
|     pt->regs[REG_SP] = (rt_ubase_t)stk; | |
|     pt->regs[REG_A0] = (rt_ubase_t)parameter; | |
|     pt->regs[REG_GP] = (rt_ubase_t)$GP; | |
|     pt->regs[REG_FP] = (rt_ubase_t)0x0; | |
|     pt->regs[REG_RA] = (rt_ubase_t)texit; | |
| 
 | |
|     pt->hi  = 0x0; | |
|     pt->lo  = 0x0; | |
|     pt->cp0_status = (ST0_IE | ST0_CU0 | ST0_IM); | |
| #ifdef RT_USING_FPU | |
|     pt->cp0_status |= (ST0_CU1 | ST0_FR); | |
| #endif | |
|     pt->cp0_cause   = read_c0_cause(); | |
|     pt->cp0_epc = (rt_ubase_t)tentry; | |
|     pt->cp0_badvaddr    = 0x0; | |
| 
 | |
|     return stk; | |
| }
 | |
| 
 |