Lines Matching refs:imm
46 static sljit_s32 load_immediate(struct sljit_compiler *compiler, sljit_s32 reg, sljit_sw imm)
53 if (imm <= SIMM_MAX && imm >= SIMM_MIN)
54 return push_inst(compiler, ADDI | D(reg) | A(0) | IMM(imm));
56 if (!(imm & ~0xffff))
57 return push_inst(compiler, ORI | S(TMP_ZERO) | A(reg) | IMM(imm));
59 if (imm <= 0x7fffffffl && imm >= -0x80000000l) {
60 FAIL_IF(push_inst(compiler, ADDIS | D(reg) | A(0) | IMM(imm >> 16)));
61 return (imm & 0xffff) ? push_inst(compiler, ORI | S(reg) | A(reg) | IMM(imm)) : SLJIT_SUCCESS;
65 tmp = (imm >= 0) ? imm : ~imm;
69 tmp = (imm << shift);
72 FAIL_IF(push_inst(compiler, ADDI | D(reg) | A(0) | IMM(tmp >> 48)));
78 FAIL_IF(push_inst(compiler, ADDIS | D(reg) | A(0) | IMM(tmp >> 48)));
79 FAIL_IF(push_inst(compiler, ORI | S(reg) | A(reg) | IMM(tmp >> 32)));
86 tmp2 = imm & ((1ul << (63 - shift)) - 1);
89 FAIL_IF(push_inst(compiler, ADDI | D(reg) | A(0) | IMM(tmp >> 48)));
95 FAIL_IF(push_inst(compiler, ADDI | D(reg) | A(0) | IMM(tmp >> 48)));
98 return (imm & 0xffff) ? push_inst(compiler, ORI | S(reg) | A(reg) | IMM(tmp2)) : SLJIT_SUCCESS;
105 FAIL_IF(push_inst(compiler, ADDI | D(reg) | A(0) | IMM(tmp >> 48)));
114 FAIL_IF(push_inst(compiler, ADDIS | D(reg) | A(0) | IMM(imm >> 48)));
115 FAIL_IF(push_inst(compiler, ORI | S(reg) | A(reg) | IMM(imm >> 32)));
117 FAIL_IF(push_inst(compiler, ORIS | S(reg) | A(reg) | IMM(imm >> 16)));
118 return push_inst(compiler, ORI | S(reg) | A(reg) | IMM(imm));
222 return push_inst(compiler, ADDI | D(dst) | A(src1) | compiler->imm);
227 return push_inst(compiler, ADDIS | D(dst) | A(src1) | compiler->imm);
232 return push_inst(compiler, ADDIC | D(dst) | A(src1) | compiler->imm);
236 FAIL_IF(push_inst(compiler, ADDI | D(dst) | A(src1) | (compiler->imm & 0xffff)));
237 return push_inst(compiler, ADDIS | D(dst) | A(dst) | (((compiler->imm >> 16) & 0xffff) + ((compiler->imm >> 15) & 0x1)));
252 return push_inst(compiler, SUBFIC | D(dst) | A(src1) | compiler->imm);
256 return push_inst(compiler, ((flags & ALT_FORM2) ? CMPI : CMPLI) | CRD(0 | ((flags & ALT_SIGN_EXT) ? 0 : 1)) | A(src1) | compiler->imm);
263 FAIL_IF(push_inst(compiler, CMPLI | CRD(0 | ((flags & ALT_SIGN_EXT) ? 0 : 1)) | A(src1) | compiler->imm));
264 return push_inst(compiler, ADDI | D(dst) | A(src1) | (-compiler->imm & 0xffff));
282 return push_inst(compiler, MULLI | D(dst) | A(src1) | compiler->imm);
292 return push_inst(compiler, ANDI | S(src1) | A(dst) | compiler->imm);
296 return push_inst(compiler, ANDIS | S(src1) | A(dst) | compiler->imm);
303 return push_inst(compiler, ORI | S(src1) | A(dst) | compiler->imm);
307 return push_inst(compiler, ORIS | S(src1) | A(dst) | compiler->imm);
311 FAIL_IF(push_inst(compiler, ORI | S(src1) | A(dst) | IMM(compiler->imm)));
312 return push_inst(compiler, ORIS | S(dst) | A(dst) | IMM(compiler->imm >> 16));
319 return push_inst(compiler, XORI | S(src1) | A(dst) | compiler->imm);
323 return push_inst(compiler, XORIS | S(src1) | A(dst) | compiler->imm);
327 FAIL_IF(push_inst(compiler, XORI | S(src1) | A(dst) | IMM(compiler->imm)));
328 return push_inst(compiler, XORIS | S(dst) | A(dst) | IMM(compiler->imm >> 16));
336 compiler->imm &= 0x1f;
337 return push_inst(compiler, RLWINM | RC(flags) | S(src1) | A(dst) | (compiler->imm << 11) | ((31 - compiler->imm) << 1));
339 compiler->imm &= 0x3f;
340 return push_inst(compiler, RLDI(dst, src1, compiler->imm, 63 - compiler->imm, 1) | RC(flags));
348 compiler->imm &= 0x1f;
349 return push_inst(compiler, RLWINM | RC(flags) | S(src1) | A(dst) | (((32 - compiler->imm) & 0x1f) << 11) | (compiler->imm << 6) | (31 << 1));
351 compiler->imm &= 0x3f;
352 return push_inst(compiler, RLDI(dst, src1, 64 - compiler->imm, compiler->imm, 0) | RC(flags));
360 compiler->imm &= 0x1f;
361 return push_inst(compiler, SRAWI | RC(flags) | S(src1) | A(dst) | (compiler->imm << 11));
363 compiler->imm &= 0x3f;
364 return push_inst(compiler, SRADI | RC(flags) | S(src1) | A(dst) | ((compiler->imm & 0x1f) << 11) | ((compiler->imm & 0x20) >> 4));
375 FAIL_IF(push_inst(compiler, ADDIS | D(reg) | A(0) | IMM(init_value >> 48)));
376 FAIL_IF(push_inst(compiler, ORI | S(reg) | A(reg) | IMM(init_value >> 32)));
378 FAIL_IF(push_inst(compiler, ORIS | S(reg) | A(reg) | IMM(init_value >> 16)));
379 return push_inst(compiler, ORI | S(reg) | A(reg) | IMM(init_value));