target/hppa: Use gva_offset_mask() everywhere
Move it to cpu.h, so it can also be used in hppa_form_gva_psw(). Signed-off-by: Sven Schnelle <svens@stackframe.org> Reviewed-by: Helge Deller <deller@gmx.de> Reviewed-by: Richard Henderson <richard.henderson@linaro.org> Message-Id: <20240324080945.991100-2-svens@stackframe.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org>
This commit is contained in:
parent
6ebebea758
commit
7d50b69660
@ -285,14 +285,20 @@ void hppa_translate_init(void);
|
||||
|
||||
#define CPU_RESOLVING_TYPE TYPE_HPPA_CPU
|
||||
|
||||
static inline uint64_t gva_offset_mask(target_ulong psw)
|
||||
{
|
||||
return (psw & PSW_W
|
||||
? MAKE_64BIT_MASK(0, 62)
|
||||
: MAKE_64BIT_MASK(0, 32));
|
||||
}
|
||||
|
||||
static inline target_ulong hppa_form_gva_psw(target_ulong psw, uint64_t spc,
|
||||
target_ulong off)
|
||||
{
|
||||
#ifdef CONFIG_USER_ONLY
|
||||
return off;
|
||||
#else
|
||||
off &= psw & PSW_W ? MAKE_64BIT_MASK(0, 62) : MAKE_64BIT_MASK(0, 32);
|
||||
return spc | off;
|
||||
return spc | (off & gva_offset_mask(psw));
|
||||
#endif
|
||||
}
|
||||
|
||||
|
@ -586,17 +586,10 @@ static bool nullify_end(DisasContext *ctx)
|
||||
return true;
|
||||
}
|
||||
|
||||
static uint64_t gva_offset_mask(DisasContext *ctx)
|
||||
{
|
||||
return (ctx->tb_flags & PSW_W
|
||||
? MAKE_64BIT_MASK(0, 62)
|
||||
: MAKE_64BIT_MASK(0, 32));
|
||||
}
|
||||
|
||||
static void copy_iaoq_entry(DisasContext *ctx, TCGv_i64 dest,
|
||||
uint64_t ival, TCGv_i64 vval)
|
||||
{
|
||||
uint64_t mask = gva_offset_mask(ctx);
|
||||
uint64_t mask = gva_offset_mask(ctx->tb_flags);
|
||||
|
||||
if (ival != -1) {
|
||||
tcg_gen_movi_i64(dest, ival & mask);
|
||||
@ -1430,7 +1423,8 @@ static void form_gva(DisasContext *ctx, TCGv_i64 *pgva, TCGv_i64 *pofs,
|
||||
|
||||
*pofs = ofs;
|
||||
*pgva = addr = tcg_temp_new_i64();
|
||||
tcg_gen_andi_i64(addr, modify <= 0 ? ofs : base, gva_offset_mask(ctx));
|
||||
tcg_gen_andi_i64(addr, modify <= 0 ? ofs : base,
|
||||
gva_offset_mask(ctx->tb_flags));
|
||||
#ifndef CONFIG_USER_ONLY
|
||||
if (!is_phys) {
|
||||
tcg_gen_or_i64(addr, addr, space_select(ctx, sp, base));
|
||||
|
Loading…
Reference in New Issue
Block a user