diff options
Diffstat (limited to 'target-sparc')
-rw-r--r-- | target-sparc/translate.c | 61 |
1 files changed, 19 insertions, 42 deletions
diff --git a/target-sparc/translate.c b/target-sparc/translate.c index 3225b8a152..c188bcc282 100644 --- a/target-sparc/translate.c +++ b/target-sparc/translate.c @@ -389,8 +389,7 @@ static inline void gen_cc_NZ(TCGv dst) l1 = gen_new_label(); l2 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + r_zero = tcg_const_tl(0); tcg_gen_brcond_i32(TCG_COND_NE, dst, r_zero, l1); tcg_gen_ori_i32(cpu_psr, cpu_psr, PSR_ZERO); gen_set_label(l1); @@ -451,8 +450,7 @@ static inline void gen_cc_V_add(TCGv dst, TCGv src1, TCGv src2) 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_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + 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); @@ -466,7 +464,6 @@ static inline void gen_cc_V_add(TCGv dst, TCGv src1, TCGv src2) int l2; l2 = gen_new_label(); - tcg_gen_movi_tl(r_zero, 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); @@ -489,8 +486,7 @@ static inline void gen_add_tv(TCGv dst, TCGv src1, TCGv src2) 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_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + 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); @@ -504,7 +500,6 @@ static inline void gen_add_tv(TCGv dst, TCGv src1, TCGv src2) int l2; l2 = gen_new_label(); - tcg_gen_movi_tl(r_zero, 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); @@ -523,9 +518,8 @@ static inline void gen_cc_V_tag(TCGv src1, TCGv src2) TCGv r_zero, r_temp; l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); + r_zero = tcg_const_tl(0); r_temp = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); 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); @@ -539,9 +533,8 @@ static inline void gen_tag_tv(TCGv src1, TCGv src2) TCGv r_zero, r_temp; l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); + r_zero = tcg_const_tl(0); r_temp = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); 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); @@ -632,8 +625,7 @@ static inline void gen_cc_V_sub(TCGv dst, TCGv src1, TCGv src2) 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_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + 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); @@ -646,7 +638,6 @@ static inline void gen_cc_V_sub(TCGv dst, TCGv src1, TCGv src2) int l2; l2 = gen_new_label(); - tcg_gen_movi_tl(r_zero, 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); @@ -668,8 +659,7 @@ static inline void gen_sub_tv(TCGv dst, TCGv src1, TCGv src2) 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_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + 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); @@ -682,7 +672,6 @@ static inline void gen_sub_tv(TCGv dst, TCGv src1, TCGv src2) int l2; l2 = gen_new_label(); - tcg_gen_movi_tl(r_zero, 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); @@ -747,8 +736,7 @@ static inline void gen_op_div_cc(void) gen_cc_clear(); gen_cc_NZ(cpu_T[0]); l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + r_zero = tcg_const_tl(0); tcg_gen_brcond_i32(TCG_COND_EQ, cpu_T[1], r_zero, l1); tcg_gen_ori_i32(cpu_psr, cpu_psr, PSR_OVF); gen_set_label(l1); @@ -1084,8 +1072,7 @@ static inline void gen_branch2(DisasContext *dc, target_ulong pc1, int l1; l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + r_zero = tcg_const_tl(0); tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, r_zero, l1); @@ -1102,8 +1089,7 @@ static inline void gen_branch_a(DisasContext *dc, target_ulong pc1, int l1; l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + r_zero = tcg_const_tl(0); tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, r_zero, l1); @@ -1127,8 +1113,7 @@ static inline void gen_generic_branch(target_ulong npc1, target_ulong npc2, l1 = gen_new_label(); l2 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + r_zero = tcg_const_tl(0); tcg_gen_brcond_tl(TCG_COND_EQ, r_cond, r_zero, l1); @@ -1348,8 +1333,7 @@ static inline void gen_cond_reg(TCGv r_dst, int cond) int l1; l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + 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, 1); @@ -2658,11 +2642,10 @@ static void disas_sparc_insn(DisasContext * dc) int l1; l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); + 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_movi_tl(r_zero, 0); tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1); gen_op_load_fpr_FT0(rs2); gen_op_store_FT0_fpr(rd); @@ -2673,11 +2656,10 @@ static void disas_sparc_insn(DisasContext * dc) int l1; l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); + 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_movi_tl(r_zero, 0); tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1); gen_op_load_fpr_DT0(DFPREG(rs2)); gen_op_store_DT0_fpr(DFPREG(rd)); @@ -2689,11 +2671,10 @@ static void disas_sparc_insn(DisasContext * dc) int l1; l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); + 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_movi_tl(r_zero, 0); tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1); gen_op_load_fpr_QT0(QFPREG(rs2)); gen_op_store_QT0_fpr(QFPREG(rd)); @@ -2712,9 +2693,8 @@ static void disas_sparc_insn(DisasContext * dc) int l1; \ \ l1 = gen_new_label(); \ - r_zero = tcg_temp_new(TCG_TYPE_TL); \ + r_zero = tcg_const_tl(0); \ r_cond = tcg_temp_new(TCG_TYPE_TL); \ - tcg_gen_movi_tl(r_zero, 0); \ 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); \ @@ -2781,9 +2761,8 @@ static void disas_sparc_insn(DisasContext * dc) int l1; \ \ l1 = gen_new_label(); \ - r_zero = tcg_temp_new(TCG_TYPE_TL); \ + r_zero = tcg_const_tl(0); \ r_cond = tcg_temp_new(TCG_TYPE_TL); \ - tcg_gen_movi_tl(r_zero, 0); \ 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); \ @@ -3441,8 +3420,7 @@ static void disas_sparc_insn(DisasContext * dc) l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + r_zero = tcg_const_tl(0); tcg_gen_brcond_tl(TCG_COND_EQ, cpu_T[2], r_zero, l1); if (IS_IMM) { /* immediate */ rs2 = GET_FIELD_SPs(insn, 0, 10); @@ -3485,8 +3463,7 @@ static void disas_sparc_insn(DisasContext * dc) l1 = gen_new_label(); - r_zero = tcg_temp_new(TCG_TYPE_TL); - tcg_gen_movi_tl(r_zero, 0); + r_zero = tcg_const_tl(0); tcg_gen_brcond_tl(gen_tcg_cond_reg[cond], cpu_T[0], r_zero, l1); if (IS_IMM) { /* immediate */ rs2 = GET_FIELD_SPs(insn, 0, 9); |