mirror of
https://github.com/Motorhead1991/qemu.git
synced 2025-08-11 03:24:58 -06:00
target/arm: Convert FRINT* (vector) to decodetree
Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20241211163036.2297116-57-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
This commit is contained in:
parent
73a6f0c245
commit
09facda342
2 changed files with 88 additions and 114 deletions
|
@ -1697,3 +1697,29 @@ FNEG_v 0.10 1110 1.1 00000 11111 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
FSQRT_v 0.10 1110 111 11001 11111 0 ..... ..... @qrr_h
|
FSQRT_v 0.10 1110 111 11001 11111 0 ..... ..... @qrr_h
|
||||||
FSQRT_v 0.10 1110 1.1 00001 11111 0 ..... ..... @qrr_sd
|
FSQRT_v 0.10 1110 1.1 00001 11111 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
|
FRINTN_v 0.00 1110 011 11001 10001 0 ..... ..... @qrr_h
|
||||||
|
FRINTN_v 0.00 1110 0.1 00001 10001 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
|
FRINTM_v 0.00 1110 011 11001 10011 0 ..... ..... @qrr_h
|
||||||
|
FRINTM_v 0.00 1110 0.1 00001 10011 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
|
FRINTP_v 0.00 1110 111 11001 10001 0 ..... ..... @qrr_h
|
||||||
|
FRINTP_v 0.00 1110 1.1 00001 10001 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
|
FRINTZ_v 0.00 1110 111 11001 10011 0 ..... ..... @qrr_h
|
||||||
|
FRINTZ_v 0.00 1110 1.1 00001 10011 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
|
FRINTA_v 0.10 1110 011 11001 10001 0 ..... ..... @qrr_h
|
||||||
|
FRINTA_v 0.10 1110 0.1 00001 10001 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
|
FRINTX_v 0.10 1110 011 11001 10011 0 ..... ..... @qrr_h
|
||||||
|
FRINTX_v 0.10 1110 0.1 00001 10011 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
|
FRINTI_v 0.10 1110 111 11001 10011 0 ..... ..... @qrr_h
|
||||||
|
FRINTI_v 0.10 1110 1.1 00001 10011 0 ..... ..... @qrr_sd
|
||||||
|
|
||||||
|
FRINT32Z_v 0.00 1110 0.1 00001 11101 0 ..... ..... @qrr_sd
|
||||||
|
FRINT32X_v 0.10 1110 0.1 00001 11101 0 ..... ..... @qrr_sd
|
||||||
|
FRINT64Z_v 0.00 1110 0.1 00001 11111 0 ..... ..... @qrr_sd
|
||||||
|
FRINT64X_v 0.10 1110 0.1 00001 11111 0 ..... ..... @qrr_sd
|
||||||
|
|
|
@ -9209,6 +9209,21 @@ static bool do_fp1_vector(DisasContext *s, arg_qrr_e *a,
|
||||||
|
|
||||||
TRANS(FSQRT_v, do_fp1_vector, a, &f_scalar_fsqrt, -1)
|
TRANS(FSQRT_v, do_fp1_vector, a, &f_scalar_fsqrt, -1)
|
||||||
|
|
||||||
|
TRANS(FRINTN_v, do_fp1_vector, a, &f_scalar_frint, FPROUNDING_TIEEVEN)
|
||||||
|
TRANS(FRINTP_v, do_fp1_vector, a, &f_scalar_frint, FPROUNDING_POSINF)
|
||||||
|
TRANS(FRINTM_v, do_fp1_vector, a, &f_scalar_frint, FPROUNDING_NEGINF)
|
||||||
|
TRANS(FRINTZ_v, do_fp1_vector, a, &f_scalar_frint, FPROUNDING_ZERO)
|
||||||
|
TRANS(FRINTA_v, do_fp1_vector, a, &f_scalar_frint, FPROUNDING_TIEAWAY)
|
||||||
|
TRANS(FRINTI_v, do_fp1_vector, a, &f_scalar_frint, -1)
|
||||||
|
TRANS(FRINTX_v, do_fp1_vector, a, &f_scalar_frintx, -1)
|
||||||
|
|
||||||
|
TRANS_FEAT(FRINT32Z_v, aa64_frint, do_fp1_vector, a,
|
||||||
|
&f_scalar_frint32, FPROUNDING_ZERO)
|
||||||
|
TRANS_FEAT(FRINT32X_v, aa64_frint, do_fp1_vector, a, &f_scalar_frint32, -1)
|
||||||
|
TRANS_FEAT(FRINT64Z_v, aa64_frint, do_fp1_vector, a,
|
||||||
|
&f_scalar_frint64, FPROUNDING_ZERO)
|
||||||
|
TRANS_FEAT(FRINT64X_v, aa64_frint, do_fp1_vector, a, &f_scalar_frint64, -1)
|
||||||
|
|
||||||
/* Common vector code for handling integer to FP conversion */
|
/* Common vector code for handling integer to FP conversion */
|
||||||
static void handle_simd_intfp_conv(DisasContext *s, int rd, int rn,
|
static void handle_simd_intfp_conv(DisasContext *s, int rd, int rn,
|
||||||
int elements, int is_signed,
|
int elements, int is_signed,
|
||||||
|
@ -9520,25 +9535,6 @@ static void handle_2misc_64(DisasContext *s, int opcode, bool u,
|
||||||
case 0x7b: /* FCVTZU */
|
case 0x7b: /* FCVTZU */
|
||||||
gen_helper_vfp_touqd(tcg_rd, tcg_rn, tcg_constant_i32(0), tcg_fpstatus);
|
gen_helper_vfp_touqd(tcg_rd, tcg_rn, tcg_constant_i32(0), tcg_fpstatus);
|
||||||
break;
|
break;
|
||||||
case 0x18: /* FRINTN */
|
|
||||||
case 0x19: /* FRINTM */
|
|
||||||
case 0x38: /* FRINTP */
|
|
||||||
case 0x39: /* FRINTZ */
|
|
||||||
case 0x58: /* FRINTA */
|
|
||||||
case 0x79: /* FRINTI */
|
|
||||||
gen_helper_rintd(tcg_rd, tcg_rn, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
case 0x59: /* FRINTX */
|
|
||||||
gen_helper_rintd_exact(tcg_rd, tcg_rn, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
case 0x1e: /* FRINT32Z */
|
|
||||||
case 0x5e: /* FRINT32X */
|
|
||||||
gen_helper_frint32_d(tcg_rd, tcg_rn, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
case 0x1f: /* FRINT64Z */
|
|
||||||
case 0x5f: /* FRINT64X */
|
|
||||||
gen_helper_frint64_d(tcg_rd, tcg_rn, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
case 0x4: /* CLS, CLZ */
|
case 0x4: /* CLS, CLZ */
|
||||||
case 0x5: /* NOT */
|
case 0x5: /* NOT */
|
||||||
|
@ -9550,6 +9546,17 @@ static void handle_2misc_64(DisasContext *s, int opcode, bool u,
|
||||||
case 0x2f: /* FABS */
|
case 0x2f: /* FABS */
|
||||||
case 0x6f: /* FNEG */
|
case 0x6f: /* FNEG */
|
||||||
case 0x7f: /* FSQRT */
|
case 0x7f: /* FSQRT */
|
||||||
|
case 0x18: /* FRINTN */
|
||||||
|
case 0x19: /* FRINTM */
|
||||||
|
case 0x38: /* FRINTP */
|
||||||
|
case 0x39: /* FRINTZ */
|
||||||
|
case 0x58: /* FRINTA */
|
||||||
|
case 0x79: /* FRINTI */
|
||||||
|
case 0x59: /* FRINTX */
|
||||||
|
case 0x1e: /* FRINT32Z */
|
||||||
|
case 0x5e: /* FRINT32X */
|
||||||
|
case 0x1f: /* FRINT64Z */
|
||||||
|
case 0x5f: /* FRINT64X */
|
||||||
g_assert_not_reached();
|
g_assert_not_reached();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10094,46 +10101,12 @@ static void disas_simd_two_reg_misc(DisasContext *s, uint32_t insn)
|
||||||
}
|
}
|
||||||
handle_2misc_widening(s, opcode, is_q, size, rn, rd);
|
handle_2misc_widening(s, opcode, is_q, size, rn, rd);
|
||||||
return;
|
return;
|
||||||
case 0x18: /* FRINTN */
|
|
||||||
case 0x19: /* FRINTM */
|
|
||||||
case 0x38: /* FRINTP */
|
|
||||||
case 0x39: /* FRINTZ */
|
|
||||||
rmode = extract32(opcode, 5, 1) | (extract32(opcode, 0, 1) << 1);
|
|
||||||
/* fall through */
|
|
||||||
case 0x59: /* FRINTX */
|
|
||||||
case 0x79: /* FRINTI */
|
|
||||||
need_fpstatus = true;
|
|
||||||
if (size == 3 && !is_q) {
|
|
||||||
unallocated_encoding(s);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 0x58: /* FRINTA */
|
|
||||||
rmode = FPROUNDING_TIEAWAY;
|
|
||||||
need_fpstatus = true;
|
|
||||||
if (size == 3 && !is_q) {
|
|
||||||
unallocated_encoding(s);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
case 0x7c: /* URSQRTE */
|
case 0x7c: /* URSQRTE */
|
||||||
if (size == 3) {
|
if (size == 3) {
|
||||||
unallocated_encoding(s);
|
unallocated_encoding(s);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 0x1e: /* FRINT32Z */
|
|
||||||
case 0x1f: /* FRINT64Z */
|
|
||||||
rmode = FPROUNDING_ZERO;
|
|
||||||
/* fall through */
|
|
||||||
case 0x5e: /* FRINT32X */
|
|
||||||
case 0x5f: /* FRINT64X */
|
|
||||||
need_fpstatus = true;
|
|
||||||
if ((size == 3 && !is_q) || !dc_isar_feature(aa64_frint, s)) {
|
|
||||||
unallocated_encoding(s);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
case 0x16: /* FCVTN, FCVTN2 */
|
case 0x16: /* FCVTN, FCVTN2 */
|
||||||
case 0x36: /* BFCVTN, BFCVTN2 */
|
case 0x36: /* BFCVTN, BFCVTN2 */
|
||||||
|
@ -10141,6 +10114,17 @@ static void disas_simd_two_reg_misc(DisasContext *s, uint32_t insn)
|
||||||
case 0x2f: /* FABS */
|
case 0x2f: /* FABS */
|
||||||
case 0x6f: /* FNEG */
|
case 0x6f: /* FNEG */
|
||||||
case 0x7f: /* FSQRT */
|
case 0x7f: /* FSQRT */
|
||||||
|
case 0x18: /* FRINTN */
|
||||||
|
case 0x19: /* FRINTM */
|
||||||
|
case 0x38: /* FRINTP */
|
||||||
|
case 0x39: /* FRINTZ */
|
||||||
|
case 0x59: /* FRINTX */
|
||||||
|
case 0x79: /* FRINTI */
|
||||||
|
case 0x58: /* FRINTA */
|
||||||
|
case 0x1e: /* FRINT32Z */
|
||||||
|
case 0x1f: /* FRINT64Z */
|
||||||
|
case 0x5e: /* FRINT32X */
|
||||||
|
case 0x5f: /* FRINT64X */
|
||||||
unallocated_encoding(s);
|
unallocated_encoding(s);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -10229,33 +10213,25 @@ static void disas_simd_two_reg_misc(DisasContext *s, uint32_t insn)
|
||||||
gen_helper_vfp_touls(tcg_res, tcg_op,
|
gen_helper_vfp_touls(tcg_res, tcg_op,
|
||||||
tcg_constant_i32(0), tcg_fpstatus);
|
tcg_constant_i32(0), tcg_fpstatus);
|
||||||
break;
|
break;
|
||||||
case 0x18: /* FRINTN */
|
|
||||||
case 0x19: /* FRINTM */
|
|
||||||
case 0x38: /* FRINTP */
|
|
||||||
case 0x39: /* FRINTZ */
|
|
||||||
case 0x58: /* FRINTA */
|
|
||||||
case 0x79: /* FRINTI */
|
|
||||||
gen_helper_rints(tcg_res, tcg_op, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
case 0x59: /* FRINTX */
|
|
||||||
gen_helper_rints_exact(tcg_res, tcg_op, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
case 0x7c: /* URSQRTE */
|
case 0x7c: /* URSQRTE */
|
||||||
gen_helper_rsqrte_u32(tcg_res, tcg_op);
|
gen_helper_rsqrte_u32(tcg_res, tcg_op);
|
||||||
break;
|
break;
|
||||||
case 0x1e: /* FRINT32Z */
|
|
||||||
case 0x5e: /* FRINT32X */
|
|
||||||
gen_helper_frint32_s(tcg_res, tcg_op, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
case 0x1f: /* FRINT64Z */
|
|
||||||
case 0x5f: /* FRINT64X */
|
|
||||||
gen_helper_frint64_s(tcg_res, tcg_op, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
default:
|
default:
|
||||||
case 0x7: /* SQABS, SQNEG */
|
case 0x7: /* SQABS, SQNEG */
|
||||||
case 0x2f: /* FABS */
|
case 0x2f: /* FABS */
|
||||||
case 0x6f: /* FNEG */
|
case 0x6f: /* FNEG */
|
||||||
case 0x7f: /* FSQRT */
|
case 0x7f: /* FSQRT */
|
||||||
|
case 0x18: /* FRINTN */
|
||||||
|
case 0x19: /* FRINTM */
|
||||||
|
case 0x38: /* FRINTP */
|
||||||
|
case 0x39: /* FRINTZ */
|
||||||
|
case 0x58: /* FRINTA */
|
||||||
|
case 0x79: /* FRINTI */
|
||||||
|
case 0x59: /* FRINTX */
|
||||||
|
case 0x1e: /* FRINT32Z */
|
||||||
|
case 0x5e: /* FRINT32X */
|
||||||
|
case 0x1f: /* FRINT64Z */
|
||||||
|
case 0x5f: /* FRINT64X */
|
||||||
g_assert_not_reached();
|
g_assert_not_reached();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -10289,7 +10265,6 @@ static void disas_simd_two_reg_misc_fp16(DisasContext *s, uint32_t insn)
|
||||||
int rn, rd;
|
int rn, rd;
|
||||||
bool is_q;
|
bool is_q;
|
||||||
bool is_scalar;
|
bool is_scalar;
|
||||||
bool only_in_vector = false;
|
|
||||||
|
|
||||||
int pass;
|
int pass;
|
||||||
TCGv_i32 tcg_rmode = NULL;
|
TCGv_i32 tcg_rmode = NULL;
|
||||||
|
@ -10343,31 +10318,6 @@ static void disas_simd_two_reg_misc_fp16(DisasContext *s, uint32_t insn)
|
||||||
case 0x3d: /* FRECPE */
|
case 0x3d: /* FRECPE */
|
||||||
case 0x3f: /* FRECPX */
|
case 0x3f: /* FRECPX */
|
||||||
break;
|
break;
|
||||||
case 0x18: /* FRINTN */
|
|
||||||
only_in_vector = true;
|
|
||||||
rmode = FPROUNDING_TIEEVEN;
|
|
||||||
break;
|
|
||||||
case 0x19: /* FRINTM */
|
|
||||||
only_in_vector = true;
|
|
||||||
rmode = FPROUNDING_NEGINF;
|
|
||||||
break;
|
|
||||||
case 0x38: /* FRINTP */
|
|
||||||
only_in_vector = true;
|
|
||||||
rmode = FPROUNDING_POSINF;
|
|
||||||
break;
|
|
||||||
case 0x39: /* FRINTZ */
|
|
||||||
only_in_vector = true;
|
|
||||||
rmode = FPROUNDING_ZERO;
|
|
||||||
break;
|
|
||||||
case 0x58: /* FRINTA */
|
|
||||||
only_in_vector = true;
|
|
||||||
rmode = FPROUNDING_TIEAWAY;
|
|
||||||
break;
|
|
||||||
case 0x59: /* FRINTX */
|
|
||||||
case 0x79: /* FRINTI */
|
|
||||||
only_in_vector = true;
|
|
||||||
/* current rounding mode */
|
|
||||||
break;
|
|
||||||
case 0x1a: /* FCVTNS */
|
case 0x1a: /* FCVTNS */
|
||||||
rmode = FPROUNDING_TIEEVEN;
|
rmode = FPROUNDING_TIEEVEN;
|
||||||
break;
|
break;
|
||||||
|
@ -10404,6 +10354,13 @@ static void disas_simd_two_reg_misc_fp16(DisasContext *s, uint32_t insn)
|
||||||
case 0x2f: /* FABS */
|
case 0x2f: /* FABS */
|
||||||
case 0x6f: /* FNEG */
|
case 0x6f: /* FNEG */
|
||||||
case 0x7f: /* FSQRT (vector) */
|
case 0x7f: /* FSQRT (vector) */
|
||||||
|
case 0x18: /* FRINTN */
|
||||||
|
case 0x19: /* FRINTM */
|
||||||
|
case 0x38: /* FRINTP */
|
||||||
|
case 0x39: /* FRINTZ */
|
||||||
|
case 0x58: /* FRINTA */
|
||||||
|
case 0x59: /* FRINTX */
|
||||||
|
case 0x79: /* FRINTI */
|
||||||
unallocated_encoding(s);
|
unallocated_encoding(s);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
@ -10415,11 +10372,6 @@ static void disas_simd_two_reg_misc_fp16(DisasContext *s, uint32_t insn)
|
||||||
unallocated_encoding(s);
|
unallocated_encoding(s);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
/* FRINTxx is only in the vector form */
|
|
||||||
if (only_in_vector) {
|
|
||||||
unallocated_encoding(s);
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!fp_access_check(s)) {
|
if (!fp_access_check(s)) {
|
||||||
|
@ -10494,17 +10446,6 @@ static void disas_simd_two_reg_misc_fp16(DisasContext *s, uint32_t insn)
|
||||||
case 0x7b: /* FCVTZU */
|
case 0x7b: /* FCVTZU */
|
||||||
gen_helper_advsimd_f16touinth(tcg_res, tcg_op, tcg_fpstatus);
|
gen_helper_advsimd_f16touinth(tcg_res, tcg_op, tcg_fpstatus);
|
||||||
break;
|
break;
|
||||||
case 0x18: /* FRINTN */
|
|
||||||
case 0x19: /* FRINTM */
|
|
||||||
case 0x38: /* FRINTP */
|
|
||||||
case 0x39: /* FRINTZ */
|
|
||||||
case 0x58: /* FRINTA */
|
|
||||||
case 0x79: /* FRINTI */
|
|
||||||
gen_helper_advsimd_rinth(tcg_res, tcg_op, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
case 0x59: /* FRINTX */
|
|
||||||
gen_helper_advsimd_rinth_exact(tcg_res, tcg_op, tcg_fpstatus);
|
|
||||||
break;
|
|
||||||
case 0x7d: /* FRSQRTE */
|
case 0x7d: /* FRSQRTE */
|
||||||
gen_helper_rsqrte_f16(tcg_res, tcg_op, tcg_fpstatus);
|
gen_helper_rsqrte_f16(tcg_res, tcg_op, tcg_fpstatus);
|
||||||
break;
|
break;
|
||||||
|
@ -10512,6 +10453,13 @@ static void disas_simd_two_reg_misc_fp16(DisasContext *s, uint32_t insn)
|
||||||
case 0x2f: /* FABS */
|
case 0x2f: /* FABS */
|
||||||
case 0x6f: /* FNEG */
|
case 0x6f: /* FNEG */
|
||||||
case 0x7f: /* FSQRT */
|
case 0x7f: /* FSQRT */
|
||||||
|
case 0x18: /* FRINTN */
|
||||||
|
case 0x19: /* FRINTM */
|
||||||
|
case 0x38: /* FRINTP */
|
||||||
|
case 0x39: /* FRINTZ */
|
||||||
|
case 0x58: /* FRINTA */
|
||||||
|
case 0x79: /* FRINTI */
|
||||||
|
case 0x59: /* FRINTX */
|
||||||
g_assert_not_reached();
|
g_assert_not_reached();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue