target/arm: Convert neon_helper.c to fpst alias
Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Reviewed-by: Philippe Mathieu-Daudé <philmd@linaro.org> Message-id: 20241206031224.78525-6-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
aec7ae42a9
commit
dae5be12c6
@ -424,13 +424,13 @@ DEF_HELPER_FLAGS_2(neon_qneg_s16, TCG_CALL_NO_RWG, i32, env, i32)
|
||||
DEF_HELPER_FLAGS_2(neon_qneg_s32, TCG_CALL_NO_RWG, i32, env, i32)
|
||||
DEF_HELPER_FLAGS_2(neon_qneg_s64, TCG_CALL_NO_RWG, i64, env, i64)
|
||||
|
||||
DEF_HELPER_3(neon_ceq_f32, i32, i32, i32, ptr)
|
||||
DEF_HELPER_3(neon_cge_f32, i32, i32, i32, ptr)
|
||||
DEF_HELPER_3(neon_cgt_f32, i32, i32, i32, ptr)
|
||||
DEF_HELPER_3(neon_acge_f32, i32, i32, i32, ptr)
|
||||
DEF_HELPER_3(neon_acgt_f32, i32, i32, i32, ptr)
|
||||
DEF_HELPER_3(neon_acge_f64, i64, i64, i64, ptr)
|
||||
DEF_HELPER_3(neon_acgt_f64, i64, i64, i64, ptr)
|
||||
DEF_HELPER_3(neon_ceq_f32, i32, i32, i32, fpst)
|
||||
DEF_HELPER_3(neon_cge_f32, i32, i32, i32, fpst)
|
||||
DEF_HELPER_3(neon_cgt_f32, i32, i32, i32, fpst)
|
||||
DEF_HELPER_3(neon_acge_f32, i32, i32, i32, fpst)
|
||||
DEF_HELPER_3(neon_acgt_f32, i32, i32, i32, fpst)
|
||||
DEF_HELPER_3(neon_acge_f64, i64, i64, i64, fpst)
|
||||
DEF_HELPER_3(neon_acgt_f64, i64, i64, i64, fpst)
|
||||
|
||||
/* iwmmxt_helper.c */
|
||||
DEF_HELPER_2(iwmmxt_maddsq, i64, i64, i64)
|
||||
|
@ -1180,51 +1180,44 @@ uint64_t HELPER(neon_qneg_s64)(CPUARMState *env, uint64_t x)
|
||||
* Note that EQ doesn't signal InvalidOp for QNaNs but GE and GT do.
|
||||
* Softfloat routines return 0/1, which we convert to the 0/-1 Neon requires.
|
||||
*/
|
||||
uint32_t HELPER(neon_ceq_f32)(uint32_t a, uint32_t b, void *fpstp)
|
||||
uint32_t HELPER(neon_ceq_f32)(uint32_t a, uint32_t b, float_status *fpst)
|
||||
{
|
||||
float_status *fpst = fpstp;
|
||||
return -float32_eq_quiet(make_float32(a), make_float32(b), fpst);
|
||||
}
|
||||
|
||||
uint32_t HELPER(neon_cge_f32)(uint32_t a, uint32_t b, void *fpstp)
|
||||
uint32_t HELPER(neon_cge_f32)(uint32_t a, uint32_t b, float_status *fpst)
|
||||
{
|
||||
float_status *fpst = fpstp;
|
||||
return -float32_le(make_float32(b), make_float32(a), fpst);
|
||||
}
|
||||
|
||||
uint32_t HELPER(neon_cgt_f32)(uint32_t a, uint32_t b, void *fpstp)
|
||||
uint32_t HELPER(neon_cgt_f32)(uint32_t a, uint32_t b, float_status *fpst)
|
||||
{
|
||||
float_status *fpst = fpstp;
|
||||
return -float32_lt(make_float32(b), make_float32(a), fpst);
|
||||
}
|
||||
|
||||
uint32_t HELPER(neon_acge_f32)(uint32_t a, uint32_t b, void *fpstp)
|
||||
uint32_t HELPER(neon_acge_f32)(uint32_t a, uint32_t b, float_status *fpst)
|
||||
{
|
||||
float_status *fpst = fpstp;
|
||||
float32 f0 = float32_abs(make_float32(a));
|
||||
float32 f1 = float32_abs(make_float32(b));
|
||||
return -float32_le(f1, f0, fpst);
|
||||
}
|
||||
|
||||
uint32_t HELPER(neon_acgt_f32)(uint32_t a, uint32_t b, void *fpstp)
|
||||
uint32_t HELPER(neon_acgt_f32)(uint32_t a, uint32_t b, float_status *fpst)
|
||||
{
|
||||
float_status *fpst = fpstp;
|
||||
float32 f0 = float32_abs(make_float32(a));
|
||||
float32 f1 = float32_abs(make_float32(b));
|
||||
return -float32_lt(f1, f0, fpst);
|
||||
}
|
||||
|
||||
uint64_t HELPER(neon_acge_f64)(uint64_t a, uint64_t b, void *fpstp)
|
||||
uint64_t HELPER(neon_acge_f64)(uint64_t a, uint64_t b, float_status *fpst)
|
||||
{
|
||||
float_status *fpst = fpstp;
|
||||
float64 f0 = float64_abs(make_float64(a));
|
||||
float64 f1 = float64_abs(make_float64(b));
|
||||
return -float64_le(f1, f0, fpst);
|
||||
}
|
||||
|
||||
uint64_t HELPER(neon_acgt_f64)(uint64_t a, uint64_t b, void *fpstp)
|
||||
uint64_t HELPER(neon_acgt_f64)(uint64_t a, uint64_t b, float_status *fpst)
|
||||
{
|
||||
float_status *fpst = fpstp;
|
||||
float64 f0 = float64_abs(make_float64(a));
|
||||
float64 f1 = float64_abs(make_float64(b));
|
||||
return -float64_lt(f1, f0, fpst);
|
||||
|
Loading…
x
Reference in New Issue
Block a user