summaryrefslogtreecommitdiffstats
path: root/fluent-bit/lib/wasm-micro-runtime-WAMR-1.2.2/core/iwasm/common/arch/invokeNative_arc.s
blob: e448eea6508246c8cc914e0f8fdbd6ecba2b501e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
/*
 * 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:
 *   r0: function ptr
 *   r1: argv
 *   r2: nstacks
 * ARC ABI:
 *   r0-r7:  function arguments, caller-saved
 *   r8-r12: temp registers, caller-saved
 */

    push_s  blink               /* push return addr */
    st.aw   fp, [sp, -4]        /* push fp */
    mov     fp, sp              /* fp = sp */

    mov     r8, r0              /* r8 = func_ptr */
    mov     r9, r1              /* r9 = argv */
    mov     r10, r2             /* r10 = nstacks */

    ld      r0, [r9, 0]         /* r0 = argv[0] */
    ld      r1, [r9, 4]         /* r1 = argv[1] */
    ld      r2, [r9, 8]         /* r2 = argv[2] */
    ld      r3, [r9, 12]        /* r3 = argv[3] */
    ld      r4, [r9, 16]        /* r4 = argv[4] */
    ld      r5, [r9, 20]        /* r5 = argv[5] */
    ld      r6, [r9, 24]        /* r6 = argv[6] */
    ld      r7, [r9, 28]        /* r7 = argv[7] */

    add     r9, r9, 32          /* r9 = stack_args */
    breq    r10, 0, call_func   /* if (r10 == 0) goto call_func */

    asl     r11, r10, 2         /* r11 = nstacks * 4 */
    sub     sp, sp, r11         /* sp = sp - nstacks * 4 */
    and     sp, sp, ~7          /* make sp 8-byte aligned */
    mov     r11, sp             /* r11 = sp */

loop_stack_args:
    breq    r10, 0, call_func   /* if (r10 == 0) goto call_func */
    ld      r12, [r9]           /* r12 = stack_args[i] */
    st      r12, [r11]          /* stack[i] = r12 */
    add     r9, r9, 4           /* r9 = r9 + 4 */
    add     r11, r11, 4         /* r11 = r11 + 4 */
    sub     r10, r10, 1         /* r10 = r10 + 1 */
    j       loop_stack_args

call_func:
    jl      [r8]                /* call function */

    mov     sp, fp              /* sp = fp */
    ld.ab   fp, [sp, 4]         /* pop fp */
    pop_s   blink               /* pop return addr */
    j_s     [blink]             /* ret */
    nop_s