• Home
  • History
  • Annotate
  • Raw
  • Download
  • only in /asuswrt-rt-n18u-9.0.0.4.380.2695/release/src-rt-6.x.4708/router/pcre-8.31/sljit/

Lines Matching refs:compiler

2  *    Stack-less Just-In-Time compiler
29 static int load_immediate(struct sljit_compiler *compiler, int reg, sljit_w imm)
32 return push_inst(compiler, ADDI | D(reg) | A(0) | IMM(imm));
35 return push_inst(compiler, ORI | S(ZERO_REG) | A(reg) | IMM(imm));
37 FAIL_IF(push_inst(compiler, ADDIS | D(reg) | A(0) | IMM(imm >> 16)));
38 return (imm & 0xffff) ? push_inst(compiler, ORI | S(reg) | A(reg) | IMM(imm)) : SLJIT_SUCCESS;
44 static SLJIT_INLINE int emit_single_op(struct sljit_compiler *compiler, int op, int flags,
52 return push_inst(compiler, ADDI | D(dst) | A(src1) | compiler->imm);
57 return push_inst(compiler, ADDIS | D(dst) | A(src1) | compiler->imm);
61 return push_inst(compiler, ADDIC | D(dst) | A(src1) | compiler->imm);
65 FAIL_IF(push_inst(compiler, ADDI | D(dst) | A(src1) | (compiler->imm & 0xffff)));
66 return push_inst(compiler, ADDIS | D(dst) | A(dst) | (((compiler->imm >> 16) & 0xffff) + ((compiler->imm >> 15) & 0x1)));
69 return push_inst(compiler, ADD | D(dst) | A(src1) | B(src2));
70 return push_inst(compiler, ADDC | OERC(ALT_SET_FLAGS) | D(dst) | A(src1) | B(src2));
74 FAIL_IF(push_inst(compiler, MFXER | S(0)));
75 FAIL_IF(push_inst(compiler, ADDE | D(dst) | A(src1) | B(src2)));
76 return push_inst(compiler, MTXER | S(0));
78 return push_inst(compiler, ADDE | D(dst) | A(src1) | B(src2));
84 return push_inst(compiler, SUBFIC | D(dst) | A(src1) | compiler->imm);
89 FAIL_IF(push_inst(compiler, CMPI | CRD(0) | A(src1) | compiler->imm));
91 return push_inst(compiler, CMPLI | CRD(4) | A(src1) | compiler->imm);
96 FAIL_IF(push_inst(compiler, CMPL | CRD(4) | A(src1) | B(src2)));
98 FAIL_IF(push_inst(compiler, CMP | CRD(0) | A(src1) | B(src2)));
102 return push_inst(compiler, SUBF | D(dst) | A(src2) | B(src1));
104 FAIL_IF(push_inst(compiler, CMPL | CRD(4) | A(src1) | B(src2)));
105 return push_inst(compiler, SUBFC | OERC(ALT_SET_FLAGS) | D(dst) | A(src2) | B(src1));
109 FAIL_IF(push_inst(compiler, MFXER | S(0)));
110 FAIL_IF(push_inst(compiler, SUBFE | D(dst) | A(src2) | B(src1)));
111 return push_inst(compiler, MTXER | S(0));
113 return push_inst(compiler, SUBFE | D(dst) | A(src2) | B(src1));
118 return push_inst(compiler, MULLI | D(dst) | A(src1) | compiler->imm);
120 return push_inst(compiler, MULLW | OERC(flags) | D(dst) | A(src2) | B(src1));
125 return push_inst(compiler, ANDI | S(src1) | A(dst) | compiler->imm);
129 return push_inst(compiler, ANDIS | S(src1) | A(dst) | compiler->imm);
131 return push_inst(compiler, AND | RC(flags) | S(src1) | A(dst) | B(src2));
136 return push_inst(compiler, ORI | S(src1) | A(dst) | compiler->imm);
140 return push_inst(compiler, ORIS | S(src1) | A(dst) | compiler->imm);
144 FAIL_IF(push_inst(compiler, ORI | S(src1) | A(dst) | IMM(compiler->imm)));
145 return push_inst(compiler, ORIS | S(dst) | A(dst) | IMM(compiler->imm >> 16));
147 return push_inst(compiler, OR | RC(flags) | S(src1) | A(dst) | B(src2));
152 return push_inst(compiler, XORI | S(src1) | A(dst) | compiler->imm);
156 return push_inst(compiler, XORIS | S(src1) | A(dst) | compiler->imm);
160 FAIL_IF(push_inst(compiler, XORI | S(src1) | A(dst) | IMM(compiler->imm)));
161 return push_inst(compiler, XORIS | S(dst) | A(dst) | IMM(compiler->imm >> 16));
163 return push_inst(compiler, XOR | RC(flags) | S(src1) | A(dst) | B(src2));
168 compiler->imm &= 0x1f;
169 return push_inst(compiler, RLWINM | RC(flags) | S(src1) | A(dst) | (compiler->imm << 11) | ((31 - compiler->imm) << 1));
171 return push_inst(compiler, SLW | RC(flags) | S(src1) | A(dst) | B(src2));
176 compiler->imm &= 0x1f;
177 return push_inst(compiler, RLWINM | RC(flags) | S(src1) | A(dst) | (((32 - compiler->imm) & 0x1f) << 11) | (compiler->imm << 6) | (31 << 1));
179 return push_inst(compiler, SRW | RC(flags) | S(src1) | A(dst) | B(src2));
184 compiler->imm &= 0x1f;
185 return push_inst(compiler, SRAWI | RC(flags) | S(src1) | A(dst) | (compiler->imm << 11));
187 return push_inst(compiler, SRAW | RC(flags) | S(src1) | A(dst) | B(src2));
194 return push_inst(compiler, OR | S(src2) | A(dst) | B(src2));
202 return push_inst(compiler, EXTSB | S(src2) | A(dst));
203 return push_inst(compiler, INS_CLEAR_LEFT(dst, src2, 24));
206 return push_inst(compiler, EXTSB | S(src2) | A(dst));
216 return push_inst(compiler, EXTSH | S(src2) | A(dst));
217 return push_inst(compiler, INS_CLEAR_LEFT(dst, src2, 16));
225 return push_inst(compiler, NOR | RC(flags) | S(src2) | A(dst) | B(src2));
229 return push_inst(compiler, NEG | OERC(flags) | D(dst) | A(src2));
233 return push_inst(compiler, CNTLZW | RC(flags) | S(src2) | A(dst));
240 static SLJIT_INLINE int emit_const(struct sljit_compiler *compiler, int reg, sljit_w init_value)
242 FAIL_IF(push_inst(compiler, ADDIS | D(reg) | A(0) | IMM(init_value >> 16)));
243 return push_inst(compiler, ORI | S(reg) | A(reg) | IMM(init_value));