tcg: Use tcg_constant_{i32,i64} with tcg int expanders

Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
Richard Henderson 2020-03-29 20:07:08 -07:00
parent 0e1ea43a9d
commit 11d11d61bd
2 changed files with 109 additions and 131 deletions

View File

@ -271,6 +271,7 @@ void tcg_gen_mb(TCGBar);
/* 32 bit ops */ /* 32 bit ops */
void tcg_gen_movi_i32(TCGv_i32 ret, int32_t arg);
void tcg_gen_addi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2); void tcg_gen_addi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2);
void tcg_gen_subfi_i32(TCGv_i32 ret, int32_t arg1, TCGv_i32 arg2); void tcg_gen_subfi_i32(TCGv_i32 ret, int32_t arg1, TCGv_i32 arg2);
void tcg_gen_subi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2); void tcg_gen_subi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2);
@ -349,11 +350,6 @@ static inline void tcg_gen_mov_i32(TCGv_i32 ret, TCGv_i32 arg)
} }
} }
static inline void tcg_gen_movi_i32(TCGv_i32 ret, int32_t arg)
{
tcg_gen_op2i_i32(INDEX_op_movi_i32, ret, arg);
}
static inline void tcg_gen_ld8u_i32(TCGv_i32 ret, TCGv_ptr arg2, static inline void tcg_gen_ld8u_i32(TCGv_i32 ret, TCGv_ptr arg2,
tcg_target_long offset) tcg_target_long offset)
{ {
@ -467,6 +463,7 @@ static inline void tcg_gen_not_i32(TCGv_i32 ret, TCGv_i32 arg)
/* 64 bit ops */ /* 64 bit ops */
void tcg_gen_movi_i64(TCGv_i64 ret, int64_t arg);
void tcg_gen_addi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2); void tcg_gen_addi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2);
void tcg_gen_subfi_i64(TCGv_i64 ret, int64_t arg1, TCGv_i64 arg2); void tcg_gen_subfi_i64(TCGv_i64 ret, int64_t arg1, TCGv_i64 arg2);
void tcg_gen_subi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2); void tcg_gen_subi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2);
@ -550,11 +547,6 @@ static inline void tcg_gen_mov_i64(TCGv_i64 ret, TCGv_i64 arg)
} }
} }
static inline void tcg_gen_movi_i64(TCGv_i64 ret, int64_t arg)
{
tcg_gen_op2i_i64(INDEX_op_movi_i64, ret, arg);
}
static inline void tcg_gen_ld8u_i64(TCGv_i64 ret, TCGv_ptr arg2, static inline void tcg_gen_ld8u_i64(TCGv_i64 ret, TCGv_ptr arg2,
tcg_target_long offset) tcg_target_long offset)
{ {
@ -698,7 +690,6 @@ static inline void tcg_gen_sub_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2)
void tcg_gen_discard_i64(TCGv_i64 arg); void tcg_gen_discard_i64(TCGv_i64 arg);
void tcg_gen_mov_i64(TCGv_i64 ret, TCGv_i64 arg); void tcg_gen_mov_i64(TCGv_i64 ret, TCGv_i64 arg);
void tcg_gen_movi_i64(TCGv_i64 ret, int64_t arg);
void tcg_gen_ld8u_i64(TCGv_i64 ret, TCGv_ptr arg2, tcg_target_long offset); void tcg_gen_ld8u_i64(TCGv_i64 ret, TCGv_ptr arg2, tcg_target_long offset);
void tcg_gen_ld8s_i64(TCGv_i64 ret, TCGv_ptr arg2, tcg_target_long offset); void tcg_gen_ld8s_i64(TCGv_i64 ret, TCGv_ptr arg2, tcg_target_long offset);
void tcg_gen_ld16u_i64(TCGv_i64 ret, TCGv_ptr arg2, tcg_target_long offset); void tcg_gen_ld16u_i64(TCGv_i64 ret, TCGv_ptr arg2, tcg_target_long offset);

View File

@ -104,15 +104,18 @@ void tcg_gen_mb(TCGBar mb_type)
/* 32 bit ops */ /* 32 bit ops */
void tcg_gen_movi_i32(TCGv_i32 ret, int32_t arg)
{
tcg_gen_mov_i32(ret, tcg_constant_i32(arg));
}
void tcg_gen_addi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) void tcg_gen_addi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
{ {
/* some cases can be optimized here */ /* some cases can be optimized here */
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i32(ret, arg1); tcg_gen_mov_i32(ret, arg1);
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_add_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_add_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
} }
@ -122,9 +125,7 @@ void tcg_gen_subfi_i32(TCGv_i32 ret, int32_t arg1, TCGv_i32 arg2)
/* Don't recurse with tcg_gen_neg_i32. */ /* Don't recurse with tcg_gen_neg_i32. */
tcg_gen_op2_i32(INDEX_op_neg_i32, ret, arg2); tcg_gen_op2_i32(INDEX_op_neg_i32, ret, arg2);
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg1); tcg_gen_sub_i32(ret, tcg_constant_i32(arg1), arg2);
tcg_gen_sub_i32(ret, t0, arg2);
tcg_temp_free_i32(t0);
} }
} }
@ -134,15 +135,12 @@ void tcg_gen_subi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i32(ret, arg1); tcg_gen_mov_i32(ret, arg1);
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_sub_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_sub_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
} }
void tcg_gen_andi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) void tcg_gen_andi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
{ {
TCGv_i32 t0;
/* Some cases can be optimized here. */ /* Some cases can be optimized here. */
switch (arg2) { switch (arg2) {
case 0: case 0:
@ -165,9 +163,8 @@ void tcg_gen_andi_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
} }
break; break;
} }
t0 = tcg_const_i32(arg2);
tcg_gen_and_i32(ret, arg1, t0); tcg_gen_and_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_temp_free_i32(t0);
} }
void tcg_gen_ori_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) void tcg_gen_ori_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
@ -178,9 +175,7 @@ void tcg_gen_ori_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
} else if (arg2 == 0) { } else if (arg2 == 0) {
tcg_gen_mov_i32(ret, arg1); tcg_gen_mov_i32(ret, arg1);
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_or_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_or_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
} }
@ -193,9 +188,7 @@ void tcg_gen_xori_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
/* Don't recurse with tcg_gen_not_i32. */ /* Don't recurse with tcg_gen_not_i32. */
tcg_gen_op2_i32(INDEX_op_not_i32, ret, arg1); tcg_gen_op2_i32(INDEX_op_not_i32, ret, arg1);
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_xor_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_xor_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
} }
@ -205,9 +198,7 @@ void tcg_gen_shli_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i32(ret, arg1); tcg_gen_mov_i32(ret, arg1);
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_shl_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_shl_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
} }
@ -217,9 +208,7 @@ void tcg_gen_shri_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i32(ret, arg1); tcg_gen_mov_i32(ret, arg1);
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_shr_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_shr_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
} }
@ -229,9 +218,7 @@ void tcg_gen_sari_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i32(ret, arg1); tcg_gen_mov_i32(ret, arg1);
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_sar_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_sar_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
} }
@ -250,9 +237,7 @@ void tcg_gen_brcondi_i32(TCGCond cond, TCGv_i32 arg1, int32_t arg2, TCGLabel *l)
if (cond == TCG_COND_ALWAYS) { if (cond == TCG_COND_ALWAYS) {
tcg_gen_br(l); tcg_gen_br(l);
} else if (cond != TCG_COND_NEVER) { } else if (cond != TCG_COND_NEVER) {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_brcond_i32(cond, arg1, tcg_constant_i32(arg2), l);
tcg_gen_brcond_i32(cond, arg1, t0, l);
tcg_temp_free_i32(t0);
} }
} }
@ -271,9 +256,7 @@ void tcg_gen_setcond_i32(TCGCond cond, TCGv_i32 ret,
void tcg_gen_setcondi_i32(TCGCond cond, TCGv_i32 ret, void tcg_gen_setcondi_i32(TCGCond cond, TCGv_i32 ret,
TCGv_i32 arg1, int32_t arg2) TCGv_i32 arg1, int32_t arg2)
{ {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_setcond_i32(cond, ret, arg1, tcg_constant_i32(arg2));
tcg_gen_setcond_i32(cond, ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
void tcg_gen_muli_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2) void tcg_gen_muli_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
@ -283,9 +266,7 @@ void tcg_gen_muli_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
} else if (is_power_of_2(arg2)) { } else if (is_power_of_2(arg2)) {
tcg_gen_shli_i32(ret, arg1, ctz32(arg2)); tcg_gen_shli_i32(ret, arg1, ctz32(arg2));
} else { } else {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_mul_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_mul_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} }
} }
@ -433,9 +414,7 @@ void tcg_gen_clz_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2)
void tcg_gen_clzi_i32(TCGv_i32 ret, TCGv_i32 arg1, uint32_t arg2) void tcg_gen_clzi_i32(TCGv_i32 ret, TCGv_i32 arg1, uint32_t arg2)
{ {
TCGv_i32 t = tcg_const_i32(arg2); tcg_gen_clz_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_clz_i32(ret, arg1, t);
tcg_temp_free_i32(t);
} }
void tcg_gen_ctz_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2) void tcg_gen_ctz_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2)
@ -468,10 +447,9 @@ void tcg_gen_ctz_i32(TCGv_i32 ret, TCGv_i32 arg1, TCGv_i32 arg2)
tcg_gen_clzi_i32(t, t, 32); tcg_gen_clzi_i32(t, t, 32);
tcg_gen_xori_i32(t, t, 31); tcg_gen_xori_i32(t, t, 31);
} }
z = tcg_const_i32(0); z = tcg_constant_i32(0);
tcg_gen_movcond_i32(TCG_COND_EQ, ret, arg1, z, arg2, t); tcg_gen_movcond_i32(TCG_COND_EQ, ret, arg1, z, arg2, t);
tcg_temp_free_i32(t); tcg_temp_free_i32(t);
tcg_temp_free_i32(z);
} else { } else {
gen_helper_ctz_i32(ret, arg1, arg2); gen_helper_ctz_i32(ret, arg1, arg2);
} }
@ -487,9 +465,7 @@ void tcg_gen_ctzi_i32(TCGv_i32 ret, TCGv_i32 arg1, uint32_t arg2)
tcg_gen_ctpop_i32(ret, t); tcg_gen_ctpop_i32(ret, t);
tcg_temp_free_i32(t); tcg_temp_free_i32(t);
} else { } else {
TCGv_i32 t = tcg_const_i32(arg2); tcg_gen_ctz_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_ctz_i32(ret, arg1, t);
tcg_temp_free_i32(t);
} }
} }
@ -547,9 +523,7 @@ void tcg_gen_rotli_i32(TCGv_i32 ret, TCGv_i32 arg1, int32_t arg2)
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i32(ret, arg1); tcg_gen_mov_i32(ret, arg1);
} else if (TCG_TARGET_HAS_rot_i32) { } else if (TCG_TARGET_HAS_rot_i32) {
TCGv_i32 t0 = tcg_const_i32(arg2); tcg_gen_rotl_i32(ret, arg1, tcg_constant_i32(arg2));
tcg_gen_rotl_i32(ret, arg1, t0);
tcg_temp_free_i32(t0);
} else { } else {
TCGv_i32 t0, t1; TCGv_i32 t0, t1;
t0 = tcg_temp_new_i32(); t0 = tcg_temp_new_i32();
@ -653,9 +627,8 @@ void tcg_gen_deposit_z_i32(TCGv_i32 ret, TCGv_i32 arg,
tcg_gen_andi_i32(ret, arg, (1u << len) - 1); tcg_gen_andi_i32(ret, arg, (1u << len) - 1);
} else if (TCG_TARGET_HAS_deposit_i32 } else if (TCG_TARGET_HAS_deposit_i32
&& TCG_TARGET_deposit_i32_valid(ofs, len)) { && TCG_TARGET_deposit_i32_valid(ofs, len)) {
TCGv_i32 zero = tcg_const_i32(0); TCGv_i32 zero = tcg_constant_i32(0);
tcg_gen_op5ii_i32(INDEX_op_deposit_i32, ret, zero, arg, ofs, len); tcg_gen_op5ii_i32(INDEX_op_deposit_i32, ret, zero, arg, ofs, len);
tcg_temp_free_i32(zero);
} else { } else {
/* To help two-operand hosts we prefer to zero-extend first, /* To help two-operand hosts we prefer to zero-extend first,
which allows ARG to stay live. */ which allows ARG to stay live. */
@ -1052,7 +1025,7 @@ void tcg_gen_bswap32_i32(TCGv_i32 ret, TCGv_i32 arg)
} else { } else {
TCGv_i32 t0 = tcg_temp_new_i32(); TCGv_i32 t0 = tcg_temp_new_i32();
TCGv_i32 t1 = tcg_temp_new_i32(); TCGv_i32 t1 = tcg_temp_new_i32();
TCGv_i32 t2 = tcg_const_i32(0x00ff00ff); TCGv_i32 t2 = tcg_constant_i32(0x00ff00ff);
/* arg = abcd */ /* arg = abcd */
tcg_gen_shri_i32(t0, arg, 8); /* t0 = .abc */ tcg_gen_shri_i32(t0, arg, 8); /* t0 = .abc */
@ -1067,7 +1040,6 @@ void tcg_gen_bswap32_i32(TCGv_i32 ret, TCGv_i32 arg)
tcg_temp_free_i32(t0); tcg_temp_free_i32(t0);
tcg_temp_free_i32(t1); tcg_temp_free_i32(t1);
tcg_temp_free_i32(t2);
} }
} }
@ -1114,8 +1086,15 @@ void tcg_gen_discard_i64(TCGv_i64 arg)
void tcg_gen_mov_i64(TCGv_i64 ret, TCGv_i64 arg) void tcg_gen_mov_i64(TCGv_i64 ret, TCGv_i64 arg)
{ {
TCGTemp *ts = tcgv_i64_temp(arg);
/* Canonicalize TCGv_i64 TEMP_CONST into TCGv_i32 TEMP_CONST. */
if (ts->kind == TEMP_CONST) {
tcg_gen_movi_i64(ret, ts->val);
} else {
tcg_gen_mov_i32(TCGV_LOW(ret), TCGV_LOW(arg)); tcg_gen_mov_i32(TCGV_LOW(ret), TCGV_LOW(arg));
tcg_gen_mov_i32(TCGV_HIGH(ret), TCGV_HIGH(arg)); tcg_gen_mov_i32(TCGV_HIGH(ret), TCGV_HIGH(arg));
}
} }
void tcg_gen_movi_i64(TCGv_i64 ret, int64_t arg) void tcg_gen_movi_i64(TCGv_i64 ret, int64_t arg)
@ -1237,6 +1216,14 @@ void tcg_gen_mul_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2)
tcg_temp_free_i64(t0); tcg_temp_free_i64(t0);
tcg_temp_free_i32(t1); tcg_temp_free_i32(t1);
} }
#else
void tcg_gen_movi_i64(TCGv_i64 ret, int64_t arg)
{
tcg_gen_mov_i64(ret, tcg_constant_i64(arg));
}
#endif /* TCG_TARGET_REG_SIZE == 32 */ #endif /* TCG_TARGET_REG_SIZE == 32 */
void tcg_gen_addi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) void tcg_gen_addi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
@ -1244,10 +1231,12 @@ void tcg_gen_addi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
/* some cases can be optimized here */ /* some cases can be optimized here */
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i64(ret, arg1); tcg_gen_mov_i64(ret, arg1);
} else if (TCG_TARGET_REG_BITS == 64) {
tcg_gen_add_i64(ret, arg1, tcg_constant_i64(arg2));
} else { } else {
TCGv_i64 t0 = tcg_const_i64(arg2); tcg_gen_add2_i32(TCGV_LOW(ret), TCGV_HIGH(ret),
tcg_gen_add_i64(ret, arg1, t0); TCGV_LOW(arg1), TCGV_HIGH(arg1),
tcg_temp_free_i64(t0); tcg_constant_i32(arg2), tcg_constant_i32(arg2 >> 32));
} }
} }
@ -1256,10 +1245,12 @@ void tcg_gen_subfi_i64(TCGv_i64 ret, int64_t arg1, TCGv_i64 arg2)
if (arg1 == 0 && TCG_TARGET_HAS_neg_i64) { if (arg1 == 0 && TCG_TARGET_HAS_neg_i64) {
/* Don't recurse with tcg_gen_neg_i64. */ /* Don't recurse with tcg_gen_neg_i64. */
tcg_gen_op2_i64(INDEX_op_neg_i64, ret, arg2); tcg_gen_op2_i64(INDEX_op_neg_i64, ret, arg2);
} else if (TCG_TARGET_REG_BITS == 64) {
tcg_gen_sub_i64(ret, tcg_constant_i64(arg1), arg2);
} else { } else {
TCGv_i64 t0 = tcg_const_i64(arg1); tcg_gen_sub2_i32(TCGV_LOW(ret), TCGV_HIGH(ret),
tcg_gen_sub_i64(ret, t0, arg2); tcg_constant_i32(arg1), tcg_constant_i32(arg1 >> 32),
tcg_temp_free_i64(t0); TCGV_LOW(arg2), TCGV_HIGH(arg2));
} }
} }
@ -1268,17 +1259,17 @@ void tcg_gen_subi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
/* some cases can be optimized here */ /* some cases can be optimized here */
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i64(ret, arg1); tcg_gen_mov_i64(ret, arg1);
} else if (TCG_TARGET_REG_BITS == 64) {
tcg_gen_sub_i64(ret, arg1, tcg_constant_i64(arg2));
} else { } else {
TCGv_i64 t0 = tcg_const_i64(arg2); tcg_gen_sub2_i32(TCGV_LOW(ret), TCGV_HIGH(ret),
tcg_gen_sub_i64(ret, arg1, t0); TCGV_LOW(arg1), TCGV_HIGH(arg1),
tcg_temp_free_i64(t0); tcg_constant_i32(arg2), tcg_constant_i32(arg2 >> 32));
} }
} }
void tcg_gen_andi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) void tcg_gen_andi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
{ {
TCGv_i64 t0;
if (TCG_TARGET_REG_BITS == 32) { if (TCG_TARGET_REG_BITS == 32) {
tcg_gen_andi_i32(TCGV_LOW(ret), TCGV_LOW(arg1), arg2); tcg_gen_andi_i32(TCGV_LOW(ret), TCGV_LOW(arg1), arg2);
tcg_gen_andi_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), arg2 >> 32); tcg_gen_andi_i32(TCGV_HIGH(ret), TCGV_HIGH(arg1), arg2 >> 32);
@ -1313,9 +1304,8 @@ void tcg_gen_andi_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
} }
break; break;
} }
t0 = tcg_const_i64(arg2);
tcg_gen_and_i64(ret, arg1, t0); tcg_gen_and_i64(ret, arg1, tcg_constant_i64(arg2));
tcg_temp_free_i64(t0);
} }
void tcg_gen_ori_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) void tcg_gen_ori_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
@ -1331,9 +1321,7 @@ void tcg_gen_ori_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
} else if (arg2 == 0) { } else if (arg2 == 0) {
tcg_gen_mov_i64(ret, arg1); tcg_gen_mov_i64(ret, arg1);
} else { } else {
TCGv_i64 t0 = tcg_const_i64(arg2); tcg_gen_or_i64(ret, arg1, tcg_constant_i64(arg2));
tcg_gen_or_i64(ret, arg1, t0);
tcg_temp_free_i64(t0);
} }
} }
@ -1351,9 +1339,7 @@ void tcg_gen_xori_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
/* Don't recurse with tcg_gen_not_i64. */ /* Don't recurse with tcg_gen_not_i64. */
tcg_gen_op2_i64(INDEX_op_not_i64, ret, arg1); tcg_gen_op2_i64(INDEX_op_not_i64, ret, arg1);
} else { } else {
TCGv_i64 t0 = tcg_const_i64(arg2); tcg_gen_xor_i64(ret, arg1, tcg_constant_i64(arg2));
tcg_gen_xor_i64(ret, arg1, t0);
tcg_temp_free_i64(t0);
} }
} }
@ -1415,9 +1401,7 @@ void tcg_gen_shli_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
} else if (arg2 == 0) { } else if (arg2 == 0) {
tcg_gen_mov_i64(ret, arg1); tcg_gen_mov_i64(ret, arg1);
} else { } else {
TCGv_i64 t0 = tcg_const_i64(arg2); tcg_gen_shl_i64(ret, arg1, tcg_constant_i64(arg2));
tcg_gen_shl_i64(ret, arg1, t0);
tcg_temp_free_i64(t0);
} }
} }
@ -1429,9 +1413,7 @@ void tcg_gen_shri_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
} else if (arg2 == 0) { } else if (arg2 == 0) {
tcg_gen_mov_i64(ret, arg1); tcg_gen_mov_i64(ret, arg1);
} else { } else {
TCGv_i64 t0 = tcg_const_i64(arg2); tcg_gen_shr_i64(ret, arg1, tcg_constant_i64(arg2));
tcg_gen_shr_i64(ret, arg1, t0);
tcg_temp_free_i64(t0);
} }
} }
@ -1443,9 +1425,7 @@ void tcg_gen_sari_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
} else if (arg2 == 0) { } else if (arg2 == 0) {
tcg_gen_mov_i64(ret, arg1); tcg_gen_mov_i64(ret, arg1);
} else { } else {
TCGv_i64 t0 = tcg_const_i64(arg2); tcg_gen_sar_i64(ret, arg1, tcg_constant_i64(arg2));
tcg_gen_sar_i64(ret, arg1, t0);
tcg_temp_free_i64(t0);
} }
} }
@ -1468,12 +1448,17 @@ void tcg_gen_brcond_i64(TCGCond cond, TCGv_i64 arg1, TCGv_i64 arg2, TCGLabel *l)
void tcg_gen_brcondi_i64(TCGCond cond, TCGv_i64 arg1, int64_t arg2, TCGLabel *l) void tcg_gen_brcondi_i64(TCGCond cond, TCGv_i64 arg1, int64_t arg2, TCGLabel *l)
{ {
if (cond == TCG_COND_ALWAYS) { if (TCG_TARGET_REG_BITS == 64) {
tcg_gen_brcond_i64(cond, arg1, tcg_constant_i64(arg2), l);
} else if (cond == TCG_COND_ALWAYS) {
tcg_gen_br(l); tcg_gen_br(l);
} else if (cond != TCG_COND_NEVER) { } else if (cond != TCG_COND_NEVER) {
TCGv_i64 t0 = tcg_const_i64(arg2); l->refs++;
tcg_gen_brcond_i64(cond, arg1, t0, l); tcg_gen_op6ii_i32(INDEX_op_brcond2_i32,
tcg_temp_free_i64(t0); TCGV_LOW(arg1), TCGV_HIGH(arg1),
tcg_constant_i32(arg2),
tcg_constant_i32(arg2 >> 32),
cond, label_arg(l));
} }
} }
@ -1499,9 +1484,19 @@ void tcg_gen_setcond_i64(TCGCond cond, TCGv_i64 ret,
void tcg_gen_setcondi_i64(TCGCond cond, TCGv_i64 ret, void tcg_gen_setcondi_i64(TCGCond cond, TCGv_i64 ret,
TCGv_i64 arg1, int64_t arg2) TCGv_i64 arg1, int64_t arg2)
{ {
TCGv_i64 t0 = tcg_const_i64(arg2); if (TCG_TARGET_REG_BITS == 64) {
tcg_gen_setcond_i64(cond, ret, arg1, t0); tcg_gen_setcond_i64(cond, ret, arg1, tcg_constant_i64(arg2));
tcg_temp_free_i64(t0); } else if (cond == TCG_COND_ALWAYS) {
tcg_gen_movi_i64(ret, 1);
} else if (cond == TCG_COND_NEVER) {
tcg_gen_movi_i64(ret, 0);
} else {
tcg_gen_op6i_i32(INDEX_op_setcond2_i32, TCGV_LOW(ret),
TCGV_LOW(arg1), TCGV_HIGH(arg1),
tcg_constant_i32(arg2),
tcg_constant_i32(arg2 >> 32), cond);
tcg_gen_movi_i32(TCGV_HIGH(ret), 0);
}
} }
void tcg_gen_muli_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2) void tcg_gen_muli_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
@ -1690,7 +1685,7 @@ void tcg_gen_bswap32_i64(TCGv_i64 ret, TCGv_i64 arg)
} else { } else {
TCGv_i64 t0 = tcg_temp_new_i64(); TCGv_i64 t0 = tcg_temp_new_i64();
TCGv_i64 t1 = tcg_temp_new_i64(); TCGv_i64 t1 = tcg_temp_new_i64();
TCGv_i64 t2 = tcg_const_i64(0x00ff00ff); TCGv_i64 t2 = tcg_constant_i64(0x00ff00ff);
/* arg = ....abcd */ /* arg = ....abcd */
tcg_gen_shri_i64(t0, arg, 8); /* t0 = .....abc */ tcg_gen_shri_i64(t0, arg, 8); /* t0 = .....abc */
@ -1706,7 +1701,6 @@ void tcg_gen_bswap32_i64(TCGv_i64 ret, TCGv_i64 arg)
tcg_temp_free_i64(t0); tcg_temp_free_i64(t0);
tcg_temp_free_i64(t1); tcg_temp_free_i64(t1);
tcg_temp_free_i64(t2);
} }
} }
@ -1850,16 +1844,16 @@ void tcg_gen_clzi_i64(TCGv_i64 ret, TCGv_i64 arg1, uint64_t arg2)
if (TCG_TARGET_REG_BITS == 32 if (TCG_TARGET_REG_BITS == 32
&& TCG_TARGET_HAS_clz_i32 && TCG_TARGET_HAS_clz_i32
&& arg2 <= 0xffffffffu) { && arg2 <= 0xffffffffu) {
TCGv_i32 t = tcg_const_i32((uint32_t)arg2 - 32); TCGv_i32 t = tcg_temp_new_i32();
tcg_gen_clz_i32(t, TCGV_LOW(arg1), t); tcg_gen_clzi_i32(t, TCGV_LOW(arg1), arg2 - 32);
tcg_gen_addi_i32(t, t, 32); tcg_gen_addi_i32(t, t, 32);
tcg_gen_clz_i32(TCGV_LOW(ret), TCGV_HIGH(arg1), t); tcg_gen_clz_i32(TCGV_LOW(ret), TCGV_HIGH(arg1), t);
tcg_gen_movi_i32(TCGV_HIGH(ret), 0); tcg_gen_movi_i32(TCGV_HIGH(ret), 0);
tcg_temp_free_i32(t); tcg_temp_free_i32(t);
} else { } else {
TCGv_i64 t = tcg_const_i64(arg2); TCGv_i64 t0 = tcg_const_i64(arg2);
tcg_gen_clz_i64(ret, arg1, t); tcg_gen_clz_i64(ret, arg1, t0);
tcg_temp_free_i64(t); tcg_temp_free_i64(t0);
} }
} }
@ -1881,7 +1875,7 @@ void tcg_gen_ctz_i64(TCGv_i64 ret, TCGv_i64 arg1, TCGv_i64 arg2)
tcg_gen_clzi_i64(t, t, 64); tcg_gen_clzi_i64(t, t, 64);
tcg_gen_xori_i64(t, t, 63); tcg_gen_xori_i64(t, t, 63);
} }
z = tcg_const_i64(0); z = tcg_constant_i64(0);
tcg_gen_movcond_i64(TCG_COND_EQ, ret, arg1, z, arg2, t); tcg_gen_movcond_i64(TCG_COND_EQ, ret, arg1, z, arg2, t);
tcg_temp_free_i64(t); tcg_temp_free_i64(t);
tcg_temp_free_i64(z); tcg_temp_free_i64(z);
@ -1895,8 +1889,8 @@ void tcg_gen_ctzi_i64(TCGv_i64 ret, TCGv_i64 arg1, uint64_t arg2)
if (TCG_TARGET_REG_BITS == 32 if (TCG_TARGET_REG_BITS == 32
&& TCG_TARGET_HAS_ctz_i32 && TCG_TARGET_HAS_ctz_i32
&& arg2 <= 0xffffffffu) { && arg2 <= 0xffffffffu) {
TCGv_i32 t32 = tcg_const_i32((uint32_t)arg2 - 32); TCGv_i32 t32 = tcg_temp_new_i32();
tcg_gen_ctz_i32(t32, TCGV_HIGH(arg1), t32); tcg_gen_ctzi_i32(t32, TCGV_HIGH(arg1), arg2 - 32);
tcg_gen_addi_i32(t32, t32, 32); tcg_gen_addi_i32(t32, t32, 32);
tcg_gen_ctz_i32(TCGV_LOW(ret), TCGV_LOW(arg1), t32); tcg_gen_ctz_i32(TCGV_LOW(ret), TCGV_LOW(arg1), t32);
tcg_gen_movi_i32(TCGV_HIGH(ret), 0); tcg_gen_movi_i32(TCGV_HIGH(ret), 0);
@ -1911,9 +1905,9 @@ void tcg_gen_ctzi_i64(TCGv_i64 ret, TCGv_i64 arg1, uint64_t arg2)
tcg_gen_ctpop_i64(ret, t); tcg_gen_ctpop_i64(ret, t);
tcg_temp_free_i64(t); tcg_temp_free_i64(t);
} else { } else {
TCGv_i64 t64 = tcg_const_i64(arg2); TCGv_i64 t0 = tcg_const_i64(arg2);
tcg_gen_ctz_i64(ret, arg1, t64); tcg_gen_ctz_i64(ret, arg1, t0);
tcg_temp_free_i64(t64); tcg_temp_free_i64(t0);
} }
} }
@ -1969,9 +1963,7 @@ void tcg_gen_rotli_i64(TCGv_i64 ret, TCGv_i64 arg1, int64_t arg2)
if (arg2 == 0) { if (arg2 == 0) {
tcg_gen_mov_i64(ret, arg1); tcg_gen_mov_i64(ret, arg1);
} else if (TCG_TARGET_HAS_rot_i64) { } else if (TCG_TARGET_HAS_rot_i64) {
TCGv_i64 t0 = tcg_const_i64(arg2); tcg_gen_rotl_i64(ret, arg1, tcg_constant_i64(arg2));
tcg_gen_rotl_i64(ret, arg1, t0);
tcg_temp_free_i64(t0);
} else { } else {
TCGv_i64 t0, t1; TCGv_i64 t0, t1;
t0 = tcg_temp_new_i64(); t0 = tcg_temp_new_i64();
@ -2089,9 +2081,8 @@ void tcg_gen_deposit_z_i64(TCGv_i64 ret, TCGv_i64 arg,
tcg_gen_andi_i64(ret, arg, (1ull << len) - 1); tcg_gen_andi_i64(ret, arg, (1ull << len) - 1);
} else if (TCG_TARGET_HAS_deposit_i64 } else if (TCG_TARGET_HAS_deposit_i64
&& TCG_TARGET_deposit_i64_valid(ofs, len)) { && TCG_TARGET_deposit_i64_valid(ofs, len)) {
TCGv_i64 zero = tcg_const_i64(0); TCGv_i64 zero = tcg_constant_i64(0);
tcg_gen_op5ii_i64(INDEX_op_deposit_i64, ret, zero, arg, ofs, len); tcg_gen_op5ii_i64(INDEX_op_deposit_i64, ret, zero, arg, ofs, len);
tcg_temp_free_i64(zero);
} else { } else {
if (TCG_TARGET_REG_BITS == 32) { if (TCG_TARGET_REG_BITS == 32) {
if (ofs >= 32) { if (ofs >= 32) {
@ -3117,9 +3108,8 @@ void tcg_gen_atomic_cmpxchg_i32(TCGv_i32 retv, TCGv addr, TCGv_i32 cmpv,
#ifdef CONFIG_SOFTMMU #ifdef CONFIG_SOFTMMU
{ {
TCGv_i32 oi = tcg_const_i32(make_memop_idx(memop & ~MO_SIGN, idx)); TCGMemOpIdx oi = make_memop_idx(memop & ~MO_SIGN, idx);
gen(retv, cpu_env, addr, cmpv, newv, oi); gen(retv, cpu_env, addr, cmpv, newv, tcg_constant_i32(oi));
tcg_temp_free_i32(oi);
} }
#else #else
gen(retv, cpu_env, addr, cmpv, newv); gen(retv, cpu_env, addr, cmpv, newv);
@ -3162,9 +3152,8 @@ void tcg_gen_atomic_cmpxchg_i64(TCGv_i64 retv, TCGv addr, TCGv_i64 cmpv,
#ifdef CONFIG_SOFTMMU #ifdef CONFIG_SOFTMMU
{ {
TCGv_i32 oi = tcg_const_i32(make_memop_idx(memop, idx)); TCGMemOpIdx oi = make_memop_idx(memop, idx);
gen(retv, cpu_env, addr, cmpv, newv, oi); gen(retv, cpu_env, addr, cmpv, newv, tcg_constant_i32(oi));
tcg_temp_free_i32(oi);
} }
#else #else
gen(retv, cpu_env, addr, cmpv, newv); gen(retv, cpu_env, addr, cmpv, newv);
@ -3226,9 +3215,8 @@ static void do_atomic_op_i32(TCGv_i32 ret, TCGv addr, TCGv_i32 val,
#ifdef CONFIG_SOFTMMU #ifdef CONFIG_SOFTMMU
{ {
TCGv_i32 oi = tcg_const_i32(make_memop_idx(memop & ~MO_SIGN, idx)); TCGMemOpIdx oi = make_memop_idx(memop & ~MO_SIGN, idx);
gen(ret, cpu_env, addr, val, oi); gen(ret, cpu_env, addr, val, tcg_constant_i32(oi));
tcg_temp_free_i32(oi);
} }
#else #else
gen(ret, cpu_env, addr, val); gen(ret, cpu_env, addr, val);
@ -3272,9 +3260,8 @@ static void do_atomic_op_i64(TCGv_i64 ret, TCGv addr, TCGv_i64 val,
#ifdef CONFIG_SOFTMMU #ifdef CONFIG_SOFTMMU
{ {
TCGv_i32 oi = tcg_const_i32(make_memop_idx(memop & ~MO_SIGN, idx)); TCGMemOpIdx oi = make_memop_idx(memop & ~MO_SIGN, idx);
gen(ret, cpu_env, addr, val, oi); gen(ret, cpu_env, addr, val, tcg_constant_i32(oi));
tcg_temp_free_i32(oi);
} }
#else #else
gen(ret, cpu_env, addr, val); gen(ret, cpu_env, addr, val);