mirror of https://github.com/xemu-project/xemu.git
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
|
@ -135,8 +135,6 @@
|
||||||
#define tcg_gen_extract_reg tcg_gen_extract_i64
|
#define tcg_gen_extract_reg tcg_gen_extract_i64
|
||||||
#define tcg_gen_sextract_reg tcg_gen_sextract_i64
|
#define tcg_gen_sextract_reg tcg_gen_sextract_i64
|
||||||
#define tcg_gen_extract2_reg tcg_gen_extract2_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_constant_reg tcg_constant_i64
|
||||||
#define tcg_gen_movcond_reg tcg_gen_movcond_i64
|
#define tcg_gen_movcond_reg tcg_gen_movcond_i64
|
||||||
#define tcg_gen_add2_reg tcg_gen_add2_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_extract_reg tcg_gen_extract_i32
|
||||||
#define tcg_gen_sextract_reg tcg_gen_sextract_i32
|
#define tcg_gen_sextract_reg tcg_gen_sextract_i32
|
||||||
#define tcg_gen_extract2_reg tcg_gen_extract2_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_constant_reg tcg_constant_i32
|
||||||
#define tcg_gen_movcond_reg tcg_gen_movcond_i32
|
#define tcg_gen_movcond_reg tcg_gen_movcond_i32
|
||||||
#define tcg_gen_add2_reg tcg_gen_add2_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)
|
static TCGv_i32 load_frw0_i32(unsigned rt)
|
||||||
{
|
{
|
||||||
if (rt == 0) {
|
if (rt == 0) {
|
||||||
return tcg_const_i32(0);
|
TCGv_i32 ret = tcg_temp_new_i32();
|
||||||
|
tcg_gen_movi_i32(ret, 0);
|
||||||
|
return ret;
|
||||||
} else {
|
} else {
|
||||||
return load_frw_i32(rt);
|
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)
|
static TCGv_i64 load_frw0_i64(unsigned rt)
|
||||||
{
|
{
|
||||||
|
TCGv_i64 ret = tcg_temp_new_i64();
|
||||||
if (rt == 0) {
|
if (rt == 0) {
|
||||||
return tcg_const_i64(0);
|
tcg_gen_movi_i64(ret, 0);
|
||||||
} else {
|
} else {
|
||||||
TCGv_i64 ret = tcg_temp_new_i64();
|
|
||||||
tcg_gen_ld32u_i64(ret, cpu_env,
|
tcg_gen_ld32u_i64(ret, cpu_env,
|
||||||
offsetof(CPUHPPAState, fr[rt & 31])
|
offsetof(CPUHPPAState, fr[rt & 31])
|
||||||
+ (rt & 32 ? LO_OFS : HI_OFS));
|
+ (rt & 32 ? LO_OFS : HI_OFS));
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
return ret;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void save_frw_i32(unsigned rt, TCGv_i32 val)
|
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)
|
static TCGv_i64 load_frd0(unsigned rt)
|
||||||
{
|
{
|
||||||
if (rt == 0) {
|
if (rt == 0) {
|
||||||
return tcg_const_i64(0);
|
TCGv_i64 ret = tcg_temp_new_i64();
|
||||||
|
tcg_gen_movi_i64(ret, 0);
|
||||||
|
return ret;
|
||||||
} else {
|
} else {
|
||||||
return load_frd(rt);
|
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. */
|
/* Convert big-endian bit numbering in SAR to left-shift. */
|
||||||
tcg_gen_xori_reg(shift, cpu_sar, TARGET_REGISTER_BITS - 1);
|
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);
|
tcg_gen_and_reg(tmp, val, mask);
|
||||||
if (rs) {
|
if (rs) {
|
||||||
tcg_gen_shl_reg(mask, mask, shift);
|
tcg_gen_shl_reg(mask, mask, shift);
|
||||||
|
|
Loading…
Reference in New Issue