Skip to content

Commit 3ca879a

Browse files
rth7680pm215
authored andcommitted
target/arm: Implement SVE compress active elements
Reviewed-by: Peter Maydell <peter.maydell@linaro.org> Signed-off-by: Richard Henderson <richard.henderson@linaro.org> Message-id: 20180613015641.5667-6-richard.henderson@linaro.org Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
1 parent 234b48e commit 3ca879a

File tree

4 files changed

+55
-0
lines changed

4 files changed

+55
-0
lines changed

target/arm/helper-sve.h

Lines changed: 3 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -460,6 +460,9 @@ DEF_HELPER_FLAGS_4(sve_trn_h, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
460460
DEF_HELPER_FLAGS_4(sve_trn_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
461461
DEF_HELPER_FLAGS_4(sve_trn_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
462462

463+
DEF_HELPER_FLAGS_4(sve_compact_s, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
464+
DEF_HELPER_FLAGS_4(sve_compact_d, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, i32)
465+
463466
DEF_HELPER_FLAGS_5(sve_and_pppp, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
464467
DEF_HELPER_FLAGS_5(sve_bic_pppp, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)
465468
DEF_HELPER_FLAGS_5(sve_eor_pppp, TCG_CALL_NO_RWG, void, ptr, ptr, ptr, ptr, i32)

target/arm/sve.decode

Lines changed: 6 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -424,6 +424,12 @@ UZP2_z 00000101 .. 1 ..... 011 011 ..... ..... @rd_rn_rm
424424
TRN1_z 00000101 .. 1 ..... 011 100 ..... ..... @rd_rn_rm
425425
TRN2_z 00000101 .. 1 ..... 011 101 ..... ..... @rd_rn_rm
426426

427+
### SVE Permute - Predicated Group
428+
429+
# SVE compress active elements
430+
# Note esz >= 2
431+
COMPACT 00000101 .. 100001 100 ... ..... ..... @rd_pg_rn
432+
427433
### SVE Predicate Logical Operations Group
428434

429435
# SVE predicate logical operations

target/arm/sve_helper.c

Lines changed: 34 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2036,3 +2036,37 @@ DO_TRN(sve_trn_d, uint64_t, )
20362036
#undef DO_ZIP
20372037
#undef DO_UZP
20382038
#undef DO_TRN
2039+
2040+
void HELPER(sve_compact_s)(void *vd, void *vn, void *vg, uint32_t desc)
2041+
{
2042+
intptr_t i, j, opr_sz = simd_oprsz(desc) / 4;
2043+
uint32_t *d = vd, *n = vn;
2044+
uint8_t *pg = vg;
2045+
2046+
for (i = j = 0; i < opr_sz; i++) {
2047+
if (pg[H1(i / 2)] & (i & 1 ? 0x10 : 0x01)) {
2048+
d[H4(j)] = n[H4(i)];
2049+
j++;
2050+
}
2051+
}
2052+
for (; j < opr_sz; j++) {
2053+
d[H4(j)] = 0;
2054+
}
2055+
}
2056+
2057+
void HELPER(sve_compact_d)(void *vd, void *vn, void *vg, uint32_t desc)
2058+
{
2059+
intptr_t i, j, opr_sz = simd_oprsz(desc) / 8;
2060+
uint64_t *d = vd, *n = vn;
2061+
uint8_t *pg = vg;
2062+
2063+
for (i = j = 0; i < opr_sz; i++) {
2064+
if (pg[H1(i)] & 1) {
2065+
d[j] = n[i];
2066+
j++;
2067+
}
2068+
}
2069+
for (; j < opr_sz; j++) {
2070+
d[j] = 0;
2071+
}
2072+
}

target/arm/translate-sve.c

Lines changed: 12 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -2284,6 +2284,18 @@ static bool trans_TRN2_z(DisasContext *s, arg_rrr_esz *a, uint32_t insn)
22842284
return do_zzz_data_ool(s, a, 1 << a->esz, trn_fns[a->esz]);
22852285
}
22862286

2287+
/*
2288+
*** SVE Permute Vector - Predicated Group
2289+
*/
2290+
2291+
static bool trans_COMPACT(DisasContext *s, arg_rpr_esz *a, uint32_t insn)
2292+
{
2293+
static gen_helper_gvec_3 * const fns[4] = {
2294+
NULL, NULL, gen_helper_sve_compact_s, gen_helper_sve_compact_d
2295+
};
2296+
return do_zpz_ool(s, a, fns[a->esz]);
2297+
}
2298+
22872299
/*
22882300
*** SVE Memory - 32-bit Gather and Unsized Contiguous Group
22892301
*/

0 commit comments

Comments
 (0)