Skip to content

Commit 70acaaf

Browse files
rth7680pm215
authored andcommitted
target/arm: Update REV, PUNPK for pred_desc
Update all users of do_perm_pred2 for the new predicate descriptor field definitions. Cc: qemu-stable@nongnu.org Buglink: https://bugs.launchpad.net/bugs/1908551 Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20210113062650.593824-5-richard.henderson@linaro.org Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
1 parent f9b0fcc commit 70acaaf

File tree

2 files changed

+8
-13
lines changed

2 files changed

+8
-13
lines changed

target/arm/sve_helper.c

+4-4
Original file line numberDiff line numberDiff line change
@@ -2036,8 +2036,8 @@ static uint8_t reverse_bits_8(uint8_t x, int n)
20362036

20372037
void HELPER(sve_rev_p)(void *vd, void *vn, uint32_t pred_desc)
20382038
{
2039-
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
2040-
int esz = extract32(pred_desc, SIMD_DATA_SHIFT, 2);
2039+
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
2040+
int esz = FIELD_EX32(pred_desc, PREDDESC, ESZ);
20412041
intptr_t i, oprsz_2 = oprsz / 2;
20422042

20432043
if (oprsz <= 8) {
@@ -2066,8 +2066,8 @@ void HELPER(sve_rev_p)(void *vd, void *vn, uint32_t pred_desc)
20662066

20672067
void HELPER(sve_punpk_p)(void *vd, void *vn, uint32_t pred_desc)
20682068
{
2069-
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
2070-
intptr_t high = extract32(pred_desc, SIMD_DATA_SHIFT + 2, 1);
2069+
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
2070+
intptr_t high = FIELD_EX32(pred_desc, PREDDESC, DATA);
20712071
uint64_t *d = vd;
20722072
intptr_t i;
20732073

target/arm/translate-sve.c

+4-9
Original file line numberDiff line numberDiff line change
@@ -2145,19 +2145,14 @@ static bool do_perm_pred2(DisasContext *s, arg_rr_esz *a, bool high_odd,
21452145
TCGv_ptr t_d = tcg_temp_new_ptr();
21462146
TCGv_ptr t_n = tcg_temp_new_ptr();
21472147
TCGv_i32 t_desc;
2148-
int desc;
2148+
uint32_t desc = 0;
21492149

21502150
tcg_gen_addi_ptr(t_d, cpu_env, pred_full_reg_offset(s, a->rd));
21512151
tcg_gen_addi_ptr(t_n, cpu_env, pred_full_reg_offset(s, a->rn));
21522152

2153-
/* Predicate sizes may be smaller and cannot use simd_desc.
2154-
We cannot round up, as we do elsewhere, because we need
2155-
the exact size for ZIP2 and REV. We retain the style for
2156-
the other helpers for consistency. */
2157-
2158-
desc = vsz - 2;
2159-
desc = deposit32(desc, SIMD_DATA_SHIFT, 2, a->esz);
2160-
desc = deposit32(desc, SIMD_DATA_SHIFT + 2, 2, high_odd);
2153+
desc = FIELD_DP32(desc, PREDDESC, OPRSZ, vsz);
2154+
desc = FIELD_DP32(desc, PREDDESC, ESZ, a->esz);
2155+
desc = FIELD_DP32(desc, PREDDESC, DATA, high_odd);
21612156
t_desc = tcg_const_i32(desc);
21622157

21632158
fn(t_d, t_n, t_desc);

0 commit comments

Comments
 (0)