mirror of
				https://github.com/bytecodealliance/wasm-micro-runtime.git
				synced 2025-10-22 17:01:30 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			82 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			82 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
| /*
 | |
|  * Copyright (C) 2019 Intel Corporation.  All rights reserved.
 | |
|  * SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception
 | |
|  */
 | |
|         .text
 | |
|         .align  2
 | |
| #ifndef BH_PLATFORM_DARWIN
 | |
|         .globl invokeNative
 | |
|         .type  invokeNative, function
 | |
| invokeNative:
 | |
| #else
 | |
|         .globl _invokeNative
 | |
| _invokeNative:
 | |
| #endif /* end of BH_PLATFORM_DARWIN */
 | |
| 
 | |
| /*
 | |
|  * Arguments passed in:
 | |
|  *
 | |
|  * x0 function ptr
 | |
|  * x1 argv
 | |
|  * x2 nstacks
 | |
|  */
 | |
| 
 | |
|         sub     sp, sp, #0x30
 | |
|         stp     x19, x20, [sp, #0x20] /* save the registers */
 | |
|         stp     x21, x22, [sp, #0x10]
 | |
|         stp     x23, x24, [sp, #0x0]
 | |
| 
 | |
|         mov     x19, x0          /* x19 = function ptr */
 | |
|         mov     x20, x1          /* x20 = argv */
 | |
|         mov     x21, x2          /* x21 = nstacks */
 | |
|         mov     x22, sp          /* save the sp before call function */
 | |
| 
 | |
|         /* Fill in float-point registers */
 | |
|         ldp     d0, d1, [x20], #16 /* d0 = argv[0], d1 = argv[1] */
 | |
|         ldp     d2, d3, [x20], #16 /* d2 = argv[2], d3 = argv[3] */
 | |
|         ldp     d4, d5, [x20], #16 /* d4 = argv[4], d5 = argv[5] */
 | |
|         ldp     d6, d7, [x20], #16 /* d6 = argv[6], d7 = argv[7] */
 | |
| 
 | |
|         /* Fill integer registers */
 | |
|         ldp     x0, x1, [x20], #16 /* x0 = argv[8] = exec_env, x1 = argv[9] */
 | |
|         ldp     x2, x3, [x20], #16 /* x2 = argv[10], x3 = argv[11] */
 | |
|         ldp     x4, x5, [x20], #16 /* x4 = argv[12], x5 = argv[13] */
 | |
|         ldp     x6, x7, [x20], #16 /* x6 = argv[14], x7 = argv[15] */
 | |
| 
 | |
|         /* Now x20 points to stack args */
 | |
| 
 | |
|         /* Directly call the fucntion if no args in stack */
 | |
|         cmp     x21, #0
 | |
|         beq     call_func
 | |
| 
 | |
|         /* Fill all stack args: reserve stack space and fill one by one */
 | |
|         mov     x23, sp
 | |
|         bic     sp,  x23, #15    /* Ensure stack is 16 bytes aligned */
 | |
|         lsl     x23, x21, #3     /* x23 = nstacks * 8 */
 | |
|         add     x23, x23, #15    /* x23 = (x23 + 15) & ~15 */
 | |
|         bic     x23, x23, #15
 | |
|         sub     sp, sp, x23      /* reserved stack space for stack arguments */
 | |
|         mov     x23, sp
 | |
| 
 | |
| loop_stack_args:                 /* copy stack arguments to stack */
 | |
|         cmp     x21, #0
 | |
|         beq     call_func
 | |
|         ldr     x24, [x20], #8
 | |
|         str     x24, [x23], #8
 | |
|         sub     x21, x21, #1
 | |
|         b       loop_stack_args
 | |
| 
 | |
| call_func:
 | |
|         mov     x20, x30         /* save x30(lr) */
 | |
|         blr     x19
 | |
|         mov     sp, x22          /* restore sp which is saved before calling fuction*/
 | |
| 
 | |
| return:
 | |
|         mov     x30,  x20              /* restore x30(lr) */
 | |
|         ldp     x19, x20, [sp, #0x20]  /* restore the registers in stack */
 | |
|         ldp     x21, x22, [sp, #0x10]
 | |
|         ldp     x23, x24, [sp, #0x0]
 | |
|         add     sp, sp, #0x30          /* restore sp */
 | |
|         ret
 | |
| 
 | 
