#include "sljitLir.h" #include <stdio.h> #include <stdlib.h> typedef long (*func3_t)(long a, long b, long c); static long SLJIT_CALL print_arr(long *a, long n) { long i; long sum = 0; for (i = 0; i < n; ++i) { sum += a[i]; printf("arr[%ld] = %ld\n", i, a[i]); } return sum; } /* This example, we generate a function like this: long func(long a, long b, long c) { long arr[3] = { a, b, c }; return print_arr(arr, 3); } */ static int temp_var(long a, long b, long c) { void *code; unsigned long len; func3_t func; /* Create a SLJIT compiler */ struct sljit_compiler *C = sljit_create_compiler(); /* reserved space in stack for long arr[3] */ sljit_emit_enter(C, 0, 3, 2, 3, 0, 0, 3 * sizeof(long)); /* opt arg R S FR FS local_size */ /* arr[0] = S0, SLJIT_SP is the init address of local var */ sljit_emit_op1(C, SLJIT_MOV, SLJIT_MEM1(SLJIT_SP), 0, SLJIT_S0, 0); /* arr[1] = S1 */ sljit_emit_op1(C, SLJIT_MOV, SLJIT_MEM1(SLJIT_SP), 1 * sizeof(long), SLJIT_S1, 0); /* arr[2] = S2 */ sljit_emit_op1(C, SLJIT_MOV, SLJIT_MEM1(SLJIT_SP), 2 * sizeof(long), SLJIT_S2, 0); /* R0 = arr; in fact SLJIT_SP is the address of arr, but can't do so in SLJIT */ sljit_get_local_base(C, SLJIT_R0, 0, 0); /* get the address of local variables */ sljit_emit_op1(C, SLJIT_MOV, SLJIT_R1, 0, SLJIT_IMM, 3); /* R1 = 3; */ sljit_emit_ijump(C, SLJIT_CALL2, SLJIT_IMM, SLJIT_FUNC_OFFSET(print_arr)); sljit_emit_return(C, SLJIT_MOV, SLJIT_R0, 0); /* Generate machine code */ code = sljit_generate_code(C); len = sljit_get_generated_code_size(C); /* Execute code */ func = (func3_t)code; printf("func return %ld\n", func(a, b, c)); /* dump_code(code, len); */ /* Clean up */ sljit_free_compiler(C); sljit_free_code(code); return 0; } int main() { return temp_var(7, 8, 9); } |