target/arm: Remove fp_status_a64
Replace with fp_status[FPST_A64]. Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Message-id: 20250129013857.135256-14-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
828def800e
commit
1c349f43b1
@ -551,7 +551,7 @@ static void arm_cpu_reset_hold(Object *obj, ResetType type)
|
|||||||
set_default_nan_mode(1, &env->vfp.fp_status[FPST_STD]);
|
set_default_nan_mode(1, &env->vfp.fp_status[FPST_STD]);
|
||||||
set_default_nan_mode(1, &env->vfp.fp_status[FPST_STD_F16]);
|
set_default_nan_mode(1, &env->vfp.fp_status[FPST_STD_F16]);
|
||||||
arm_set_default_fp_behaviours(&env->vfp.fp_status_a32);
|
arm_set_default_fp_behaviours(&env->vfp.fp_status_a32);
|
||||||
arm_set_default_fp_behaviours(&env->vfp.fp_status_a64);
|
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_A64]);
|
||||||
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_STD]);
|
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_STD]);
|
||||||
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_A32_F16]);
|
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_A32_F16]);
|
||||||
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_A64_F16]);
|
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_A64_F16]);
|
||||||
|
@ -691,7 +691,6 @@ typedef struct CPUArchState {
|
|||||||
float_status fp_status[FPST_COUNT];
|
float_status fp_status[FPST_COUNT];
|
||||||
struct {
|
struct {
|
||||||
float_status fp_status_a32;
|
float_status fp_status_a32;
|
||||||
float_status fp_status_a64;
|
|
||||||
};
|
};
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1044,7 +1044,7 @@ void HELPER(sme_fmopa_h)(void *vza, void *vzn, void *vzm, void *vpn,
|
|||||||
* round-to-odd -- see above.
|
* round-to-odd -- see above.
|
||||||
*/
|
*/
|
||||||
fpst_f16 = env->vfp.fp_status[FPST_A64_F16];
|
fpst_f16 = env->vfp.fp_status[FPST_A64_F16];
|
||||||
fpst_std = env->vfp.fp_status_a64;
|
fpst_std = env->vfp.fp_status[FPST_A64];
|
||||||
set_default_nan_mode(true, &fpst_std);
|
set_default_nan_mode(true, &fpst_std);
|
||||||
set_default_nan_mode(true, &fpst_f16);
|
set_default_nan_mode(true, &fpst_f16);
|
||||||
fpst_odd = fpst_std;
|
fpst_odd = fpst_std;
|
||||||
|
@ -2172,7 +2172,7 @@ void HELPER(gvec_fmlal_a64)(void *vd, void *vn, void *vm,
|
|||||||
negx = 0x8000800080008000ull;
|
negx = 0x8000800080008000ull;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
do_fmlal(vd, vn, vm, &env->vfp.fp_status_a64, negx, negf, desc,
|
do_fmlal(vd, vn, vm, &env->vfp.fp_status[FPST_A64], negx, negf, desc,
|
||||||
get_flush_inputs_to_zero(&env->vfp.fp_status[FPST_A64_F16]));
|
get_flush_inputs_to_zero(&env->vfp.fp_status[FPST_A64_F16]));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2182,7 +2182,7 @@ void HELPER(sve2_fmlal_zzzw_s)(void *vd, void *vn, void *vm, void *va,
|
|||||||
intptr_t i, oprsz = simd_oprsz(desc);
|
intptr_t i, oprsz = simd_oprsz(desc);
|
||||||
bool is_s = extract32(desc, SIMD_DATA_SHIFT, 1);
|
bool is_s = extract32(desc, SIMD_DATA_SHIFT, 1);
|
||||||
intptr_t sel = extract32(desc, SIMD_DATA_SHIFT + 1, 1) * sizeof(float16);
|
intptr_t sel = extract32(desc, SIMD_DATA_SHIFT + 1, 1) * sizeof(float16);
|
||||||
float_status *status = &env->vfp.fp_status_a64;
|
float_status *status = &env->vfp.fp_status[FPST_A64];
|
||||||
bool fz16 = get_flush_inputs_to_zero(&env->vfp.fp_status[FPST_A64_F16]);
|
bool fz16 = get_flush_inputs_to_zero(&env->vfp.fp_status[FPST_A64_F16]);
|
||||||
int negx = 0, negf = 0;
|
int negx = 0, negf = 0;
|
||||||
|
|
||||||
@ -2253,7 +2253,7 @@ void HELPER(gvec_fmlal_idx_a64)(void *vd, void *vn, void *vm,
|
|||||||
negx = 0x8000800080008000ull;
|
negx = 0x8000800080008000ull;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
do_fmlal_idx(vd, vn, vm, &env->vfp.fp_status_a64, negx, negf, desc,
|
do_fmlal_idx(vd, vn, vm, &env->vfp.fp_status[FPST_A64], negx, negf, desc,
|
||||||
get_flush_inputs_to_zero(&env->vfp.fp_status[FPST_A64_F16]));
|
get_flush_inputs_to_zero(&env->vfp.fp_status[FPST_A64_F16]));
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -2264,7 +2264,7 @@ void HELPER(sve2_fmlal_zzxw_s)(void *vd, void *vn, void *vm, void *va,
|
|||||||
bool is_s = extract32(desc, SIMD_DATA_SHIFT, 1);
|
bool is_s = extract32(desc, SIMD_DATA_SHIFT, 1);
|
||||||
intptr_t sel = extract32(desc, SIMD_DATA_SHIFT + 1, 1) * sizeof(float16);
|
intptr_t sel = extract32(desc, SIMD_DATA_SHIFT + 1, 1) * sizeof(float16);
|
||||||
intptr_t idx = extract32(desc, SIMD_DATA_SHIFT + 2, 3) * sizeof(float16);
|
intptr_t idx = extract32(desc, SIMD_DATA_SHIFT + 2, 3) * sizeof(float16);
|
||||||
float_status *status = &env->vfp.fp_status_a64;
|
float_status *status = &env->vfp.fp_status[FPST_A64];
|
||||||
bool fz16 = get_flush_inputs_to_zero(&env->vfp.fp_status[FPST_A64_F16]);
|
bool fz16 = get_flush_inputs_to_zero(&env->vfp.fp_status[FPST_A64_F16]);
|
||||||
int negx = 0, negf = 0;
|
int negx = 0, negf = 0;
|
||||||
|
|
||||||
@ -2951,7 +2951,7 @@ bool is_ebf(CPUARMState *env, float_status *statusp, float_status *oddstatusp)
|
|||||||
*/
|
*/
|
||||||
bool ebf = is_a64(env) && env->vfp.fpcr & FPCR_EBF;
|
bool ebf = is_a64(env) && env->vfp.fpcr & FPCR_EBF;
|
||||||
|
|
||||||
*statusp = is_a64(env) ? env->vfp.fp_status_a64 : env->vfp.fp_status_a32;
|
*statusp = is_a64(env) ? env->vfp.fp_status[FPST_A64] : env->vfp.fp_status_a32;
|
||||||
set_default_nan_mode(true, statusp);
|
set_default_nan_mode(true, statusp);
|
||||||
|
|
||||||
if (ebf) {
|
if (ebf) {
|
||||||
|
@ -125,7 +125,7 @@ static uint32_t vfp_get_fpsr_from_host(CPUARMState *env)
|
|||||||
a32_flags |= (get_float_exception_flags(&env->vfp.fp_status[FPST_STD_F16])
|
a32_flags |= (get_float_exception_flags(&env->vfp.fp_status[FPST_STD_F16])
|
||||||
& ~float_flag_input_denormal_flushed);
|
& ~float_flag_input_denormal_flushed);
|
||||||
|
|
||||||
a64_flags |= get_float_exception_flags(&env->vfp.fp_status_a64);
|
a64_flags |= get_float_exception_flags(&env->vfp.fp_status[FPST_A64]);
|
||||||
a64_flags |= (get_float_exception_flags(&env->vfp.fp_status[FPST_A64_F16])
|
a64_flags |= (get_float_exception_flags(&env->vfp.fp_status[FPST_A64_F16])
|
||||||
& ~(float_flag_input_denormal_flushed | float_flag_input_denormal_used));
|
& ~(float_flag_input_denormal_flushed | float_flag_input_denormal_used));
|
||||||
/*
|
/*
|
||||||
@ -156,7 +156,7 @@ static void vfp_clear_float_status_exc_flags(CPUARMState *env)
|
|||||||
* be the architecturally up-to-date exception flag information first.
|
* be the architecturally up-to-date exception flag information first.
|
||||||
*/
|
*/
|
||||||
set_float_exception_flags(0, &env->vfp.fp_status_a32);
|
set_float_exception_flags(0, &env->vfp.fp_status_a32);
|
||||||
set_float_exception_flags(0, &env->vfp.fp_status_a64);
|
set_float_exception_flags(0, &env->vfp.fp_status[FPST_A64]);
|
||||||
set_float_exception_flags(0, &env->vfp.fp_status[FPST_A32_F16]);
|
set_float_exception_flags(0, &env->vfp.fp_status[FPST_A32_F16]);
|
||||||
set_float_exception_flags(0, &env->vfp.fp_status[FPST_A64_F16]);
|
set_float_exception_flags(0, &env->vfp.fp_status[FPST_A64_F16]);
|
||||||
set_float_exception_flags(0, &env->vfp.fp_status[FPST_STD]);
|
set_float_exception_flags(0, &env->vfp.fp_status[FPST_STD]);
|
||||||
@ -199,7 +199,7 @@ static void vfp_set_fpcr_to_host(CPUARMState *env, uint32_t val, uint32_t mask)
|
|||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
set_float_rounding_mode(i, &env->vfp.fp_status_a32);
|
set_float_rounding_mode(i, &env->vfp.fp_status_a32);
|
||||||
set_float_rounding_mode(i, &env->vfp.fp_status_a64);
|
set_float_rounding_mode(i, &env->vfp.fp_status[FPST_A64]);
|
||||||
set_float_rounding_mode(i, &env->vfp.fp_status[FPST_A32_F16]);
|
set_float_rounding_mode(i, &env->vfp.fp_status[FPST_A32_F16]);
|
||||||
set_float_rounding_mode(i, &env->vfp.fp_status[FPST_A64_F16]);
|
set_float_rounding_mode(i, &env->vfp.fp_status[FPST_A64_F16]);
|
||||||
}
|
}
|
||||||
@ -217,7 +217,7 @@ static void vfp_set_fpcr_to_host(CPUARMState *env, uint32_t val, uint32_t mask)
|
|||||||
if (changed & FPCR_FZ) {
|
if (changed & FPCR_FZ) {
|
||||||
bool ftz_enabled = val & FPCR_FZ;
|
bool ftz_enabled = val & FPCR_FZ;
|
||||||
set_flush_to_zero(ftz_enabled, &env->vfp.fp_status_a32);
|
set_flush_to_zero(ftz_enabled, &env->vfp.fp_status_a32);
|
||||||
set_flush_to_zero(ftz_enabled, &env->vfp.fp_status_a64);
|
set_flush_to_zero(ftz_enabled, &env->vfp.fp_status[FPST_A64]);
|
||||||
/* FIZ is A64 only so FZ always makes A32 code flush inputs to zero */
|
/* FIZ is A64 only so FZ always makes A32 code flush inputs to zero */
|
||||||
set_flush_inputs_to_zero(ftz_enabled, &env->vfp.fp_status_a32);
|
set_flush_inputs_to_zero(ftz_enabled, &env->vfp.fp_status_a32);
|
||||||
}
|
}
|
||||||
@ -228,12 +228,12 @@ static void vfp_set_fpcr_to_host(CPUARMState *env, uint32_t val, uint32_t mask)
|
|||||||
*/
|
*/
|
||||||
bool fitz_enabled = (val & FPCR_FIZ) ||
|
bool fitz_enabled = (val & FPCR_FIZ) ||
|
||||||
(val & (FPCR_FZ | FPCR_AH)) == FPCR_FZ;
|
(val & (FPCR_FZ | FPCR_AH)) == FPCR_FZ;
|
||||||
set_flush_inputs_to_zero(fitz_enabled, &env->vfp.fp_status_a64);
|
set_flush_inputs_to_zero(fitz_enabled, &env->vfp.fp_status[FPST_A64]);
|
||||||
}
|
}
|
||||||
if (changed & FPCR_DN) {
|
if (changed & FPCR_DN) {
|
||||||
bool dnan_enabled = val & FPCR_DN;
|
bool dnan_enabled = val & FPCR_DN;
|
||||||
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status_a32);
|
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status_a32);
|
||||||
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status_a64);
|
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status[FPST_A64]);
|
||||||
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status[FPST_A32_F16]);
|
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status[FPST_A32_F16]);
|
||||||
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status[FPST_A64_F16]);
|
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status[FPST_A64_F16]);
|
||||||
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status[FPST_AH]);
|
set_default_nan_mode(dnan_enabled, &env->vfp.fp_status[FPST_AH]);
|
||||||
@ -244,10 +244,10 @@ static void vfp_set_fpcr_to_host(CPUARMState *env, uint32_t val, uint32_t mask)
|
|||||||
|
|
||||||
if (ah_enabled) {
|
if (ah_enabled) {
|
||||||
/* Change behaviours for A64 FP operations */
|
/* Change behaviours for A64 FP operations */
|
||||||
arm_set_ah_fp_behaviours(&env->vfp.fp_status_a64);
|
arm_set_ah_fp_behaviours(&env->vfp.fp_status[FPST_A64]);
|
||||||
arm_set_ah_fp_behaviours(&env->vfp.fp_status[FPST_A64_F16]);
|
arm_set_ah_fp_behaviours(&env->vfp.fp_status[FPST_A64_F16]);
|
||||||
} else {
|
} else {
|
||||||
arm_set_default_fp_behaviours(&env->vfp.fp_status_a64);
|
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_A64]);
|
||||||
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_A64_F16]);
|
arm_set_default_fp_behaviours(&env->vfp.fp_status[FPST_A64_F16]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user