Lines Matching refs:compiler
335 static sljit_si push_inst_debug(struct sljit_compiler *compiler, sljit_ins ins, int line) in push_inst_debug() argument
337 sljit_ins *ptr = (sljit_ins *)ensure_buf(compiler, sizeof(sljit_ins)); in push_inst_debug()
340 compiler->size++; in push_inst_debug()
346 static sljit_si push_inst_nodebug(struct sljit_compiler *compiler, sljit_ins ins) in push_inst_nodebug() argument
348 sljit_ins *ptr = (sljit_ins *)ensure_buf(compiler, sizeof(sljit_ins)); in push_inst_nodebug()
351 compiler->size++; in push_inst_nodebug()
357 static sljit_si push_inst(struct sljit_compiler *compiler, sljit_ins ins) in push_inst() argument
359 sljit_ins *ptr = (sljit_ins *)ensure_buf(compiler, sizeof(sljit_ins)); in push_inst()
362 compiler->size++; in push_inst()
385 push_inst(compiler, encoding)
388 push_3_buffer(compiler, opcode, dst, srca, srcb, __LINE__)
391 push_2_buffer(compiler, opcode, dst, src, __LINE__)
394 push_jr_buffer(compiler, TILEGX_OPC_JR, reg, __LINE__)
397 push_3_buffer(compiler, TILEGX_OPC_ADD, dst, srca, srcb, __LINE__)
400 push_3_buffer(compiler, TILEGX_OPC_SUB, dst, srca, srcb, __LINE__)
403 push_3_buffer(compiler, TILEGX_OPC_NOR, dst, srca, srcb, __LINE__)
406 push_3_buffer(compiler, TILEGX_OPC_OR, dst, srca, srcb, __LINE__)
409 push_3_buffer(compiler, TILEGX_OPC_XOR, dst, srca, srcb, __LINE__)
412 push_3_buffer(compiler, TILEGX_OPC_AND, dst, srca, srcb, __LINE__)
415 push_2_buffer(compiler, TILEGX_OPC_CLZ, dst, src, __LINE__)
418 push_3_buffer(compiler, TILEGX_OPC_SHLI, dst, srca, srcb, __LINE__)
421 push_3_buffer(compiler, TILEGX_OPC_SHRUI, dst, srca, imm, __LINE__)
424 push_3_buffer(compiler, TILEGX_OPC_XORI, dst, srca, imm, __LINE__)
427 push_3_buffer(compiler, TILEGX_OPC_ORI, dst, srca, imm, __LINE__)
430 push_3_buffer(compiler, TILEGX_OPC_CMPLTU, dst, srca, srcb, __LINE__)
433 push_3_buffer(compiler, TILEGX_OPC_CMPLTS, dst, srca, srcb, __LINE__)
436 push_3_buffer(compiler, TILEGX_OPC_CMPLTUI, dst, srca, imm, __LINE__)
439 push_3_buffer(compiler, TILEGX_OPC_CMOVNEZ, dst, srca, srcb, __LINE__)
442 push_3_buffer(compiler, TILEGX_OPC_CMOVEQZ, dst, srca, srcb, __LINE__)
445 push_3_buffer(compiler, TILEGX_OPC_ADDLI, dst, srca, srcb, __LINE__)
448 push_3_buffer(compiler, TILEGX_OPC_SHL16INSLI, dst, srca, srcb, __LINE__)
451 push_3_buffer(compiler, TILEGX_OPC_LD_ADD, dst, addr, adjust, __LINE__)
454 push_3_buffer(compiler, TILEGX_OPC_ST_ADD, src, addr, adjust, __LINE__)
457 push_2_buffer(compiler, TILEGX_OPC_LD, dst, addr, __LINE__)
460 push_4_buffer(compiler, TILEGX_OPC_BFEXTU, dst, src, start, end, __LINE__)
463 push_4_buffer(compiler, TILEGX_OPC_BFEXTS, dst, src, start, end, __LINE__)
466 push_inst(compiler, ADD_X1 | DEST_X1(dest) | SRCA_X1(srca) | SRCB_X1(srcb))
469 push_inst(compiler, ADDI_X1 | DEST_X1(dest) | SRCA_X1(srca) | IMM8_X1(imm))
472 push_inst(compiler, ADDLI_X1 | DEST_X1(dest) | SRCA_X1(srca) | IMM16_X1(imm))
475 push_inst(compiler, SHL16INSLI_X1 | DEST_X1(dest) | SRCA_X1(srca) | IMM16_X1(imm))
478 push_inst(compiler, JALR_X1 | SRCA_X1(reg))
481 push_inst(compiler, JR_X1 | SRCA_X1(reg))
626 static sljit_si update_buffer(struct sljit_compiler *compiler) in update_buffer() argument
655 return push_inst_nodebug(compiler, bits); in update_buffer()
657 return push_inst(compiler, bits); in update_buffer()
696 return push_inst_nodebug(compiler, bits); in update_buffer()
698 return push_inst(compiler, bits); in update_buffer()
728 return push_inst_nodebug(compiler, bits); in update_buffer()
730 return push_inst(compiler, bits); in update_buffer()
739 static sljit_si flush_buffer(struct sljit_compiler *compiler) in flush_buffer() argument
742 update_buffer(compiler); in flush_buffer()
745 static sljit_si push_4_buffer(struct sljit_compiler *compiler, tilegx_mnemonic opc, int op0, int op… in push_4_buffer() argument
748 FAIL_IF(update_buffer(compiler)); in push_4_buffer()
765 static sljit_si push_3_buffer(struct sljit_compiler *compiler, tilegx_mnemonic opc, int op0, int op… in push_3_buffer() argument
768 FAIL_IF(update_buffer(compiler)); in push_3_buffer()
825 static sljit_si push_2_buffer(struct sljit_compiler *compiler, tilegx_mnemonic opc, int op0, int op… in push_2_buffer() argument
828 FAIL_IF(update_buffer(compiler)); in push_2_buffer()
870 static sljit_si push_0_buffer(struct sljit_compiler *compiler, tilegx_mnemonic opc, int line) in push_0_buffer() argument
873 FAIL_IF(update_buffer(compiler)); in push_0_buffer()
886 static sljit_si push_jr_buffer(struct sljit_compiler *compiler, tilegx_mnemonic opc, int op0, int l… in push_jr_buffer() argument
889 FAIL_IF(update_buffer(compiler)); in push_jr_buffer()
900 return flush_buffer(compiler); in push_jr_buffer()
997 SLJIT_API_FUNC_ATTRIBUTE void * sljit_generate_code(struct sljit_compiler *compiler) in sljit_generate_code() argument
1012 check_sljit_generate_code(compiler); in sljit_generate_code()
1013 reverse_buf(compiler); in sljit_generate_code()
1015 code = (sljit_ins *)SLJIT_MALLOC_EXEC(compiler->size * sizeof(sljit_ins)); in sljit_generate_code()
1017 buf = compiler->buf; in sljit_generate_code()
1021 label = compiler->labels; in sljit_generate_code()
1022 jump = compiler->jumps; in sljit_generate_code()
1023 const_ = compiler->consts; in sljit_generate_code()
1072 SLJIT_ASSERT(code_ptr - code <= (sljit_sw)compiler->size); in sljit_generate_code()
1074 jump = compiler->jumps; in sljit_generate_code()
1115 compiler->error = SLJIT_ERR_COMPILED; in sljit_generate_code()
1116 compiler->executable_size = (code_ptr - code) * sizeof(sljit_ins); in sljit_generate_code()
1121 static sljit_si load_immediate(struct sljit_compiler *compiler, sljit_si dst_ar, sljit_sw imm) in load_immediate() argument
1144 static sljit_si emit_const(struct sljit_compiler *compiler, sljit_si dst_ar, sljit_sw imm, int flus… in emit_const() argument
1159 static sljit_si emit_const_64(struct sljit_compiler *compiler, sljit_si dst_ar, sljit_sw imm, int f… in emit_const_64() argument
1176 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_enter(struct sljit_compiler *compiler, in sljit_emit_enter() argument
1184 …check_sljit_emit_enter(compiler, options, args, scratches, saveds, fscratches, fsaveds, local_size… in sljit_emit_enter()
1186 compiler->options = options; in sljit_emit_enter()
1187 compiler->scratches = scratches; in sljit_emit_enter()
1188 compiler->saveds = saveds; in sljit_emit_enter()
1189 compiler->fscratches = fscratches; in sljit_emit_enter()
1190 compiler->fsaveds = fsaveds; in sljit_emit_enter()
1192 compiler->logical_local_size = local_size; in sljit_emit_enter()
1197 compiler->local_size = local_size; in sljit_emit_enter()
1204 FAIL_IF(load_immediate(compiler, TMP_REG1_mapped, local_size)); in sljit_emit_enter()
1241 SLJIT_API_FUNC_ATTRIBUTE void sljit_set_context(struct sljit_compiler *compiler, in sljit_set_context() argument
1246 …check_sljit_set_context(compiler, options, args, scratches, saveds, fscratches, fsaveds, local_siz… in sljit_set_context()
1248 compiler->options = options; in sljit_set_context()
1249 compiler->scratches = scratches; in sljit_set_context()
1250 compiler->saveds = saveds; in sljit_set_context()
1251 compiler->fscratches = fscratches; in sljit_set_context()
1252 compiler->fsaveds = fsaveds; in sljit_set_context()
1254 compiler->logical_local_size = local_size; in sljit_set_context()
1258 compiler->local_size = (local_size + 7) & ~7; in sljit_set_context()
1261 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_return(struct sljit_compiler *compiler, sljit_si op, s… in sljit_emit_return() argument
1268 check_sljit_emit_return(compiler, op, src, srcw); in sljit_emit_return()
1270 FAIL_IF(emit_mov_before_return(compiler, op, src, srcw)); in sljit_emit_return()
1272 local_size = compiler->local_size; in sljit_emit_return()
1276 FAIL_IF(load_immediate(compiler, TMP_REG1_mapped, local_size)); in sljit_emit_return()
1285 if (compiler->saveds >= 5) { in sljit_emit_return()
1292 if (compiler->saveds >= 4) { in sljit_emit_return()
1301 if (compiler->saveds >= 3) { in sljit_emit_return()
1310 if (compiler->saveds >= 2) { in sljit_emit_return()
1319 if (compiler->saveds >= 1) { in sljit_emit_return()
1328 if (compiler->local_size <= SIMM_16BIT_MAX) in sljit_emit_return()
1329 FAIL_IF(ADDLI(SLJIT_LOCALS_REG_mapped, SLJIT_LOCALS_REG_mapped, compiler->local_size)); in sljit_emit_return()
1339 static sljit_si getput_arg_fast(struct sljit_compiler *compiler, sljit_si flags, sljit_si reg_ar, s… in getput_arg_fast() argument
1391 static sljit_si getput_arg(struct sljit_compiler *compiler, sljit_si flags, sljit_si reg_ar, sljit_… in getput_arg() argument
1418 if (argw == compiler->cache_argw) { in getput_arg()
1420 if (arg == compiler->cache_arg) { in getput_arg()
1427 if ((SLJIT_MEM | (arg & OFFS_REG_MASK)) == compiler->cache_arg) { in getput_arg()
1429 compiler->cache_arg = arg; in getput_arg()
1430 compiler->cache_argw = argw; in getput_arg()
1445 if ((SLJIT_MEM | (arg & OFFS_REG_MASK)) == compiler->cache_arg) { in getput_arg()
1456 compiler->cache_arg = SLJIT_MEM | (arg & OFFS_REG_MASK); in getput_arg()
1457 compiler->cache_argw = argw; in getput_arg()
1463 compiler->cache_arg = arg; in getput_arg()
1464 compiler->cache_argw = argw; in getput_arg()
1509 if (compiler->cache_arg == SLJIT_MEM in getput_arg()
1510 && argw - compiler->cache_argw <= SIMM_16BIT_MAX in getput_arg()
1511 && argw - compiler->cache_argw >= SIMM_16BIT_MIN) { in getput_arg()
1512 if (argw != compiler->cache_argw) { in getput_arg()
1513 FAIL_IF(ADD(TMP_REG3_mapped, TMP_REG3_mapped, argw - compiler->cache_argw)); in getput_arg()
1514 compiler->cache_argw = argw; in getput_arg()
1519 compiler->cache_arg = SLJIT_MEM; in getput_arg()
1520 compiler->cache_argw = argw; in getput_arg()
1521 FAIL_IF(load_immediate(compiler, TMP_REG3_mapped, argw)); in getput_arg()
1532 if (compiler->cache_arg == arg in getput_arg()
1533 && argw - compiler->cache_argw <= SIMM_16BIT_MAX in getput_arg()
1534 && argw - compiler->cache_argw >= SIMM_16BIT_MIN) { in getput_arg()
1535 if (argw != compiler->cache_argw) { in getput_arg()
1536 FAIL_IF(ADDLI(TMP_REG3_mapped, TMP_REG3_mapped, argw - compiler->cache_argw)); in getput_arg()
1537 compiler->cache_argw = argw; in getput_arg()
1546 if (compiler->cache_arg == SLJIT_MEM in getput_arg()
1547 && argw - compiler->cache_argw <= SIMM_16BIT_MAX in getput_arg()
1548 && argw - compiler->cache_argw >= SIMM_16BIT_MIN) { in getput_arg()
1549 if (argw != compiler->cache_argw) in getput_arg()
1550 FAIL_IF(ADDLI(TMP_REG3_mapped, TMP_REG3_mapped, argw - compiler->cache_argw)); in getput_arg()
1552 compiler->cache_arg = SLJIT_MEM; in getput_arg()
1553 FAIL_IF(load_immediate(compiler, TMP_REG3_mapped, argw)); in getput_arg()
1556 compiler->cache_argw = argw; in getput_arg()
1568 compiler->cache_arg = arg; in getput_arg()
1584 static SLJIT_INLINE sljit_si emit_op_mem(struct sljit_compiler *compiler, sljit_si flags, sljit_si … in emit_op_mem() argument
1586 if (getput_arg_fast(compiler, flags, reg_ar, arg, argw)) in emit_op_mem()
1587 return compiler->error; in emit_op_mem()
1589 compiler->cache_arg = 0; in emit_op_mem()
1590 compiler->cache_argw = 0; in emit_op_mem()
1591 return getput_arg(compiler, flags, reg_ar, arg, argw, 0, 0); in emit_op_mem()
1594 static SLJIT_INLINE sljit_si emit_op_mem2(struct sljit_compiler *compiler, sljit_si flags, sljit_si… in emit_op_mem2() argument
1596 if (getput_arg_fast(compiler, flags, reg, arg1, arg1w)) in emit_op_mem2()
1597 return compiler->error; in emit_op_mem2()
1598 return getput_arg(compiler, flags, reg, arg1, arg1w, arg2, arg2w); in emit_op_mem2()
1601 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_fast_enter(struct sljit_compiler *compiler, sljit_si d… in sljit_emit_fast_enter() argument
1604 check_sljit_emit_fast_enter(compiler, dst, dstw); in sljit_emit_fast_enter()
1615 return emit_op_mem(compiler, WORD_DATA, RA, dst, dstw); in sljit_emit_fast_enter()
1618 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_fast_return(struct sljit_compiler *compiler, sljit_si … in sljit_emit_fast_return() argument
1621 check_sljit_emit_fast_return(compiler, src, srcw); in sljit_emit_fast_return()
1628 FAIL_IF(emit_op_mem(compiler, WORD_DATA | LOAD_DATA, RA, src, srcw)); in sljit_emit_fast_return()
1631 FAIL_IF(load_immediate(compiler, RA, srcw)); in sljit_emit_fast_return()
1636 static SLJIT_INLINE sljit_si emit_single_op(struct sljit_compiler *compiler, sljit_si op, sljit_si … in emit_single_op() argument
1839 FAIL_IF(load_immediate(compiler, ADDR_TMP_mapped, src2)); in emit_single_op()
1898 FAIL_IF(load_immediate(compiler, ADDR_TMP_mapped, -src2)); in emit_single_op()
1924 FAIL_IF(load_immediate(compiler, ADDR_TMP_mapped, src2)); \ in emit_single_op()
1927 compiler, op_norm, EQUAL_FLAG, reg_map[src1], \ in emit_single_op()
1931 compiler, op_norm, reg_map[dst], reg_map[src1], \ in emit_single_op()
1936 compiler, op_norm, EQUAL_FLAG, reg_map[src1], \ in emit_single_op()
1940 compiler, op_norm, reg_map[dst], reg_map[src1], \ in emit_single_op()
1960 compiler, op_imm, EQUAL_FLAG, reg_map[src1], \ in emit_single_op()
1964 compiler, op_imm, reg_map[dst], reg_map[src1], \ in emit_single_op()
1969 compiler, op_imm, reg_map[dst], reg_map[src1], \ in emit_single_op()
1973 compiler, op_norm, reg_map[dst], reg_map[src1], \ in emit_single_op()
1994 static sljit_si emit_op(struct sljit_compiler *compiler, sljit_si op, sljit_si flags, sljit_si dst,… in emit_op() argument
2006 compiler->cache_arg = 0; in emit_op()
2007 compiler->cache_argw = 0; in emit_op()
2020 …} else if ((dst & SLJIT_MEM) && !getput_arg_fast(compiler, flags | ARG_TEST, TMP_REG1_mapped, dst,… in emit_op()
2055 FAIL_IF(load_immediate(compiler, TMP_REG1_mapped, src1w)); in emit_op()
2060 if (getput_arg_fast(compiler, flags | LOAD_DATA, TMP_REG1_mapped, src1, src1w)) in emit_op()
2061 FAIL_IF(compiler->error); in emit_op()
2076 FAIL_IF(load_immediate(compiler, reg_map[sugg_src2_r], src2w)); in emit_op()
2085 if (getput_arg_fast(compiler, flags | LOAD_DATA, reg_map[sugg_src2_r], src2, src2w)) in emit_op()
2086 FAIL_IF(compiler->error); in emit_op()
2095 FAIL_IF(getput_arg(compiler, flags | LOAD_DATA, TMP_REG2_mapped, src2, src2w, src1, src1w)); in emit_op()
2096 FAIL_IF(getput_arg(compiler, flags | LOAD_DATA, TMP_REG1_mapped, src1, src1w, dst, dstw)); in emit_op()
2098 FAIL_IF(getput_arg(compiler, flags | LOAD_DATA, TMP_REG1_mapped, src1, src1w, src2, src2w)); in emit_op()
2099 FAIL_IF(getput_arg(compiler, flags | LOAD_DATA, TMP_REG2_mapped, src2, src2w, dst, dstw)); in emit_op()
2102 FAIL_IF(getput_arg(compiler, flags | LOAD_DATA, TMP_REG1_mapped, src1, src1w, dst, dstw)); in emit_op()
2104 FAIL_IF(getput_arg(compiler, flags | LOAD_DATA, reg_map[sugg_src2_r], src2, src2w, dst, dstw)); in emit_op()
2106 FAIL_IF(emit_single_op(compiler, op, flags, dst_r, src1_r, src2_r)); in emit_op()
2110 getput_arg_fast(compiler, flags, reg_map[dst_r], dst, dstw); in emit_op()
2111 return compiler->error; in emit_op()
2114 return getput_arg(compiler, flags, reg_map[dst_r], dst, dstw, 0, 0); in emit_op()
2120 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op_flags(struct sljit_compiler *compiler, sljit_si op,… in sljit_emit_op_flags() argument
2126 check_sljit_emit_op_flags(compiler, op, dst, dstw, src, srcw, type); in sljit_emit_op_flags()
2135 compiler->cache_arg = 0; in sljit_emit_op_flags()
2136 compiler->cache_argw = 0; in sljit_emit_op_flags()
2139 FAIL_IF(emit_op_mem2(compiler, WORD_DATA | LOAD_DATA, TMP_REG1_mapped, src, srcw, dst, dstw)); in sljit_emit_op_flags()
2199 …return emit_op(compiler, op | flags, CUMULATIVE_OP | LOGICAL_OP | IMM_OP | ALT_KEEP_CACHE, dst, ds… in sljit_emit_op_flags()
2203 return emit_op_mem(compiler, WORD_DATA, dst_ar, dst, dstw); in sljit_emit_op_flags()
2211 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op0(struct sljit_compiler *compiler, sljit_si op) { in sljit_emit_op0() argument
2213 check_sljit_emit_op0(compiler, op); in sljit_emit_op0()
2218 return push_0_buffer(compiler, TILEGX_OPC_FNOP, __LINE__); in sljit_emit_op0()
2233 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op1(struct sljit_compiler *compiler, sljit_si op, slji… in sljit_emit_op1() argument
2236 check_sljit_emit_op1(compiler, op, dst, dstw, src, srcw); in sljit_emit_op1()
2243 return emit_op(compiler, SLJIT_MOV, WORD_DATA, dst, dstw, TMP_REG1, 0, src, srcw); in sljit_emit_op1()
2246 return emit_op(compiler, SLJIT_MOV_UI, INT_DATA, dst, dstw, TMP_REG1, 0, src, srcw); in sljit_emit_op1()
2249 return emit_op(compiler, SLJIT_MOV_SI, INT_DATA | SIGNED_DATA, dst, dstw, TMP_REG1, 0, src, srcw); in sljit_emit_op1()
2252 …return emit_op(compiler, SLJIT_MOV_UB, BYTE_DATA, dst, dstw, TMP_REG1, 0, src, (src & SLJIT_IMM) ?… in sljit_emit_op1()
2255 …return emit_op(compiler, SLJIT_MOV_SB, BYTE_DATA | SIGNED_DATA, dst, dstw, TMP_REG1, 0, src, (src … in sljit_emit_op1()
2258 …return emit_op(compiler, SLJIT_MOV_UH, HALF_DATA, dst, dstw, TMP_REG1, 0, src, (src & SLJIT_IMM) ?… in sljit_emit_op1()
2261 …return emit_op(compiler, SLJIT_MOV_SH, HALF_DATA | SIGNED_DATA, dst, dstw, TMP_REG1, 0, src, (src … in sljit_emit_op1()
2265 return emit_op(compiler, SLJIT_MOV, WORD_DATA | WRITE_BACK, dst, dstw, TMP_REG1, 0, src, srcw); in sljit_emit_op1()
2268 return emit_op(compiler, SLJIT_MOV_UI, INT_DATA | WRITE_BACK, dst, dstw, TMP_REG1, 0, src, srcw); in sljit_emit_op1()
2271 …return emit_op(compiler, SLJIT_MOV_SI, INT_DATA | SIGNED_DATA | WRITE_BACK, dst, dstw, TMP_REG1, 0… in sljit_emit_op1()
2274 …return emit_op(compiler, SLJIT_MOV_UB, BYTE_DATA | WRITE_BACK, dst, dstw, TMP_REG1, 0, src, (src &… in sljit_emit_op1()
2277 …return emit_op(compiler, SLJIT_MOV_SB, BYTE_DATA | SIGNED_DATA | WRITE_BACK, dst, dstw, TMP_REG1, … in sljit_emit_op1()
2280 …return emit_op(compiler, SLJIT_MOV_UH, HALF_DATA | WRITE_BACK, dst, dstw, TMP_REG1, 0, src, (src &… in sljit_emit_op1()
2283 …return emit_op(compiler, SLJIT_MOV_SH, HALF_DATA | SIGNED_DATA | WRITE_BACK, dst, dstw, TMP_REG1, … in sljit_emit_op1()
2286 return emit_op(compiler, op, 0, dst, dstw, TMP_REG1, 0, src, srcw); in sljit_emit_op1()
2289 …return emit_op(compiler, SLJIT_SUB | GET_ALL_FLAGS(op), IMM_OP, dst, dstw, SLJIT_IMM, 0, src, srcw… in sljit_emit_op1()
2292 return emit_op(compiler, op, 0, dst, dstw, TMP_REG1, 0, src, srcw); in sljit_emit_op1()
2298 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_op2(struct sljit_compiler *compiler, sljit_si op, slji… in sljit_emit_op2() argument
2301 check_sljit_emit_op2(compiler, op, dst, dstw, src1, src1w, src2, src2w); in sljit_emit_op2()
2309 return emit_op(compiler, op, CUMULATIVE_OP | IMM_OP, dst, dstw, src1, src1w, src2, src2w); in sljit_emit_op2()
2313 return emit_op(compiler, op, IMM_OP, dst, dstw, src1, src1w, src2, src2w); in sljit_emit_op2()
2316 return emit_op(compiler, op, CUMULATIVE_OP, dst, dstw, src1, src1w, src2, src2w); in sljit_emit_op2()
2321 …return emit_op(compiler, op, CUMULATIVE_OP | LOGICAL_OP | IMM_OP, dst, dstw, src1, src1w, src2, sr… in sljit_emit_op2()
2331 return emit_op(compiler, op, IMM_OP, dst, dstw, src1, src1w, src2, src2w); in sljit_emit_op2()
2337 SLJIT_API_FUNC_ATTRIBUTE struct sljit_label * sljit_emit_label(struct sljit_compiler *compiler) in sljit_emit_label() argument
2341 flush_buffer(compiler); in sljit_emit_label()
2344 check_sljit_emit_label(compiler); in sljit_emit_label()
2346 if (compiler->last_label && compiler->last_label->size == compiler->size) in sljit_emit_label()
2347 return compiler->last_label; in sljit_emit_label()
2349 label = (struct sljit_label *)ensure_abuf(compiler, sizeof(struct sljit_label)); in sljit_emit_label()
2351 set_label(label, compiler); in sljit_emit_label()
2355 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_ijump(struct sljit_compiler *compiler, sljit_si type, … in sljit_emit_ijump() argument
2360 flush_buffer(compiler); in sljit_emit_ijump()
2363 check_sljit_emit_ijump(compiler, type, src, srcw); in sljit_emit_ijump()
2377 FAIL_IF(emit_const(compiler, reg_map[PIC_ADDR_REG], srcw, 1)); in sljit_emit_ijump()
2380 FAIL_IF(emit_op(compiler, SLJIT_MOV, WORD_DATA, TMP_REG2, 0, TMP_REG1, 0, src, srcw)); in sljit_emit_ijump()
2406 jump = (struct sljit_jump *)ensure_abuf(compiler, sizeof(struct sljit_jump)); in sljit_emit_ijump()
2408 set_jump(jump, compiler, JUMP_ADDR | ((type >= SLJIT_FAST_CALL) ? IS_JAL : 0)); in sljit_emit_ijump()
2410 FAIL_IF(emit_const(compiler, TMP_REG2_mapped, 0, 1)); in sljit_emit_ijump()
2414 jump->addr = compiler->size; in sljit_emit_ijump()
2417 jump->addr = compiler->size; in sljit_emit_ijump()
2424 FAIL_IF(emit_op(compiler, SLJIT_MOV, WORD_DATA, TMP_REG2, 0, TMP_REG1, 0, src, srcw)); in sljit_emit_ijump()
2429 jump->addr = compiler->size; in sljit_emit_ijump()
2442 SLJIT_API_FUNC_ATTRIBUTE struct sljit_jump * sljit_emit_jump(struct sljit_compiler *compiler, sljit… in sljit_emit_jump() argument
2448 flush_buffer(compiler); in sljit_emit_jump()
2451 check_sljit_emit_jump(compiler, type); in sljit_emit_jump()
2453 jump = (struct sljit_jump *)ensure_abuf(compiler, sizeof(struct sljit_jump)); in sljit_emit_jump()
2455 set_jump(jump, compiler, type & SLJIT_REWRITABLE_JUMP); in sljit_emit_jump()
2516 PTR_FAIL_IF(emit_const(compiler, TMP_REG2_mapped, 0, 1)); in sljit_emit_jump()
2518 jump->addr = compiler->size; in sljit_emit_jump()
2525 jump->addr = compiler->size; in sljit_emit_jump()
2537 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_fop1(struct sljit_compiler *compiler, sljit_si op, slj… in sljit_emit_fop1() argument
2542 SLJIT_API_FUNC_ATTRIBUTE sljit_si sljit_emit_fop2(struct sljit_compiler *compiler, sljit_si op, slj… in sljit_emit_fop2() argument
2547 SLJIT_API_FUNC_ATTRIBUTE struct sljit_const * sljit_emit_const(struct sljit_compiler *compiler, slj… in sljit_emit_const() argument
2552 flush_buffer(compiler); in sljit_emit_const()
2555 check_sljit_emit_const(compiler, dst, dstw, init_value); in sljit_emit_const()
2558 const_ = (struct sljit_const *)ensure_abuf(compiler, sizeof(struct sljit_const)); in sljit_emit_const()
2560 set_const(const_, compiler); in sljit_emit_const()
2564 PTR_FAIL_IF(emit_const_64(compiler, reg, init_value, 1)); in sljit_emit_const()
2567 PTR_FAIL_IF(emit_op(compiler, SLJIT_MOV, WORD_DATA, dst, dstw, TMP_REG1, 0, TMP_REG2, 0)); in sljit_emit_const()