[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
Re: [Qemu-arm] [Qemu-devel] [PATCH v2 29/32] arm/translate-a64: add FP16
From: |
Richard Henderson |
Subject: |
Re: [Qemu-arm] [Qemu-devel] [PATCH v2 29/32] arm/translate-a64: add FP16 FMOV to simd_mod_imm |
Date: |
Fri, 9 Feb 2018 10:23:12 -0800 |
User-agent: |
Mozilla/5.0 (X11; Linux x86_64; rv:52.0) Gecko/20100101 Thunderbird/52.6.0 |
On 02/08/2018 09:31 AM, Alex Bennée wrote:
> Only one half-precision instruction has been added to this group.
>
> Signed-off-by: Alex Bennée <address@hidden>
>
> ---
> v2
> - checkpatch fixes
> ---
> target/arm/translate-a64.c | 48
> ++++++++++++++++++++++++++++++++++++----------
> 1 file changed, 38 insertions(+), 10 deletions(-)
>
> diff --git a/target/arm/translate-a64.c b/target/arm/translate-a64.c
> index fa21299061..b209f57d55 100644
> --- a/target/arm/translate-a64.c
> +++ b/target/arm/translate-a64.c
> @@ -6160,6 +6160,8 @@ static void disas_simd_copy(DisasContext *s, uint32_t
> insn)
> * MVNI - move inverted (shifted) imm into register
> * ORR - bitwise OR of (shifted) imm with register
> * BIC - bitwise clear of (shifted) imm with register
> + * With ARMv8.2 we also have:
> + * FMOV half-precision
> */
> static void disas_simd_mod_imm(DisasContext *s, uint32_t insn)
> {
> @@ -6176,8 +6178,11 @@ static void disas_simd_mod_imm(DisasContext *s,
> uint32_t insn)
> int i;
>
> if (o2 != 0 || ((cmode == 0xf) && is_neg && !is_q)) {
> - unallocated_encoding(s);
> - return;
> + /* Check for FMOV (vector, immediate) - half-precision */
> + if (!(arm_dc_feature(s, ARM_FEATURE_V8_FP16) && o2 && cmode == 0xf))
> {
> + unallocated_encoding(s);
> + return;
> + }
> }
>
> if (!fp_access_check(s)) {
> @@ -6235,19 +6240,42 @@ static void disas_simd_mod_imm(DisasContext *s,
> uint32_t insn)
> imm |= 0x4000000000000000ULL;
> }
> } else {
> - imm = (abcdefgh & 0x3f) << 19;
> - if (abcdefgh & 0x80) {
> - imm |= 0x80000000;
> - }
> - if (abcdefgh & 0x40) {
> - imm |= 0x3e000000;
> + if (o2) {
> + /* FMOV (vector, immediate) - half-precision
> + *
> + * We don't need fancy immediate expansion, just:
> + * imm16 = imm8<7>:NOT(imm8<6>):Replicate(imm8<6>,2):
> + * imm8<5:0>:Zeros(6);
> + */
> + uint32_t imm8_5_0 = extract32(abcdefgh, 0, 6);
> + uint32_t imm8_6 = extract32(abcdefgh, 6, 1);
> + uint32_t imm8_7 = extract32(abcdefgh, 7, 1);
> + uint32_t imm8_6_rep = imm8_6 << 1 | imm8_6;
> + uint32_t imm8_6_not = ~imm8_6;
> + imm = deposit64(imm, 6, 6, imm8_5_0);
> + imm = deposit64(imm, 12, 2, imm8_6_rep);
> + imm = deposit64(imm, 14, 1, imm8_6_not);
> + imm = deposit64(imm, 15, 1, imm8_7);
> + /* now duplicate across the lanes */
> + imm = bitfield_replicate(imm, 16);
> } else {
> - imm |= 0x40000000;
> + imm = (abcdefgh & 0x3f) << 19;
> + if (abcdefgh & 0x80) {
> + imm |= 0x80000000;
> + }
> + if (abcdefgh & 0x40) {
> + imm |= 0x3e000000;
> + } else {
> + imm |= 0x40000000;
> + }
> + imm |= (imm << 32);
> }
> - imm |= (imm << 32);
Please use vfp_expand_imm(MO_16, abcdefgh), which probably didn't exist when
you first wrote this.
r~
- Re: [Qemu-arm] [Qemu-devel] [PATCH v2 15/32] arm/translate-a64: add FP16 FMULX/MLS/FMLA to simd_indexed, (continued)
- [Qemu-arm] [PATCH v2 28/32] arm/translate-a64: add FP16 FRSQRTE to simd_two_reg_misc_fp16, Alex Bennée, 2018/02/08
- [Qemu-arm] [PATCH v2 25/32] arm/translate-a64: add FP16 FRCPX to simd_two_reg_misc_fp16, Alex Bennée, 2018/02/08
- [Qemu-arm] [PATCH v2 23/32] arm/helper.c: re-factor recpe and add recepe_f16, Alex Bennée, 2018/02/08
- [Qemu-arm] [PATCH v2 16/32] arm/translate-a64: add FP16 x2 ops for simd_indexed, Alex Bennée, 2018/02/08
- [Qemu-arm] [PATCH v2 29/32] arm/translate-a64: add FP16 FMOV to simd_mod_imm, Alex Bennée, 2018/02/08
- Re: [Qemu-arm] [Qemu-devel] [PATCH v2 29/32] arm/translate-a64: add FP16 FMOV to simd_mod_imm,
Richard Henderson <=
- [Qemu-arm] [PATCH v2 14/32] arm/translate-a64: add FP16 pairwise ops simd_three_reg_same_fp16, Alex Bennée, 2018/02/08
- Re: [Qemu-arm] [Qemu-devel] [PATCH v2 00/32] Add ARMv8.2 half-precision functions, no-reply, 2018/02/08
- Re: [Qemu-arm] [Qemu-devel] [PATCH v2 00/32] Add ARMv8.2 half-precision functions, no-reply, 2018/02/08
- Re: [Qemu-arm] [Qemu-devel] [PATCH v2 00/32] Add ARMv8.2 half-precision functions, no-reply, 2018/02/08
- Re: [Qemu-arm] [Qemu-devel] [PATCH v2 00/32] Add ARMv8.2 half-precision functions, no-reply, 2018/02/08
- Re: [Qemu-arm] [Qemu-devel] [PATCH v2 00/32] Add ARMv8.2 half-precision functions, no-reply, 2018/02/08
- Re: [Qemu-arm] [Qemu-devel] [PATCH v2 00/32] Add ARMv8.2 half-precision functions, no-reply, 2018/02/09
- Re: [Qemu-arm] [PATCH v2 00/32] Add ARMv8.2 half-precision functions, Peter Maydell, 2018/02/13