#include "sljitLir.h"
#include <stdio.h>
#include <stdlib.h>
typedef sljit_sw (SLJIT_FUNC *func3_t)(sljit_sw a, sljit_sw b, sljit_sw c);
static sljit_sw SLJIT_FUNC print_num(sljit_sw a)
{
printf("a = %ld\n", (long)a);
return a + 1;
}
static int func_call(sljit_sw a, sljit_sw b, sljit_sw c)
{
void *code;
sljit_uw len;
func3_t func;
struct sljit_jump *out;
struct sljit_jump *print_c;
struct sljit_compiler *C = sljit_create_compiler(NULL);
sljit_emit_enter(C, 0, SLJIT_ARGS3(W, W, W, W), 3, 3, 0);
sljit_emit_op2(C, SLJIT_AND, SLJIT_R0, 0, SLJIT_S0, 0, SLJIT_IMM, 1);
print_c = sljit_emit_cmp(C, SLJIT_EQUAL, SLJIT_R0, 0, SLJIT_IMM, 0);
sljit_emit_op1(C, SLJIT_MOV, SLJIT_R0, 0, SLJIT_S1, 0);
sljit_emit_icall(C, SLJIT_CALL, SLJIT_ARGS1(W, W), SLJIT_IMM, SLJIT_FUNC_ADDR(print_num));
out = sljit_emit_jump(C, SLJIT_JUMP);
sljit_set_label(print_c, sljit_emit_label(C));
sljit_emit_op1(C, SLJIT_MOV, SLJIT_R0, 0, SLJIT_S2, 0);
sljit_emit_icall(C, SLJIT_CALL, SLJIT_ARGS1(W, W), SLJIT_IMM, SLJIT_FUNC_ADDR(print_num));
sljit_set_label(out, sljit_emit_label(C));
sljit_emit_return(C, SLJIT_MOV, SLJIT_R0, 0);
code = sljit_generate_code(C, 0, NULL);
len = sljit_get_generated_code_size(C);
func = (func3_t)code;
printf("func return %ld\n", (long)func(a, b, c));
sljit_free_compiler(C);
sljit_free_code(code, NULL);
return 0;
}
int main()
{
return func_call(4, 5, 6);
}