mirror of
https://gitlab.com/qemu-project/qemu
synced 2024-11-05 20:35:44 +00:00
target/hppa: Avoid use of tcg_const_i32 throughout
All uses were read-write, so replace with a new allocation and initialization. Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
a300dad3e8
commit
0992a93013
1 changed files with 11 additions and 10 deletions
|
@ -135,8 +135,6 @@
|
|||
#define tcg_gen_extract_reg tcg_gen_extract_i64
|
||||
#define tcg_gen_sextract_reg tcg_gen_sextract_i64
|
||||
#define tcg_gen_extract2_reg tcg_gen_extract2_i64
|
||||
#define tcg_const_reg tcg_const_i64
|
||||
#define tcg_const_local_reg tcg_const_local_i64
|
||||
#define tcg_constant_reg tcg_constant_i64
|
||||
#define tcg_gen_movcond_reg tcg_gen_movcond_i64
|
||||
#define tcg_gen_add2_reg tcg_gen_add2_i64
|
||||
|
@ -228,8 +226,6 @@
|
|||
#define tcg_gen_extract_reg tcg_gen_extract_i32
|
||||
#define tcg_gen_sextract_reg tcg_gen_sextract_i32
|
||||
#define tcg_gen_extract2_reg tcg_gen_extract2_i32
|
||||
#define tcg_const_reg tcg_const_i32
|
||||
#define tcg_const_local_reg tcg_const_local_i32
|
||||
#define tcg_constant_reg tcg_constant_i32
|
||||
#define tcg_gen_movcond_reg tcg_gen_movcond_i32
|
||||
#define tcg_gen_add2_reg tcg_gen_add2_i32
|
||||
|
@ -574,7 +570,9 @@ static TCGv_i32 load_frw_i32(unsigned rt)
|
|||
static TCGv_i32 load_frw0_i32(unsigned rt)
|
||||
{
|
||||
if (rt == 0) {
|
||||
return tcg_const_i32(0);
|
||||
TCGv_i32 ret = tcg_temp_new_i32();
|
||||
tcg_gen_movi_i32(ret, 0);
|
||||
return ret;
|
||||
} else {
|
||||
return load_frw_i32(rt);
|
||||
}
|
||||
|
@ -582,15 +580,15 @@ static TCGv_i32 load_frw0_i32(unsigned rt)
|
|||
|
||||
static TCGv_i64 load_frw0_i64(unsigned rt)
|
||||
{
|
||||
TCGv_i64 ret = tcg_temp_new_i64();
|
||||
if (rt == 0) {
|
||||
return tcg_const_i64(0);
|
||||
tcg_gen_movi_i64(ret, 0);
|
||||
} else {
|
||||
TCGv_i64 ret = tcg_temp_new_i64();
|
||||
tcg_gen_ld32u_i64(ret, cpu_env,
|
||||
offsetof(CPUHPPAState, fr[rt & 31])
|
||||
+ (rt & 32 ? LO_OFS : HI_OFS));
|
||||
return ret;
|
||||
}
|
||||
return ret;
|
||||
}
|
||||
|
||||
static void save_frw_i32(unsigned rt, TCGv_i32 val)
|
||||
|
@ -613,7 +611,9 @@ static TCGv_i64 load_frd(unsigned rt)
|
|||
static TCGv_i64 load_frd0(unsigned rt)
|
||||
{
|
||||
if (rt == 0) {
|
||||
return tcg_const_i64(0);
|
||||
TCGv_i64 ret = tcg_temp_new_i64();
|
||||
tcg_gen_movi_i64(ret, 0);
|
||||
return ret;
|
||||
} else {
|
||||
return load_frd(rt);
|
||||
}
|
||||
|
@ -3330,7 +3330,8 @@ static bool do_depw_sar(DisasContext *ctx, unsigned rt, unsigned c,
|
|||
/* Convert big-endian bit numbering in SAR to left-shift. */
|
||||
tcg_gen_xori_reg(shift, cpu_sar, TARGET_REGISTER_BITS - 1);
|
||||
|
||||
mask = tcg_const_reg(msb + (msb - 1));
|
||||
mask = tcg_temp_new();
|
||||
tcg_gen_movi_reg(mask, msb + (msb - 1));
|
||||
tcg_gen_and_reg(tmp, val, mask);
|
||||
if (rs) {
|
||||
tcg_gen_shl_reg(mask, mask, shift);
|
||||
|
|
Loading…
Reference in a new issue