#include "sljitLir.h"
#include <stdio.h>
#include <stdlib.h>
typedef sljit_sw (SLJIT_FUNC *func_arr_t)(sljit_sw *arr, sljit_sw narr);
static void SLJIT_FUNC print_num(sljit_sw a)
{
printf("num = %ld\n", (long)a);
}
static int array_access(sljit_sw *arr, sljit_sw narr)
{
void *code;
sljit_uw len;
func_arr_t func;
struct sljit_label *loopstart;
struct sljit_jump *out;
struct sljit_compiler *C = sljit_create_compiler(NULL);
sljit_emit_enter(C, 0, SLJIT_ARGS2(W, P, W), 1, 3, 0);
sljit_emit_op2(C, SLJIT_XOR, SLJIT_S2, 0, SLJIT_S2, 0, SLJIT_S2, 0);
sljit_emit_op1(C, SLJIT_MOV, SLJIT_S1, 0, SLJIT_IMM, narr);
loopstart = sljit_emit_label(C);
out = sljit_emit_cmp(C, SLJIT_GREATER_EQUAL, SLJIT_S2, 0, SLJIT_S1, 0);
sljit_emit_op1(C, SLJIT_MOV, SLJIT_R0, 0, SLJIT_MEM2(SLJIT_S0, SLJIT_S2), SLJIT_WORD_SHIFT);
sljit_emit_icall(C, SLJIT_CALL, SLJIT_ARGS1V(W), SLJIT_IMM, SLJIT_FUNC_ADDR(print_num));
sljit_emit_op2(C, SLJIT_ADD, SLJIT_S2, 0, SLJIT_S2, 0, SLJIT_IMM, 1);
sljit_set_label(sljit_emit_jump(C, SLJIT_JUMP), loopstart);
sljit_set_label(out, sljit_emit_label(C));
sljit_emit_return(C, SLJIT_MOV, SLJIT_S1, 0);
code = sljit_generate_code(C, 0, NULL);
len = sljit_get_generated_code_size(C);
func = (func_arr_t)code;
printf("func return %ld\n", (long)func(arr, narr));
sljit_free_compiler(C);
sljit_free_code(code, NULL);
return 0;
}
int main(void)
{
sljit_sw arr[8] = { 3, -10, 4, 6, 8, 12, 2000, 0 };
return array_access(arr, 8);
}