aboutsummaryrefslogtreecommitdiff
path: root/target-sparc/translate.c
diff options
context:
space:
mode:
Diffstat (limited to 'target-sparc/translate.c')
-rw-r--r--target-sparc/translate.c602
1 files changed, 237 insertions, 365 deletions
diff --git a/target-sparc/translate.c b/target-sparc/translate.c
index 66bceb9fef..72dd9f2a05 100644
--- a/target-sparc/translate.c
+++ b/target-sparc/translate.c
@@ -362,11 +362,8 @@ static inline void gen_mov_reg_C(TCGv reg, TCGv src)
static inline void gen_op_exception(int exception)
{
- TCGv r_except;
-
- r_except = tcg_temp_new(TCG_TYPE_I32);
- tcg_gen_movi_i32(r_except, exception);
- tcg_gen_helper_0_1(raise_exception, r_except);
+ tcg_gen_movi_i32(cpu_tmp0, exception);
+ tcg_gen_helper_0_1(raise_exception, cpu_tmp0);
}
static inline void gen_cc_clear(void)
@@ -386,15 +383,13 @@ static inline void gen_cc_clear(void)
static inline void gen_cc_NZ(TCGv dst)
{
int l1, l2;
- TCGv r_zero;
l1 = gen_new_label();
l2 = gen_new_label();
- r_zero = tcg_const_tl(0);
- tcg_gen_brcond_i32(TCG_COND_NE, dst, r_zero, l1);
+ tcg_gen_brcond_i32(TCG_COND_NE, dst, tcg_const_i32(0), l1);
tcg_gen_ori_i32(cpu_psr, cpu_psr, PSR_ZERO);
gen_set_label(l1);
- tcg_gen_brcond_i32(TCG_COND_GE, dst, r_zero, l2);
+ tcg_gen_brcond_i32(TCG_COND_GE, dst, tcg_const_i32(0), l2);
tcg_gen_ori_i32(cpu_psr, cpu_psr, PSR_NEG);
gen_set_label(l2);
#ifdef TARGET_SPARC64
@@ -403,10 +398,10 @@ static inline void gen_cc_NZ(TCGv dst)
l3 = gen_new_label();
l4 = gen_new_label();
- tcg_gen_brcond_tl(TCG_COND_NE, dst, r_zero, l3);
+ tcg_gen_brcond_tl(TCG_COND_NE, dst, tcg_const_tl(0), l3);
tcg_gen_ori_i32(cpu_xcc, cpu_xcc, PSR_ZERO);
gen_set_label(l3);
- tcg_gen_brcond_tl(TCG_COND_GE, dst, r_zero, l4);
+ tcg_gen_brcond_tl(TCG_COND_GE, dst, tcg_const_tl(0), l4);
tcg_gen_ori_i32(cpu_xcc, cpu_xcc, PSR_NEG);
gen_set_label(l4);
}
@@ -443,21 +438,18 @@ static inline void gen_cc_C_add(TCGv dst, TCGv src1)
*/
static inline void gen_cc_V_add(TCGv dst, TCGv src1, TCGv src2)
{
- TCGv r_temp, r_temp2, r_temp3, r_zero;
+ TCGv r_temp;
int l1;
l1 = gen_new_label();
r_temp = tcg_temp_new(TCG_TYPE_TL);
- r_temp2 = tcg_temp_new(TCG_TYPE_TL);
- r_temp3 = tcg_temp_new(TCG_TYPE_TL);
- r_zero = tcg_const_tl(0);
tcg_gen_xor_tl(r_temp, src1, src2);
tcg_gen_xori_tl(r_temp, r_temp, -1);
- tcg_gen_xor_tl(r_temp2, src1, dst);
- tcg_gen_and_tl(r_temp, r_temp, r_temp2);
- tcg_gen_andi_tl(r_temp3, r_temp, (1 << 31));
- tcg_gen_brcond_i32(TCG_COND_EQ, r_temp3, r_zero, l1);
+ tcg_gen_xor_tl(cpu_tmp0, src1, dst);
+ tcg_gen_and_tl(r_temp, r_temp, cpu_tmp0);
+ tcg_gen_andi_tl(r_temp, r_temp, (1 << 31));
+ tcg_gen_brcond_i32(TCG_COND_EQ, r_temp, tcg_const_i32(0), l1);
tcg_gen_ori_i32(cpu_psr, cpu_psr, PSR_OVF);
gen_set_label(l1);
#ifdef TARGET_SPARC64
@@ -467,33 +459,31 @@ static inline void gen_cc_V_add(TCGv dst, TCGv src1, TCGv src2)
l2 = gen_new_label();
tcg_gen_xor_tl(r_temp, src1, src2);
tcg_gen_xori_tl(r_temp, r_temp, -1);
- tcg_gen_xor_tl(r_temp2, src1, dst);
- tcg_gen_and_tl(r_temp, r_temp, r_temp2);
- tcg_gen_andi_tl(r_temp3, r_temp, (1ULL << 63));
- tcg_gen_brcond_tl(TCG_COND_EQ, r_temp3, r_zero, l2);
+ tcg_gen_xor_tl(cpu_tmp0, src1, dst);
+ tcg_gen_and_tl(r_temp, r_temp, cpu_tmp0);
+ tcg_gen_andi_tl(r_temp, r_temp, (1ULL << 63));
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_temp, tcg_const_tl(0), l2);
tcg_gen_ori_i32(cpu_xcc, cpu_xcc, PSR_OVF);
gen_set_label(l2);
}
#endif
+ tcg_gen_discard_tl(r_temp);
}
static inline void gen_add_tv(TCGv dst, TCGv src1, TCGv src2)
{
- TCGv r_temp, r_temp2, r_temp3, r_zero;
+ TCGv r_temp;
int l1;
l1 = gen_new_label();
r_temp = tcg_temp_new(TCG_TYPE_TL);
- r_temp2 = tcg_temp_new(TCG_TYPE_TL);
- r_temp3 = tcg_temp_new(TCG_TYPE_TL);
- r_zero = tcg_const_tl(0);
tcg_gen_xor_tl(r_temp, src1, src2);
tcg_gen_xori_tl(r_temp, r_temp, -1);
- tcg_gen_xor_tl(r_temp2, src1, dst);
- tcg_gen_and_tl(r_temp, r_temp, r_temp2);
- tcg_gen_andi_tl(r_temp3, r_temp, (1 << 31));
- tcg_gen_brcond_i32(TCG_COND_EQ, r_temp3, r_zero, l1);
+ tcg_gen_xor_tl(cpu_tmp0, src1, dst);
+ tcg_gen_and_tl(r_temp, r_temp, cpu_tmp0);
+ tcg_gen_andi_tl(r_temp, r_temp, (1 << 31));
+ tcg_gen_brcond_i32(TCG_COND_EQ, r_temp, tcg_const_i32(0), l1);
gen_op_exception(TT_TOVF);
gen_set_label(l1);
#ifdef TARGET_SPARC64
@@ -503,27 +493,25 @@ static inline void gen_add_tv(TCGv dst, TCGv src1, TCGv src2)
l2 = gen_new_label();
tcg_gen_xor_tl(r_temp, src1, src2);
tcg_gen_xori_tl(r_temp, r_temp, -1);
- tcg_gen_xor_tl(r_temp2, src1, dst);
- tcg_gen_and_tl(r_temp, r_temp, r_temp2);
- tcg_gen_andi_tl(r_temp3, r_temp, (1ULL << 63));
- tcg_gen_brcond_tl(TCG_COND_EQ, r_temp3, r_zero, l2);
+ tcg_gen_xor_tl(cpu_tmp0, src1, dst);
+ tcg_gen_and_tl(r_temp, r_temp, cpu_tmp0);
+ tcg_gen_andi_tl(r_temp, r_temp, (1ULL << 63));
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_temp, tcg_const_tl(0), l2);
gen_op_exception(TT_TOVF);
gen_set_label(l2);
}
#endif
+ tcg_gen_discard_tl(r_temp);
}
static inline void gen_cc_V_tag(TCGv src1, TCGv src2)
{
int l1;
- TCGv r_zero, r_temp;
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
- r_temp = tcg_temp_new(TCG_TYPE_TL);
- tcg_gen_or_tl(r_temp, src1, src2);
- tcg_gen_andi_tl(r_temp, r_temp, 0x3);
- tcg_gen_brcond_tl(TCG_COND_EQ, r_temp, r_zero, l1);
+ tcg_gen_or_tl(cpu_tmp0, src1, src2);
+ tcg_gen_andi_tl(cpu_tmp0, cpu_tmp0, 0x3);
+ tcg_gen_brcond_tl(TCG_COND_EQ, cpu_tmp0, tcg_const_tl(0), l1);
tcg_gen_ori_i32(cpu_psr, cpu_psr, PSR_OVF);
gen_set_label(l1);
}
@@ -531,14 +519,11 @@ static inline void gen_cc_V_tag(TCGv src1, TCGv src2)
static inline void gen_tag_tv(TCGv src1, TCGv src2)
{
int l1;
- TCGv r_zero, r_temp;
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
- r_temp = tcg_temp_new(TCG_TYPE_TL);
- tcg_gen_or_tl(r_temp, src1, src2);
- tcg_gen_andi_tl(r_temp, r_temp, 0x3);
- tcg_gen_brcond_tl(TCG_COND_EQ, r_temp, r_zero, l1);
+ tcg_gen_or_tl(cpu_tmp0, src1, src2);
+ tcg_gen_andi_tl(cpu_tmp0, cpu_tmp0, 0x3);
+ tcg_gen_brcond_tl(TCG_COND_EQ, cpu_tmp0, tcg_const_tl(0), l1);
gen_op_exception(TT_TOVF);
gen_set_label(l1);
}
@@ -618,20 +603,17 @@ static inline void gen_cc_C_sub(TCGv src1, TCGv src2)
*/
static inline void gen_cc_V_sub(TCGv dst, TCGv src1, TCGv src2)
{
- TCGv r_temp, r_temp2, r_temp3, r_zero;
+ TCGv r_temp;
int l1;
l1 = gen_new_label();
r_temp = tcg_temp_new(TCG_TYPE_TL);
- r_temp2 = tcg_temp_new(TCG_TYPE_TL);
- r_temp3 = tcg_temp_new(TCG_TYPE_TL);
- r_zero = tcg_const_tl(0);
tcg_gen_xor_tl(r_temp, src1, src2);
- tcg_gen_xor_tl(r_temp2, src1, dst);
- tcg_gen_and_tl(r_temp, r_temp, r_temp2);
- tcg_gen_andi_tl(r_temp3, r_temp, (1 << 31));
- tcg_gen_brcond_i32(TCG_COND_EQ, r_temp3, r_zero, l1);
+ tcg_gen_xor_tl(cpu_tmp0, src1, dst);
+ tcg_gen_and_tl(r_temp, r_temp, cpu_tmp0);
+ tcg_gen_andi_tl(r_temp, r_temp, (1 << 31));
+ tcg_gen_brcond_i32(TCG_COND_EQ, r_temp, tcg_const_i32(0), l1);
tcg_gen_ori_i32(cpu_psr, cpu_psr, PSR_OVF);
gen_set_label(l1);
#ifdef TARGET_SPARC64
@@ -640,32 +622,30 @@ static inline void gen_cc_V_sub(TCGv dst, TCGv src1, TCGv src2)
l2 = gen_new_label();
tcg_gen_xor_tl(r_temp, src1, src2);
- tcg_gen_xor_tl(r_temp2, src1, dst);
- tcg_gen_and_tl(r_temp, r_temp, r_temp2);
- tcg_gen_andi_tl(r_temp3, r_temp, (1ULL << 63));
- tcg_gen_brcond_tl(TCG_COND_EQ, r_temp3, r_zero, l2);
+ tcg_gen_xor_tl(cpu_tmp0, src1, dst);
+ tcg_gen_and_tl(r_temp, r_temp, cpu_tmp0);
+ tcg_gen_andi_tl(r_temp, r_temp, (1ULL << 63));
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_temp, tcg_const_tl(0), l2);
tcg_gen_ori_i32(cpu_xcc, cpu_xcc, PSR_OVF);
gen_set_label(l2);
}
#endif
+ tcg_gen_discard_tl(r_temp);
}
static inline void gen_sub_tv(TCGv dst, TCGv src1, TCGv src2)
{
- TCGv r_temp, r_temp2, r_temp3, r_zero;
+ TCGv r_temp;
int l1;
l1 = gen_new_label();
r_temp = tcg_temp_new(TCG_TYPE_TL);
- r_temp2 = tcg_temp_new(TCG_TYPE_TL);
- r_temp3 = tcg_temp_new(TCG_TYPE_TL);
- r_zero = tcg_const_tl(0);
tcg_gen_xor_tl(r_temp, src1, src2);
- tcg_gen_xor_tl(r_temp2, src1, dst);
- tcg_gen_and_tl(r_temp, r_temp, r_temp2);
- tcg_gen_andi_tl(r_temp3, r_temp, (1 << 31));
- tcg_gen_brcond_i32(TCG_COND_EQ, r_temp3, r_zero, l1);
+ tcg_gen_xor_tl(cpu_tmp0, src1, dst);
+ tcg_gen_and_tl(r_temp, r_temp, cpu_tmp0);
+ tcg_gen_andi_tl(r_temp, r_temp, (1 << 31));
+ tcg_gen_brcond_i32(TCG_COND_EQ, r_temp, tcg_const_i32(0), l1);
gen_op_exception(TT_TOVF);
gen_set_label(l1);
#ifdef TARGET_SPARC64
@@ -674,14 +654,15 @@ static inline void gen_sub_tv(TCGv dst, TCGv src1, TCGv src2)
l2 = gen_new_label();
tcg_gen_xor_tl(r_temp, src1, src2);
- tcg_gen_xor_tl(r_temp2, src1, dst);
- tcg_gen_and_tl(r_temp, r_temp, r_temp2);
- tcg_gen_andi_tl(r_temp3, r_temp, (1ULL << 63));
- tcg_gen_brcond_tl(TCG_COND_EQ, r_temp3, r_zero, l2);
+ tcg_gen_xor_tl(cpu_tmp0, src1, dst);
+ tcg_gen_and_tl(r_temp, r_temp, cpu_tmp0);
+ tcg_gen_andi_tl(r_temp, r_temp, (1ULL << 63));
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_temp, tcg_const_tl(0), l2);
gen_op_exception(TT_TOVF);
gen_set_label(l2);
}
#endif
+ tcg_gen_discard_tl(r_temp);
}
static inline void gen_op_sub_T1_T0_cc(void)
@@ -760,13 +741,11 @@ static inline void gen_op_sdivx_T1_T0(void)
static inline void gen_op_div_cc(void)
{
int l1;
- TCGv r_zero;
gen_cc_clear();
gen_cc_NZ(cpu_T[0]);
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
- tcg_gen_brcond_i32(TCG_COND_EQ, cpu_T[1], r_zero, l1);
+ tcg_gen_brcond_i32(TCG_COND_EQ, cpu_T[1], tcg_const_i32(0), l1);
tcg_gen_ori_i32(cpu_psr, cpu_psr, PSR_OVF);
gen_set_label(l1);
}
@@ -792,36 +771,27 @@ static inline void gen_op_eval_be(TCGv dst, TCGv src)
// Z | (N ^ V)
static inline void gen_op_eval_ble(TCGv dst, TCGv src)
{
- TCGv r_flag;
-
- r_flag = tcg_temp_new(TCG_TYPE_TL);
- gen_mov_reg_N(r_flag, src);
+ gen_mov_reg_N(cpu_tmp0, src);
gen_mov_reg_V(dst, src);
- tcg_gen_xor_tl(dst, dst, r_flag);
- gen_mov_reg_Z(r_flag, src);
- tcg_gen_or_tl(dst, dst, r_flag);
+ tcg_gen_xor_tl(dst, dst, cpu_tmp0);
+ gen_mov_reg_Z(cpu_tmp0, src);
+ tcg_gen_or_tl(dst, dst, cpu_tmp0);
}
// N ^ V
static inline void gen_op_eval_bl(TCGv dst, TCGv src)
{
- TCGv r_V;
-
- r_V = tcg_temp_new(TCG_TYPE_TL);
- gen_mov_reg_V(r_V, src);
+ gen_mov_reg_V(cpu_tmp0, src);
gen_mov_reg_N(dst, src);
- tcg_gen_xor_tl(dst, dst, r_V);
+ tcg_gen_xor_tl(dst, dst, cpu_tmp0);
}
// C | Z
static inline void gen_op_eval_bleu(TCGv dst, TCGv src)
{
- TCGv r_Z;
-
- r_Z = tcg_temp_new(TCG_TYPE_TL);
- gen_mov_reg_Z(r_Z, src);
+ gen_mov_reg_Z(cpu_tmp0, src);
gen_mov_reg_C(dst, src);
- tcg_gen_or_tl(dst, dst, r_Z);
+ tcg_gen_or_tl(dst, dst, cpu_tmp0);
}
// C
@@ -858,38 +828,29 @@ static inline void gen_op_eval_bne(TCGv dst, TCGv src)
// !(Z | (N ^ V))
static inline void gen_op_eval_bg(TCGv dst, TCGv src)
{
- TCGv r_flag;
-
- r_flag = tcg_temp_new(TCG_TYPE_TL);
- gen_mov_reg_N(r_flag, src);
+ gen_mov_reg_N(cpu_tmp0, src);
gen_mov_reg_V(dst, src);
- tcg_gen_xor_tl(dst, dst, r_flag);
- gen_mov_reg_Z(r_flag, src);
- tcg_gen_or_tl(dst, dst, r_flag);
+ tcg_gen_xor_tl(dst, dst, cpu_tmp0);
+ gen_mov_reg_Z(cpu_tmp0, src);
+ tcg_gen_or_tl(dst, dst, cpu_tmp0);
tcg_gen_xori_tl(dst, dst, 0x1);
}
// !(N ^ V)
static inline void gen_op_eval_bge(TCGv dst, TCGv src)
{
- TCGv r_V;
-
- r_V = tcg_temp_new(TCG_TYPE_TL);
- gen_mov_reg_V(r_V, src);
+ gen_mov_reg_V(cpu_tmp0, src);
gen_mov_reg_N(dst, src);
- tcg_gen_xor_tl(dst, dst, r_V);
+ tcg_gen_xor_tl(dst, dst, cpu_tmp0);
tcg_gen_xori_tl(dst, dst, 0x1);
}
// !(C | Z)
static inline void gen_op_eval_bgu(TCGv dst, TCGv src)
{
- TCGv r_Z;
-
- r_Z = tcg_temp_new(TCG_TYPE_TL);
- gen_mov_reg_Z(r_Z, src);
+ gen_mov_reg_Z(cpu_tmp0, src);
gen_mov_reg_C(dst, src);
- tcg_gen_or_tl(dst, dst, r_Z);
+ tcg_gen_or_tl(dst, dst, cpu_tmp0);
tcg_gen_xori_tl(dst, dst, 0x1);
}
@@ -939,24 +900,18 @@ static inline void gen_mov_reg_FCC1(TCGv reg, TCGv src,
static inline void gen_op_eval_fbne(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_or_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_or_tl(dst, dst, cpu_tmp0);
}
// 1 or 2: FCC0 ^ FCC1
static inline void gen_op_eval_fblg(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_xor_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_xor_tl(dst, dst, cpu_tmp0);
}
// 1 or 3: FCC0
@@ -970,13 +925,10 @@ static inline void gen_op_eval_fbul(TCGv dst, TCGv src,
static inline void gen_op_eval_fbl(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_xori_tl(r_fcc1, r_fcc1, 0x1);
- tcg_gen_and_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_xori_tl(cpu_tmp0, cpu_tmp0, 0x1);
+ tcg_gen_and_tl(dst, dst, cpu_tmp0);
}
// 2 or 3: FCC1
@@ -990,37 +942,28 @@ static inline void gen_op_eval_fbug(TCGv dst, TCGv src,
static inline void gen_op_eval_fbg(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
tcg_gen_xori_tl(dst, dst, 0x1);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_and_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_and_tl(dst, dst, cpu_tmp0);
}
// 3: FCC0 & FCC1
static inline void gen_op_eval_fbu(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_and_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_and_tl(dst, dst, cpu_tmp0);
}
// 0: !(FCC0 | FCC1)
static inline void gen_op_eval_fbe(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_or_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_or_tl(dst, dst, cpu_tmp0);
tcg_gen_xori_tl(dst, dst, 0x1);
}
@@ -1028,12 +971,9 @@ static inline void gen_op_eval_fbe(TCGv dst, TCGv src,
static inline void gen_op_eval_fbue(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_xor_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_xor_tl(dst, dst, cpu_tmp0);
tcg_gen_xori_tl(dst, dst, 0x1);
}
@@ -1049,13 +989,10 @@ static inline void gen_op_eval_fbge(TCGv dst, TCGv src,
static inline void gen_op_eval_fbuge(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_xori_tl(r_fcc1, r_fcc1, 0x1);
- tcg_gen_and_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_xori_tl(cpu_tmp0, cpu_tmp0, 0x1);
+ tcg_gen_and_tl(dst, dst, cpu_tmp0);
tcg_gen_xori_tl(dst, dst, 0x1);
}
@@ -1071,13 +1008,10 @@ static inline void gen_op_eval_fble(TCGv dst, TCGv src,
static inline void gen_op_eval_fbule(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
tcg_gen_xori_tl(dst, dst, 0x1);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_and_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_and_tl(dst, dst, cpu_tmp0);
tcg_gen_xori_tl(dst, dst, 0x1);
}
@@ -1085,25 +1019,20 @@ static inline void gen_op_eval_fbule(TCGv dst, TCGv src,
static inline void gen_op_eval_fbo(TCGv dst, TCGv src,
unsigned int fcc_offset)
{
- TCGv r_fcc1;
-
- r_fcc1 = tcg_temp_new(TCG_TYPE_TL);
gen_mov_reg_FCC0(dst, src, fcc_offset);
- gen_mov_reg_FCC1(r_fcc1, src, fcc_offset);
- tcg_gen_and_tl(dst, dst, r_fcc1);
+ gen_mov_reg_FCC1(cpu_tmp0, src, fcc_offset);
+ tcg_gen_and_tl(dst, dst, cpu_tmp0);
tcg_gen_xori_tl(dst, dst, 0x1);
}
static inline void gen_branch2(DisasContext *dc, target_ulong pc1,
target_ulong pc2, TCGv r_cond)
{
- TCGv r_zero;
int l1;
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
- tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, r_zero, l1);
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, tcg_const_tl(0), l1);
gen_goto_tb(dc, 0, pc1, pc1 + 4);
@@ -1114,13 +1043,11 @@ static inline void gen_branch2(DisasContext *dc, target_ulong pc1,
static inline void gen_branch_a(DisasContext *dc, target_ulong pc1,
target_ulong pc2, TCGv r_cond)
{
- TCGv r_zero;
int l1;
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
- tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, r_zero, l1);
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, tcg_const_tl(0), l1);
gen_goto_tb(dc, 0, pc2, pc1);
@@ -1137,14 +1064,12 @@ static inline void gen_branch(DisasContext *dc, target_ulong pc,
static inline void gen_generic_branch(target_ulong npc1, target_ulong npc2,
TCGv r_cond)
{
- TCGv r_zero;
int l1, l2;
l1 = gen_new_label();
l2 = gen_new_label();
- r_zero = tcg_const_tl(0);
- tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, r_zero, l1);
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, tcg_const_tl(0), l1);
gen_movl_npc_im(npc1);
gen_op_jmp_label(l2);
@@ -1354,13 +1279,11 @@ static const int gen_tcg_cond_reg[8] = {
static inline void gen_cond_reg(TCGv r_dst, int cond)
{
- TCGv r_zero;
int l1;
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
- tcg_gen_mov_tl(r_dst, r_zero);
- tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1);
+ tcg_gen_movi_tl(r_dst, 0);
+ tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], tcg_const_tl(0), l1);
tcg_gen_movi_tl(r_dst, 1);
gen_set_label(l1);
}
@@ -1614,175 +1537,134 @@ static inline void gen_clear_float_exceptions(void)
/* asi moves */
#ifdef TARGET_SPARC64
-static inline void gen_ld_asi(int insn, int size, int sign)
+static inline TCGv gen_get_asi(int insn, TCGv r_addr)
{
int asi, offset;
- TCGv r_size, r_sign;
+ TCGv r_asi;
- r_size = tcg_temp_new(TCG_TYPE_I32);
- r_sign = tcg_temp_new(TCG_TYPE_I32);
- tcg_gen_movi_i32(r_size, size);
- tcg_gen_movi_i32(r_sign, sign);
if (IS_IMM) {
+ r_asi = tcg_temp_new(TCG_TYPE_I32);
offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(cpu_T[1], cpu_env, offsetof(CPUSPARCState, asi));
+ tcg_gen_addi_tl(r_addr, r_addr, offset);
+ tcg_gen_ld_i32(r_asi, cpu_env, offsetof(CPUSPARCState, asi));
} else {
asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(cpu_T[1], asi);
+ r_asi = tcg_const_i32(asi);
}
- tcg_gen_helper_1_4(helper_ld_asi, cpu_T[1], cpu_T[0], cpu_T[1], r_size,
- r_sign);
+ return r_asi;
+}
+
+static inline void gen_ld_asi(int insn, int size, int sign)
+{
+ TCGv r_asi;
+
+ r_asi = gen_get_asi(insn, cpu_T[0]);
+ tcg_gen_helper_1_4(helper_ld_asi, cpu_T[1], cpu_T[0], r_asi,
+ tcg_const_i32(size), tcg_const_i32(sign));
+ tcg_gen_discard_i32(r_asi);
}
static inline void gen_st_asi(int insn, int size)
{
- int asi, offset;
- TCGv r_asi, r_size;
+ TCGv r_asi;
- r_asi = tcg_temp_new(TCG_TYPE_I32);
- r_size = tcg_temp_new(TCG_TYPE_I32);
- tcg_gen_movi_i32(r_size, size);
- if (IS_IMM) {
- offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(r_asi, cpu_env, offsetof(CPUSPARCState, asi));
- } else {
- asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(r_asi, asi);
- }
- tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], cpu_T[1], r_asi, r_size);
+ r_asi = gen_get_asi(insn, cpu_T[0]);
+ tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], cpu_T[1], r_asi,
+ tcg_const_i32(size));
+ tcg_gen_discard_i32(r_asi);
}
static inline void gen_ldf_asi(int insn, int size, int rd)
{
- int asi, offset;
- TCGv r_asi, r_size, r_rd;
+ TCGv r_asi;
- r_asi = tcg_temp_new(TCG_TYPE_I32);
- r_size = tcg_temp_new(TCG_TYPE_I32);
- r_rd = tcg_temp_new(TCG_TYPE_I32);
- tcg_gen_movi_i32(r_size, size);
- tcg_gen_movi_i32(r_rd, rd);
- if (IS_IMM) {
- offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(r_asi, cpu_env, offsetof(CPUSPARCState, asi));
- } else {
- asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(r_asi, asi);
- }
- tcg_gen_helper_0_4(helper_ldf_asi, cpu_T[0], r_asi, r_size, r_rd);
+ r_asi = gen_get_asi(insn, cpu_T[0]);
+ tcg_gen_helper_0_4(helper_ldf_asi, cpu_T[0], r_asi, tcg_const_i32(size),
+ tcg_const_i32(rd));
+ tcg_gen_discard_i32(r_asi);
}
static inline void gen_stf_asi(int insn, int size, int rd)
{
- int asi, offset;
- TCGv r_asi, r_size, r_rd;
+ TCGv r_asi;
- r_asi = tcg_temp_new(TCG_TYPE_I32);
- r_size = tcg_temp_new(TCG_TYPE_I32);
- r_rd = tcg_temp_new(TCG_TYPE_I32);
- tcg_gen_movi_i32(r_size, size);
- tcg_gen_movi_i32(r_rd, rd);
- if (IS_IMM) {
- offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(r_asi, cpu_env, offsetof(CPUSPARCState, asi));
- } else {
- asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(r_asi, asi);
- }
- tcg_gen_helper_0_4(helper_stf_asi, cpu_T[0], r_asi, r_size, r_rd);
+ r_asi = gen_get_asi(insn, cpu_T[0]);
+ tcg_gen_helper_0_4(helper_stf_asi, cpu_T[0], r_asi, tcg_const_i32(size),
+ tcg_const_i32(rd));
+ tcg_gen_discard_i32(r_asi);
}
static inline void gen_swap_asi(int insn)
{
- int asi, offset;
- TCGv r_size, r_sign, r_temp;
+ TCGv r_temp, r_asi;
- r_size = tcg_temp_new(TCG_TYPE_I32);
- r_sign = tcg_temp_new(TCG_TYPE_I32);
r_temp = tcg_temp_new(TCG_TYPE_I32);
- tcg_gen_movi_i32(r_size, 4);
- tcg_gen_movi_i32(r_sign, 0);
- if (IS_IMM) {
- offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(cpu_T[1], cpu_env, offsetof(CPUSPARCState, asi));
- } else {
- asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(cpu_T[1], asi);
- }
- tcg_gen_helper_1_4(helper_ld_asi, r_temp, cpu_T[0], cpu_T[1], r_size,
- r_sign);
- tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], cpu_T[1], r_size, r_sign);
+ r_asi = gen_get_asi(insn, cpu_T[0]);
+ tcg_gen_helper_1_4(helper_ld_asi, r_temp, cpu_T[0], r_asi,
+ tcg_const_i32(4), tcg_const_i32(0));
+ tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], r_temp, r_asi,
+ tcg_const_i32(4));
tcg_gen_mov_i32(cpu_T[1], r_temp);
+ tcg_gen_discard_i32(r_asi);
+ tcg_gen_discard_i32(r_temp);
}
static inline void gen_ldda_asi(int insn)
{
- int asi, offset;
- TCGv r_size, r_sign, r_dword;
+ TCGv r_dword, r_asi;
- r_size = tcg_temp_new(TCG_TYPE_I32);
- r_sign = tcg_temp_new(TCG_TYPE_I32);
r_dword = tcg_temp_new(TCG_TYPE_I64);
- tcg_gen_movi_i32(r_size, 8);
- tcg_gen_movi_i32(r_sign, 0);
- if (IS_IMM) {
- offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(cpu_T[1], cpu_env, offsetof(CPUSPARCState, asi));
- } else {
- asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(cpu_T[1], asi);
- }
- tcg_gen_helper_1_4(helper_ld_asi, r_dword, cpu_T[0], cpu_T[1], r_size,
- r_sign);
+ r_asi = gen_get_asi(insn, cpu_T[0]);
+ tcg_gen_helper_1_4(helper_ld_asi, r_dword, cpu_T[0], r_asi,
+ tcg_const_i32(8), tcg_const_i32(0));
tcg_gen_trunc_i64_i32(cpu_T[0], r_dword);
tcg_gen_shri_i64(r_dword, r_dword, 32);
tcg_gen_trunc_i64_i32(cpu_T[1], r_dword);
+ tcg_gen_discard_i32(r_asi);
+ tcg_gen_discard_i64(r_dword);
+}
+
+static inline void gen_stda_asi(int insn, int rd)
+{
+ TCGv r_dword, r_temp, r_asi;
+
+ r_dword = tcg_temp_new(TCG_TYPE_I64);
+ r_temp = tcg_temp_new(TCG_TYPE_I32);
+ gen_movl_reg_TN(rd + 1, r_temp);
+ tcg_gen_helper_1_2(helper_pack64, r_dword, cpu_T[1],
+ r_temp);
+ r_asi = gen_get_asi(insn, cpu_T[0]);
+ tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], r_dword, r_asi,
+ tcg_const_i32(8));
+ tcg_gen_discard_i32(r_asi);
+ tcg_gen_discard_i32(r_temp);
+ tcg_gen_discard_i64(r_dword);
}
static inline void gen_cas_asi(int insn, int rd)
{
- int asi, offset;
TCGv r_val1, r_asi;
r_val1 = tcg_temp_new(TCG_TYPE_I32);
- r_asi = tcg_temp_new(TCG_TYPE_I32);
gen_movl_reg_TN(rd, r_val1);
- if (IS_IMM) {
- offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(r_asi, cpu_env, offsetof(CPUSPARCState, asi));
- } else {
- asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(r_asi, asi);
- }
+ r_asi = gen_get_asi(insn, cpu_T[0]);
tcg_gen_helper_1_4(helper_cas_asi, cpu_T[1], cpu_T[0], r_val1, cpu_T[1],
r_asi);
+ tcg_gen_discard_i32(r_asi);
+ tcg_gen_discard_i32(r_val1);
}
static inline void gen_casx_asi(int insn, int rd)
{
- int asi, offset;
TCGv r_val1, r_asi;
r_val1 = tcg_temp_new(TCG_TYPE_I64);
- r_asi = tcg_temp_new(TCG_TYPE_I32);
gen_movl_reg_TN(rd, r_val1);
- if (IS_IMM) {
- offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(r_asi, cpu_env, offsetof(CPUSPARCState, asi));
- } else {
- asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(r_asi, asi);
- }
+ r_asi = gen_get_asi(insn, cpu_T[0]);
tcg_gen_helper_1_4(helper_casx_asi, cpu_T[1], cpu_T[0], r_val1, cpu_T[1],
r_asi);
+ tcg_gen_discard_i32(r_asi);
+ tcg_gen_discard_i32(r_val1);
}
#elif !defined(CONFIG_USER_ONLY)
@@ -1790,70 +1672,72 @@ static inline void gen_casx_asi(int insn, int rd)
static inline void gen_ld_asi(int insn, int size, int sign)
{
int asi;
- TCGv r_size, r_sign, r_dword;
+ TCGv r_dword;
- r_size = tcg_temp_new(TCG_TYPE_I32);
- r_sign = tcg_temp_new(TCG_TYPE_I32);
r_dword = tcg_temp_new(TCG_TYPE_I64);
- tcg_gen_movi_i32(r_size, size);
- tcg_gen_movi_i32(r_sign, sign);
asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(cpu_T[1], asi);
- tcg_gen_helper_1_4(helper_ld_asi, r_dword, cpu_T[0], cpu_T[1], r_size,
- r_sign);
+ tcg_gen_helper_1_4(helper_ld_asi, r_dword, cpu_T[0], tcg_const_i32(asi),
+ tcg_const_i32(size), tcg_const_i32(sign));
tcg_gen_trunc_i64_i32(cpu_T[1], r_dword);
+ tcg_gen_discard_i64(r_dword);
}
static inline void gen_st_asi(int insn, int size)
{
int asi;
- TCGv r_dword, r_asi, r_size;
+ TCGv r_dword;
r_dword = tcg_temp_new(TCG_TYPE_I64);
tcg_gen_extu_i32_i64(r_dword, cpu_T[1]);
- r_asi = tcg_temp_new(TCG_TYPE_I32);
- r_size = tcg_temp_new(TCG_TYPE_I32);
asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(r_asi, asi);
- tcg_gen_movi_i32(r_size, size);
- tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], r_dword, r_asi, r_size);
+ tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], r_dword, tcg_const_i32(asi),
+ tcg_const_i32(size));
+ tcg_gen_discard_i64(r_dword);
}
static inline void gen_swap_asi(int insn)
{
int asi;
- TCGv r_size, r_sign, r_temp;
+ TCGv r_temp;
- r_size = tcg_temp_new(TCG_TYPE_I32);
- r_sign = tcg_temp_new(TCG_TYPE_I32);
r_temp = tcg_temp_new(TCG_TYPE_I32);
- tcg_gen_movi_i32(r_size, 4);
- tcg_gen_movi_i32(r_sign, 0);
asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(cpu_T[1], asi);
- tcg_gen_helper_1_4(helper_ld_asi, r_temp, cpu_T[0], cpu_T[1], r_size,
- r_sign);
- tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], cpu_T[1], r_size, r_sign);
+ tcg_gen_helper_1_4(helper_ld_asi, r_temp, cpu_T[0], tcg_const_i32(asi),
+ tcg_const_i32(4), tcg_const_i32(0));
+ tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], cpu_T[1], tcg_const_i32(asi),
+ tcg_const_i32(4));
tcg_gen_mov_i32(cpu_T[1], r_temp);
+ tcg_gen_discard_i32(r_temp);
}
static inline void gen_ldda_asi(int insn)
{
int asi;
- TCGv r_size, r_sign, r_dword;
+ TCGv r_dword;
- r_size = tcg_temp_new(TCG_TYPE_I32);
- r_sign = tcg_temp_new(TCG_TYPE_I32);
r_dword = tcg_temp_new(TCG_TYPE_I64);
- tcg_gen_movi_i32(r_size, 8);
- tcg_gen_movi_i32(r_sign, 0);
asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(cpu_T[1], asi);
- tcg_gen_helper_1_4(helper_ld_asi, r_dword, cpu_T[0], cpu_T[1], r_size,
- r_sign);
+ tcg_gen_helper_1_4(helper_ld_asi, r_dword, cpu_T[0], tcg_const_i32(asi),
+ tcg_const_i32(8), tcg_const_i32(0));
tcg_gen_trunc_i64_i32(cpu_T[0], r_dword);
tcg_gen_shri_i64(r_dword, r_dword, 32);
tcg_gen_trunc_i64_i32(cpu_T[1], r_dword);
+ tcg_gen_discard_i64(r_dword);
+}
+
+static inline void gen_stda_asi(int insn, int rd)
+{
+ int asi;
+ TCGv r_dword, r_temp;
+
+ r_dword = tcg_temp_new(TCG_TYPE_I64);
+ r_temp = tcg_temp_new(TCG_TYPE_I32);
+ gen_movl_reg_TN(rd + 1, r_temp);
+ tcg_gen_helper_1_2(helper_pack64, r_dword, cpu_T[1], r_temp);
+ asi = GET_FIELD(insn, 19, 26);
+ tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], r_dword, tcg_const_i32(asi),
+ tcg_const_i32(8));
+ tcg_gen_discard_i64(r_dword);
}
#endif
@@ -1861,18 +1745,12 @@ static inline void gen_ldda_asi(int insn)
static inline void gen_ldstub_asi(int insn)
{
int asi;
- TCGv r_dword, r_asi, r_size;
gen_ld_asi(insn, 1, 0);
- r_dword = tcg_temp_new(TCG_TYPE_I64);
- r_asi = tcg_temp_new(TCG_TYPE_I32);
- r_size = tcg_temp_new(TCG_TYPE_I32);
asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(r_dword, 0xff);
- tcg_gen_movi_i32(r_asi, asi);
- tcg_gen_movi_i32(r_size, 1);
- tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], r_dword, r_asi, r_size);
+ tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], tcg_const_i64(0xff),
+ tcg_const_i32(asi), tcg_const_i32(1));
}
#endif
@@ -2028,6 +1906,7 @@ static void disas_sparc_insn(DisasContext * dc)
gen_cond(r_cond, 0, cond);
#endif
tcg_gen_helper_0_2(helper_trapcc, cpu_T[0], r_cond);
+ tcg_gen_discard_tl(r_cond);
}
gen_op_next_insn();
tcg_gen_exit_tb(0);
@@ -2069,6 +1948,7 @@ static void disas_sparc_insn(DisasContext * dc)
tcg_gen_helper_1_1(helper_tick_get_count, cpu_T[0],
r_tickptr);
gen_movl_T0_reg(rd);
+ tcg_gen_discard_ptr(r_tickptr);
}
break;
case 0x5: /* V9 rdpc */
@@ -2101,6 +1981,7 @@ static void disas_sparc_insn(DisasContext * dc)
tcg_gen_helper_1_1(helper_tick_get_count, cpu_T[0],
r_tickptr);
gen_movl_T0_reg(rd);
+ tcg_gen_discard_ptr(r_tickptr);
}
break;
case 0x19: /* System tick compare */
@@ -2167,6 +2048,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tsptr));
tcg_gen_ld_tl(cpu_T[0], r_tsptr,
offsetof(trap_state, tpc));
+ tcg_gen_discard_ptr(r_tsptr);
}
break;
case 1: // tnpc
@@ -2178,6 +2060,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tsptr));
tcg_gen_ld_tl(cpu_T[0], r_tsptr,
offsetof(trap_state, tnpc));
+ tcg_gen_discard_ptr(r_tsptr);
}
break;
case 2: // tstate
@@ -2189,6 +2072,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tsptr));
tcg_gen_ld_tl(cpu_T[0], r_tsptr,
offsetof(trap_state, tstate));
+ tcg_gen_discard_ptr(r_tsptr);
}
break;
case 3: // tt
@@ -2200,6 +2084,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tsptr));
tcg_gen_ld_i32(cpu_T[0], r_tsptr,
offsetof(trap_state, tt));
+ tcg_gen_discard_ptr(r_tsptr);
}
break;
case 4: // tick
@@ -2212,6 +2097,7 @@ static void disas_sparc_insn(DisasContext * dc)
tcg_gen_helper_1_1(helper_tick_get_count, cpu_T[0],
r_tickptr);
gen_movl_T0_reg(rd);
+ tcg_gen_discard_ptr(r_tickptr);
}
break;
case 5: // tba
@@ -2659,44 +2545,41 @@ static void disas_sparc_insn(DisasContext * dc)
xop = GET_FIELD(insn, 18, 26);
#ifdef TARGET_SPARC64
if ((xop & 0x11f) == 0x005) { // V9 fmovsr
- TCGv r_zero;
int l1;
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
cond = GET_FIELD_SP(insn, 14, 17);
rs1 = GET_FIELD(insn, 13, 17);
gen_movl_reg_T0(rs1);
- tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1);
+ tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0],
+ tcg_const_tl(0), l1);
gen_op_load_fpr_FT0(rs2);
gen_op_store_FT0_fpr(rd);
gen_set_label(l1);
break;
} else if ((xop & 0x11f) == 0x006) { // V9 fmovdr
- TCGv r_zero;
int l1;
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
cond = GET_FIELD_SP(insn, 14, 17);
rs1 = GET_FIELD(insn, 13, 17);
gen_movl_reg_T0(rs1);
- tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1);
+ tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0],
+ tcg_const_tl(0), l1);
gen_op_load_fpr_DT0(DFPREG(rs2));
gen_op_store_DT0_fpr(DFPREG(rd));
gen_set_label(l1);
break;
} else if ((xop & 0x11f) == 0x007) { // V9 fmovqr
#if defined(CONFIG_USER_ONLY)
- TCGv r_zero;
int l1;
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
cond = GET_FIELD_SP(insn, 14, 17);
rs1 = GET_FIELD(insn, 13, 17);
gen_movl_reg_T0(rs1);
- tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1);
+ tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0],
+ tcg_const_tl(0), l1);
gen_op_load_fpr_QT0(QFPREG(rs2));
gen_op_store_QT0_fpr(QFPREG(rd));
gen_set_label(l1);
@@ -2710,18 +2593,19 @@ static void disas_sparc_insn(DisasContext * dc)
#ifdef TARGET_SPARC64
#define FMOVCC(size_FDQ, fcc) \
{ \
- TCGv r_zero, r_cond; \
+ TCGv r_cond; \
int l1; \
\
l1 = gen_new_label(); \
- r_zero = tcg_const_tl(0); \
r_cond = tcg_temp_new(TCG_TYPE_TL); \
cond = GET_FIELD_SP(insn, 14, 17); \
gen_fcond(r_cond, fcc, cond); \
- tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, r_zero, l1); \
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, \
+ tcg_const_tl(0), l1); \
glue(glue(gen_op_load_fpr_, size_FDQ), T0)(glue(size_FDQ, FPREG(rs2))); \
glue(glue(gen_op_store_, size_FDQ), T0_fpr)(glue(size_FDQ, FPREG(rd))); \
gen_set_label(l1); \
+ tcg_gen_discard_tl(r_cond); \
}
case 0x001: /* V9 fmovscc %fcc0 */
FMOVCC(F, 0);
@@ -2778,18 +2662,19 @@ static void disas_sparc_insn(DisasContext * dc)
#undef FMOVCC
#define FMOVCC(size_FDQ, icc) \
{ \
- TCGv r_zero, r_cond; \
+ TCGv r_cond; \
int l1; \
\
l1 = gen_new_label(); \
- r_zero = tcg_const_tl(0); \
r_cond = tcg_temp_new(TCG_TYPE_TL); \
cond = GET_FIELD_SP(insn, 14, 17); \
gen_cond(r_cond, icc, cond); \
- tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, r_zero, l1); \
+ tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, \
+ tcg_const_tl(0), l1); \
glue(glue(gen_op_load_fpr_, size_FDQ), T0)(glue(size_FDQ, FPREG(rs2))); \
glue(glue(gen_op_store_, size_FDQ), T0_fpr)(glue(size_FDQ, FPREG(rd))); \
gen_set_label(l1); \
+ tcg_gen_discard_tl(r_cond); \
}
case 0x101: /* V9 fmovscc %icc */
@@ -3178,6 +3063,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tick));
tcg_gen_helper_0_2(helper_tick_set_limit,
r_tickptr, cpu_T[0]);
+ tcg_gen_discard_ptr(r_tickptr);
}
break;
case 0x18: /* System tick */
@@ -3194,6 +3080,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, stick));
tcg_gen_helper_0_2(helper_tick_set_count,
r_tickptr, cpu_T[0]);
+ tcg_gen_discard_ptr(r_tickptr);
}
break;
case 0x19: /* System tick compare */
@@ -3212,6 +3099,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, stick));
tcg_gen_helper_0_2(helper_tick_set_limit,
r_tickptr, cpu_T[0]);
+ tcg_gen_discard_ptr(r_tickptr);
}
break;
@@ -3274,6 +3162,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tsptr));
tcg_gen_st_tl(cpu_T[0], r_tsptr,
offsetof(trap_state, tpc));
+ tcg_gen_discard_ptr(r_tsptr);
}
break;
case 1: // tnpc
@@ -3285,6 +3174,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tsptr));
tcg_gen_st_tl(cpu_T[0], r_tsptr,
offsetof(trap_state, tnpc));
+ tcg_gen_discard_ptr(r_tsptr);
}
break;
case 2: // tstate
@@ -3296,6 +3186,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tsptr));
tcg_gen_st_tl(cpu_T[0], r_tsptr,
offsetof(trap_state, tstate));
+ tcg_gen_discard_ptr(r_tsptr);
}
break;
case 3: // tt
@@ -3307,6 +3198,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tsptr));
tcg_gen_st_i32(cpu_T[0], r_tsptr,
offsetof(trap_state, tt));
+ tcg_gen_discard_ptr(r_tsptr);
}
break;
case 4: // tick
@@ -3318,6 +3210,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, tick));
tcg_gen_helper_0_2(helper_tick_set_count,
r_tickptr, cpu_T[0]);
+ tcg_gen_discard_ptr(r_tickptr);
}
break;
case 5: // tba
@@ -3410,6 +3303,7 @@ static void disas_sparc_insn(DisasContext * dc)
offsetof(CPUState, hstick));
tcg_gen_helper_0_2(helper_tick_set_limit,
r_tickptr, cpu_T[0]);
+ tcg_gen_discard_ptr(r_tickptr);
}
break;
case 6: // hver readonly
@@ -3453,6 +3347,7 @@ static void disas_sparc_insn(DisasContext * dc)
}
gen_movl_T1_reg(rd);
gen_set_label(l1);
+ tcg_gen_discard_tl(r_cond);
break;
}
case 0x2d: /* V9 sdivx */
@@ -3477,7 +3372,6 @@ static void disas_sparc_insn(DisasContext * dc)
case 0x2f: /* V9 movr */
{
int cond = GET_FIELD_SP(insn, 10, 12);
- TCGv r_zero;
int l1;
rs1 = GET_FIELD(insn, 13, 17);
@@ -3485,8 +3379,8 @@ static void disas_sparc_insn(DisasContext * dc)
l1 = gen_new_label();
- r_zero = tcg_const_tl(0);
- tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1);
+ tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0],
+ tcg_const_tl(0), l1);
if (IS_IMM) { /* immediate */
rs2 = GET_FIELD_SPs(insn, 0, 9);
gen_movl_simm_T1(rs2);
@@ -4077,6 +3971,7 @@ static void disas_sparc_insn(DisasContext * dc)
gen_movl_T0_reg(rd + 1);
tcg_gen_shri_i64(r_dword, r_dword, 32);
tcg_gen_trunc_i64_i32(cpu_T[1], r_dword);
+ tcg_gen_discard_i64(r_dword);
}
break;
case 0x9: /* load signed byte */
@@ -4302,6 +4197,7 @@ static void disas_sparc_insn(DisasContext * dc)
tcg_gen_helper_1_2(helper_pack64, r_dword, cpu_T[1],
r_low);
tcg_gen_qemu_st64(r_dword, cpu_T[0], dc->mem_idx);
+ tcg_gen_discard_i64(r_dword);
}
#else /* __i386__ */
gen_op_check_align_T0_7();
@@ -4350,32 +4246,8 @@ static void disas_sparc_insn(DisasContext * dc)
if (rd & 1)
goto illegal_insn;
else {
- int asi;
- TCGv r_dword, r_temp, r_size;
-
gen_op_check_align_T0_7();
- r_dword = tcg_temp_new(TCG_TYPE_I64);
- r_temp = tcg_temp_new(TCG_TYPE_I32);
- r_size = tcg_temp_new(TCG_TYPE_I32);
- gen_movl_reg_TN(rd + 1, r_temp);
- tcg_gen_helper_1_2(helper_pack64, r_dword, cpu_T[1],
- r_temp);
-#ifdef TARGET_SPARC64
- if (IS_IMM) {
- int offset;
-
- offset = GET_FIELD(insn, 25, 31);
- tcg_gen_addi_tl(cpu_T[0], cpu_T[0], offset);
- tcg_gen_ld_i32(r_dword, cpu_env, offsetof(CPUSPARCState, asi));
- } else {
-#endif
- asi = GET_FIELD(insn, 19, 26);
- tcg_gen_movi_i32(r_temp, asi);
-#ifdef TARGET_SPARC64
- }
-#endif
- tcg_gen_movi_i32(r_size, 8);
- tcg_gen_helper_0_4(helper_st_asi, cpu_T[0], r_dword, r_temp, r_size);
+ gen_stda_asi(insn, rd);
}
break;
#endif