1 1.1 alnsn #include "sljitLir.h" 2 1.1 alnsn 3 1.1 alnsn #include <stdio.h> 4 1.1 alnsn #include <stdlib.h> 5 1.1 alnsn 6 1.1 alnsn typedef long SLJIT_CALL (*func_arr_t)(long *arr, long narr); 7 1.1 alnsn 8 1.1 alnsn static long SLJIT_CALL print_num(long a) 9 1.1 alnsn { 10 1.1 alnsn printf("num = %ld\n", a); 11 1.1 alnsn return a + 1; 12 1.1 alnsn } 13 1.1 alnsn 14 1.1 alnsn /* 15 1.1 alnsn This example, we generate a function like this: 16 1.1 alnsn 17 1.1 alnsn long func(long *array, long narray) 18 1.1 alnsn { 19 1.1 alnsn long i; 20 1.1 alnsn for (i = 0; i < narray; ++i) 21 1.1 alnsn print_num(array[i]); 22 1.1 alnsn return narray; 23 1.1 alnsn } 24 1.1 alnsn 25 1.1 alnsn */ 26 1.1 alnsn 27 1.1 alnsn static int array_access(long *arr, long narr) 28 1.1 alnsn { 29 1.1 alnsn void *code; 30 1.1 alnsn unsigned long len; 31 1.1 alnsn func_arr_t func; 32 1.1 alnsn 33 1.1 alnsn /* Create a SLJIT compiler */ 34 1.1 alnsn struct sljit_compiler *C = sljit_create_compiler(); 35 1.1 alnsn 36 1.1 alnsn sljit_emit_enter(C, 0, 2, 1, 3, 0, 0, 0); 37 1.1 alnsn /* opt arg R S FR FS local_size */ 38 1.1 alnsn sljit_emit_op2(C, SLJIT_XOR, SLJIT_S2, 0, SLJIT_S2, 0, SLJIT_S2, 0); // S2 = 0 39 1.1 alnsn struct sljit_label *loopstart = sljit_emit_label(C); // loopstart: 40 1.1 alnsn struct sljit_jump *out = sljit_emit_cmp(C, SLJIT_GREATER_EQUAL, SLJIT_S2, 0, SLJIT_S1, 0); // S2 >= a --> jump out 41 1.1 alnsn 42 1.1 alnsn sljit_emit_op1(C, SLJIT_MOV, SLJIT_R0, 0, SLJIT_MEM2(SLJIT_S0, SLJIT_S2), SLJIT_WORD_SHIFT);// R0 = (long *)S0[S2]; 43 1.1 alnsn sljit_emit_ijump(C, SLJIT_CALL1, SLJIT_IMM, SLJIT_FUNC_OFFSET(print_num)); // print_num(R0); 44 1.1 alnsn 45 1.1 alnsn sljit_emit_op2(C, SLJIT_ADD, SLJIT_S2, 0, SLJIT_S2, 0, SLJIT_IMM, 1); // S2 += 1 46 1.1 alnsn sljit_set_label(sljit_emit_jump(C, SLJIT_JUMP), loopstart); // jump loopstart 47 1.1 alnsn sljit_set_label(out, sljit_emit_label(C)); // out: 48 1.1 alnsn sljit_emit_return(C, SLJIT_MOV, SLJIT_S1, 0); // return RET 49 1.1 alnsn 50 1.1 alnsn /* Generate machine code */ 51 1.1 alnsn code = sljit_generate_code(C); 52 1.1 alnsn len = sljit_get_generated_code_size(C); 53 1.1 alnsn 54 1.1 alnsn /* Execute code */ 55 1.1 alnsn func = (func_arr_t)code; 56 1.1 alnsn printf("func return %ld\n", func(arr, narr)); 57 1.1 alnsn 58 1.1 alnsn /* dump_code(code, len); */ 59 1.1 alnsn 60 1.1 alnsn /* Clean up */ 61 1.1 alnsn sljit_free_compiler(C); 62 1.1 alnsn sljit_free_code(code); 63 1.1 alnsn return 0; 64 1.1 alnsn } 65 1.1 alnsn 66 1.1 alnsn int main() 67 1.1 alnsn { 68 1.1 alnsn long arr[8] = { 3, -10, 4, 6, 8, 12, 2000 }; 69 1.1 alnsn return array_access(arr, 8); 70 1.1 alnsn } 71