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.
		
		
		
		
		
			
		
			
				
					
					
						
							67 lines
						
					
					
						
							1.7 KiB
						
					
					
				
			
		
		
		
			
			
			
				
					
				
				
					
				
			
		
		
	
	
							67 lines
						
					
					
						
							1.7 KiB
						
					
					
				| ;/* | |
| ; * Copyright (c) 2006-2022, RT-Thread Development Team | |
| ; * | |
| ; * SPDX-License-Identifier: Apache-2.0 | |
| ; * | |
| ; * Change Logs: | |
| ; * Date           Author       Notes | |
| ; * 2019-10-25     tyx          first version | |
| ; * 2021-03-26     lxf          modify bad instruction | |
| ; */ | |
|  | |
| ;/* | |
| ; * @addtogroup cortex-m33 | |
| ; */ | |
|  | |
| 
 | |
|     SECTION    .text:CODE(2) | |
|     THUMB | |
|     REQUIRE8 | |
|     PRESERVE8 | |
| 
 | |
|     IMPORT rt_secure_svc_handle | |
| 
 | |
| ;/* | |
| ; * int tzcall(int id, rt_ubase_t arg0, rt_ubase_t arg1, rt_ubase_t arg2); | |
| ; */ | |
|     EXPORT tzcall | |
| tzcall: | |
|     SVC     1                       ;/* call SVC 1 */ | |
|     BX      LR | |
| 
 | |
| tzcall_entry: | |
|     PUSH    {R1, R4, LR} | |
|     MOV     R4, R1                  ;/* copy thread SP to R4 */ | |
|     LDMFD   R4!, {r0 - r3}          ;/* pop user stack, get input arg0, arg1, arg2 */ | |
|     STMFD   R4!, {r0 - r3}          ;/* push stack, user stack recovery */ | |
|     BL      rt_secure_svc_handle    ;/* call fun */ | |
|     POP     {R1, R4, LR} | |
|     STR     R0, [R1]                ;/* update return value */ | |
|     BX      LR                      ;/* return to thread */ | |
|  | |
| syscall_entry: | |
|     BX      LR                      ;/* return to user app */ | |
|  | |
|     EXPORT SVC_Handler | |
| SVC_Handler: | |
| 
 | |
|     ;/* get SP, save to R1 */ | |
|     MRS     R1, MSP                 ;/* get fault context from handler. */ | |
|     TST     LR, #0x04               ;/* if(!EXC_RETURN[2]) */ | |
|     BEQ     get_sp_done | |
|     MRS     R1, PSP                 ;/* get fault context from thread. */ | |
| get_sp_done: | |
| 
 | |
|     ;/* get svc index */ | |
|     LDR     R0, [R1, #24] | |
|     LDRB    R0, [R0, #-2] | |
|  | |
|     ;/* if svc == 0, do system call */ | |
|     CMP     R0, #0x0 | |
|     BEQ    syscall_entry | |
| 
 | |
|     ;/* if svc == 1, do TrustZone call */ | |
|     CMP     R0, #0x1 | |
|     BEQ    tzcall_entry | |
| 
 | |
|     END
 | |
| 
 |