Lines Matching refs:compiler
4 * Stack-less Just-In-Time compiler
31 static sljit_s32 load_immediate(struct sljit_compiler *compiler, sljit_s32 reg, sljit_sw imm)
34 return push_inst(compiler, ADDI | D(reg) | A(0) | IMM(imm));
37 return push_inst(compiler, ORI | S(TMP_ZERO) | A(reg) | IMM(imm));
39 FAIL_IF(push_inst(compiler, ADDIS | D(reg) | A(0) | IMM(imm >> 16)));
40 return (imm & 0xffff) ? push_inst(compiler, ORI | S(reg) | A(reg) | IMM(imm)) : SLJIT_SUCCESS;
46 static SLJIT_INLINE sljit_s32 emit_single_op(struct sljit_compiler *compiler, sljit_s32 op, sljit_s32 flags,
56 return push_inst(compiler, OR | S(src2) | A(dst) | B(src2));
64 return push_inst(compiler, EXTSB | S(src2) | A(dst));
65 return push_inst(compiler, INS_CLEAR_LEFT(dst, src2, 24));
68 return push_inst(compiler, EXTSB | S(src2) | A(dst));
79 return push_inst(compiler, EXTSH | S(src2) | A(dst));
80 return push_inst(compiler, INS_CLEAR_LEFT(dst, src2, 16));
89 return push_inst(compiler, NOR | RC(flags) | S(src2) | A(dst) | B(src2));
93 return push_inst(compiler, NEG | OERC(flags) | D(dst) | A(src2));
97 return push_inst(compiler, CNTLZW | RC(flags) | S(src2) | A(dst));
103 return push_inst(compiler, ADDI | D(dst) | A(src1) | compiler->imm);
108 return push_inst(compiler, ADDIS | D(dst) | A(src1) | compiler->imm);
112 return push_inst(compiler, ADDIC | D(dst) | A(src1) | compiler->imm);
116 FAIL_IF(push_inst(compiler, ADDI | D(dst) | A(src1) | (compiler->imm & 0xffff)));
117 return push_inst(compiler, ADDIS | D(dst) | A(dst) | (((compiler->imm >> 16) & 0xffff) + ((compiler->imm >> 15) & 0x1)));
120 return push_inst(compiler, ADD | D(dst) | A(src1) | B(src2));
121 return push_inst(compiler, ADDC | OERC(ALT_SET_FLAGS) | D(dst) | A(src1) | B(src2));
124 return push_inst(compiler, ADDE | D(dst) | A(src1) | B(src2));
129 return push_inst(compiler, SUBFIC | D(dst) | A(src1) | compiler->imm);
133 return push_inst(compiler, ((flags & ALT_FORM2) ? CMPI : CMPLI) | CRD(0) | A(src1) | compiler->imm);
136 return push_inst(compiler, ((flags & ALT_FORM4) ? CMP : CMPL) | CRD(0) | A(src1) | B(src2));
140 FAIL_IF(push_inst(compiler, CMPLI | CRD(0) | A(src1) | compiler->imm));
141 return push_inst(compiler, ADDI | D(dst) | A(src1) | (-compiler->imm & 0xffff));
144 FAIL_IF(push_inst(compiler, CMPL | CRD(0) | A(src1) | B(src2)));
145 return push_inst(compiler, SUBF | D(dst) | A(src2) | B(src1));
148 return push_inst(compiler, SUBF | D(dst) | A(src2) | B(src1));
149 return push_inst(compiler, SUBFC | OERC(ALT_SET_FLAGS) | D(dst) | A(src2) | B(src1));
152 return push_inst(compiler, SUBFE | D(dst) | A(src2) | B(src1));
157 return push_inst(compiler, MULLI | D(dst) | A(src1) | compiler->imm);
159 return push_inst(compiler, MULLW | OERC(flags) | D(dst) | A(src2) | B(src1));
164 return push_inst(compiler, ANDI | S(src1) | A(dst) | compiler->imm);
168 return push_inst(compiler, ANDIS | S(src1) | A(dst) | compiler->imm);
170 return push_inst(compiler, AND | RC(flags) | S(src1) | A(dst) | B(src2));
175 return push_inst(compiler, ORI | S(src1) | A(dst) | compiler->imm);
179 return push_inst(compiler, ORIS | S(src1) | A(dst) | compiler->imm);
183 FAIL_IF(push_inst(compiler, ORI | S(src1) | A(dst) | IMM(compiler->imm)));
184 return push_inst(compiler, ORIS | S(dst) | A(dst) | IMM(compiler->imm >> 16));
186 return push_inst(compiler, OR | RC(flags) | S(src1) | A(dst) | B(src2));
191 return push_inst(compiler, XORI | S(src1) | A(dst) | compiler->imm);
195 return push_inst(compiler, XORIS | S(src1) | A(dst) | compiler->imm);
199 FAIL_IF(push_inst(compiler, XORI | S(src1) | A(dst) | IMM(compiler->imm)));
200 return push_inst(compiler, XORIS | S(dst) | A(dst) | IMM(compiler->imm >> 16));
202 return push_inst(compiler, XOR | RC(flags) | S(src1) | A(dst) | B(src2));
207 compiler->imm &= 0x1f;
208 return push_inst(compiler, RLWINM | RC(flags) | S(src1) | A(dst) | (compiler->imm << 11) | ((31 - compiler->imm) << 1));
210 return push_inst(compiler, SLW | RC(flags) | S(src1) | A(dst) | B(src2));
215 compiler->imm &= 0x1f;
216 return push_inst(compiler, RLWINM | RC(flags) | S(src1) | A(dst) | (((32 - compiler->imm) & 0x1f) << 11) | (compiler->imm << 6) | (31 << 1));
218 return push_inst(compiler, SRW | RC(flags) | S(src1) | A(dst) | B(src2));
223 compiler->imm &= 0x1f;
224 return push_inst(compiler, SRAWI | RC(flags) | S(src1) | A(dst) | (compiler->imm << 11));
226 return push_inst(compiler, SRAW | RC(flags) | S(src1) | A(dst) | B(src2));
233 static SLJIT_INLINE sljit_s32 emit_const(struct sljit_compiler *compiler, sljit_s32 reg, sljit_sw init_value)
235 FAIL_IF(push_inst(compiler, ADDIS | D(reg) | A(0) | IMM(init_value >> 16)));
236 return push_inst(compiler, ORI | S(reg) | A(reg) | IMM(init_value));