target/arm: Use tcg_constant in translate-neon.c
Use tcg_constant_{i32,i64} as appropriate throughout. Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
01d90db599
commit
d9b47e97e7
@ -447,7 +447,7 @@ static bool trans_VLDST_multiple(DisasContext *s, arg_VLDST_multiple *a)
|
|||||||
int mmu_idx = get_mem_index(s);
|
int mmu_idx = get_mem_index(s);
|
||||||
int size = a->size;
|
int size = a->size;
|
||||||
TCGv_i64 tmp64;
|
TCGv_i64 tmp64;
|
||||||
TCGv_i32 addr, tmp;
|
TCGv_i32 addr;
|
||||||
|
|
||||||
if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
|
if (!arm_dc_feature(s, ARM_FEATURE_NEON)) {
|
||||||
return false;
|
return false;
|
||||||
@ -513,7 +513,6 @@ static bool trans_VLDST_multiple(DisasContext *s, arg_VLDST_multiple *a)
|
|||||||
|
|
||||||
tmp64 = tcg_temp_new_i64();
|
tmp64 = tcg_temp_new_i64();
|
||||||
addr = tcg_temp_new_i32();
|
addr = tcg_temp_new_i32();
|
||||||
tmp = tcg_const_i32(1 << size);
|
|
||||||
load_reg_var(s, addr, a->rn);
|
load_reg_var(s, addr, a->rn);
|
||||||
|
|
||||||
mop = endian | size | align;
|
mop = endian | size | align;
|
||||||
@ -530,7 +529,7 @@ static bool trans_VLDST_multiple(DisasContext *s, arg_VLDST_multiple *a)
|
|||||||
neon_load_element64(tmp64, tt, n, size);
|
neon_load_element64(tmp64, tt, n, size);
|
||||||
gen_aa32_st_internal_i64(s, tmp64, addr, mmu_idx, mop);
|
gen_aa32_st_internal_i64(s, tmp64, addr, mmu_idx, mop);
|
||||||
}
|
}
|
||||||
tcg_gen_add_i32(addr, addr, tmp);
|
tcg_gen_addi_i32(addr, addr, 1 << size);
|
||||||
|
|
||||||
/* Subsequent memory operations inherit alignment */
|
/* Subsequent memory operations inherit alignment */
|
||||||
mop &= ~MO_AMASK;
|
mop &= ~MO_AMASK;
|
||||||
@ -538,7 +537,6 @@ static bool trans_VLDST_multiple(DisasContext *s, arg_VLDST_multiple *a)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
tcg_temp_free_i32(addr);
|
tcg_temp_free_i32(addr);
|
||||||
tcg_temp_free_i32(tmp);
|
|
||||||
tcg_temp_free_i64(tmp64);
|
tcg_temp_free_i64(tmp64);
|
||||||
|
|
||||||
gen_neon_ldst_base_update(s, a->rm, a->rn, nregs * interleave * 8);
|
gen_neon_ldst_base_update(s, a->rm, a->rn, nregs * interleave * 8);
|
||||||
@ -1348,7 +1346,7 @@ static bool do_2shift_env_64(DisasContext *s, arg_2reg_shift *a,
|
|||||||
* To avoid excessive duplication of ops we implement shift
|
* To avoid excessive duplication of ops we implement shift
|
||||||
* by immediate using the variable shift operations.
|
* by immediate using the variable shift operations.
|
||||||
*/
|
*/
|
||||||
constimm = tcg_const_i64(dup_const(a->size, a->shift));
|
constimm = tcg_constant_i64(dup_const(a->size, a->shift));
|
||||||
|
|
||||||
for (pass = 0; pass < a->q + 1; pass++) {
|
for (pass = 0; pass < a->q + 1; pass++) {
|
||||||
TCGv_i64 tmp = tcg_temp_new_i64();
|
TCGv_i64 tmp = tcg_temp_new_i64();
|
||||||
@ -1358,7 +1356,6 @@ static bool do_2shift_env_64(DisasContext *s, arg_2reg_shift *a,
|
|||||||
write_neon_element64(tmp, a->vd, pass, MO_64);
|
write_neon_element64(tmp, a->vd, pass, MO_64);
|
||||||
tcg_temp_free_i64(tmp);
|
tcg_temp_free_i64(tmp);
|
||||||
}
|
}
|
||||||
tcg_temp_free_i64(constimm);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1394,7 +1391,7 @@ static bool do_2shift_env_32(DisasContext *s, arg_2reg_shift *a,
|
|||||||
* To avoid excessive duplication of ops we implement shift
|
* To avoid excessive duplication of ops we implement shift
|
||||||
* by immediate using the variable shift operations.
|
* by immediate using the variable shift operations.
|
||||||
*/
|
*/
|
||||||
constimm = tcg_const_i32(dup_const(a->size, a->shift));
|
constimm = tcg_constant_i32(dup_const(a->size, a->shift));
|
||||||
tmp = tcg_temp_new_i32();
|
tmp = tcg_temp_new_i32();
|
||||||
|
|
||||||
for (pass = 0; pass < (a->q ? 4 : 2); pass++) {
|
for (pass = 0; pass < (a->q ? 4 : 2); pass++) {
|
||||||
@ -1403,7 +1400,6 @@ static bool do_2shift_env_32(DisasContext *s, arg_2reg_shift *a,
|
|||||||
write_neon_element32(tmp, a->vd, pass, MO_32);
|
write_neon_element32(tmp, a->vd, pass, MO_32);
|
||||||
}
|
}
|
||||||
tcg_temp_free_i32(tmp);
|
tcg_temp_free_i32(tmp);
|
||||||
tcg_temp_free_i32(constimm);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1457,7 +1453,7 @@ static bool do_2shift_narrow_64(DisasContext *s, arg_2reg_shift *a,
|
|||||||
* This is always a right shift, and the shiftfn is always a
|
* This is always a right shift, and the shiftfn is always a
|
||||||
* left-shift helper, which thus needs the negated shift count.
|
* left-shift helper, which thus needs the negated shift count.
|
||||||
*/
|
*/
|
||||||
constimm = tcg_const_i64(-a->shift);
|
constimm = tcg_constant_i64(-a->shift);
|
||||||
rm1 = tcg_temp_new_i64();
|
rm1 = tcg_temp_new_i64();
|
||||||
rm2 = tcg_temp_new_i64();
|
rm2 = tcg_temp_new_i64();
|
||||||
rd = tcg_temp_new_i32();
|
rd = tcg_temp_new_i32();
|
||||||
@ -1477,7 +1473,6 @@ static bool do_2shift_narrow_64(DisasContext *s, arg_2reg_shift *a,
|
|||||||
tcg_temp_free_i32(rd);
|
tcg_temp_free_i32(rd);
|
||||||
tcg_temp_free_i64(rm1);
|
tcg_temp_free_i64(rm1);
|
||||||
tcg_temp_free_i64(rm2);
|
tcg_temp_free_i64(rm2);
|
||||||
tcg_temp_free_i64(constimm);
|
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
@ -1521,7 +1516,7 @@ static bool do_2shift_narrow_32(DisasContext *s, arg_2reg_shift *a,
|
|||||||
/* size == 2 */
|
/* size == 2 */
|
||||||
imm = -a->shift;
|
imm = -a->shift;
|
||||||
}
|
}
|
||||||
constimm = tcg_const_i32(imm);
|
constimm = tcg_constant_i32(imm);
|
||||||
|
|
||||||
/* Load all inputs first to avoid potential overwrite */
|
/* Load all inputs first to avoid potential overwrite */
|
||||||
rm1 = tcg_temp_new_i32();
|
rm1 = tcg_temp_new_i32();
|
||||||
@ -1546,7 +1541,6 @@ static bool do_2shift_narrow_32(DisasContext *s, arg_2reg_shift *a,
|
|||||||
|
|
||||||
shiftfn(rm3, rm3, constimm);
|
shiftfn(rm3, rm3, constimm);
|
||||||
shiftfn(rm4, rm4, constimm);
|
shiftfn(rm4, rm4, constimm);
|
||||||
tcg_temp_free_i32(constimm);
|
|
||||||
|
|
||||||
tcg_gen_concat_i32_i64(rtmp, rm3, rm4);
|
tcg_gen_concat_i32_i64(rtmp, rm3, rm4);
|
||||||
tcg_temp_free_i32(rm4);
|
tcg_temp_free_i32(rm4);
|
||||||
@ -2911,7 +2905,7 @@ static bool trans_VTBL(DisasContext *s, arg_VTBL *a)
|
|||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
desc = tcg_const_i32((a->vn << 2) | a->len);
|
desc = tcg_constant_i32((a->vn << 2) | a->len);
|
||||||
def = tcg_temp_new_i64();
|
def = tcg_temp_new_i64();
|
||||||
if (a->op) {
|
if (a->op) {
|
||||||
read_neon_element64(def, a->vd, 0, MO_64);
|
read_neon_element64(def, a->vd, 0, MO_64);
|
||||||
@ -2926,7 +2920,6 @@ static bool trans_VTBL(DisasContext *s, arg_VTBL *a)
|
|||||||
|
|
||||||
tcg_temp_free_i64(def);
|
tcg_temp_free_i64(def);
|
||||||
tcg_temp_free_i64(val);
|
tcg_temp_free_i64(val);
|
||||||
tcg_temp_free_i32(desc);
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user