mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-01-09 22:05:41 +00:00
target/arm: Implement SVE Select Vectors Group
Backports commit d3fe4a29d754dee73cbf3cb7584db222981179ac from qemu
This commit is contained in:
parent
7698c1634e
commit
7211d415a4
|
@ -3469,6 +3469,10 @@
|
||||||
#define helper_sve_sdiv_zpzz_d helper_sve_sdiv_zpzz_d_aarch64
|
#define helper_sve_sdiv_zpzz_d helper_sve_sdiv_zpzz_d_aarch64
|
||||||
#define helper_sve_sdiv_zpzz_s helper_sve_sdiv_zpzz_s_aarch64
|
#define helper_sve_sdiv_zpzz_s helper_sve_sdiv_zpzz_s_aarch64
|
||||||
#define helper_sve_sel_pppp helper_sve_sel_pppp_aarch64
|
#define helper_sve_sel_pppp helper_sve_sel_pppp_aarch64
|
||||||
|
#define helper_sve_sel_zpzz_b helper_sve_sel_zpzz_b_aarch64
|
||||||
|
#define helper_sve_sel_zpzz_d helper_sve_sel_zpzz_d_aarch64
|
||||||
|
#define helper_sve_sel_zpzz_h helper_sve_sel_zpzz_h_aarch64
|
||||||
|
#define helper_sve_sel_zpzz_s helper_sve_sel_zpzz_s_aarch64
|
||||||
#define helper_sve_smax_zpzz_b helper_sve_smax_zpzz_b_aarch64
|
#define helper_sve_smax_zpzz_b helper_sve_smax_zpzz_b_aarch64
|
||||||
#define helper_sve_smax_zpzz_d helper_sve_smax_zpzz_d_aarch64
|
#define helper_sve_smax_zpzz_d helper_sve_smax_zpzz_d_aarch64
|
||||||
#define helper_sve_smax_zpzz_h helper_sve_smax_zpzz_h_aarch64
|
#define helper_sve_smax_zpzz_h helper_sve_smax_zpzz_h_aarch64
|
||||||
|
|
|
@ -3469,6 +3469,10 @@
|
||||||
#define helper_sve_sdiv_zpzz_d helper_sve_sdiv_zpzz_d_aarch64eb
|
#define helper_sve_sdiv_zpzz_d helper_sve_sdiv_zpzz_d_aarch64eb
|
||||||
#define helper_sve_sdiv_zpzz_s helper_sve_sdiv_zpzz_s_aarch64eb
|
#define helper_sve_sdiv_zpzz_s helper_sve_sdiv_zpzz_s_aarch64eb
|
||||||
#define helper_sve_sel_pppp helper_sve_sel_pppp_aarch64eb
|
#define helper_sve_sel_pppp helper_sve_sel_pppp_aarch64eb
|
||||||
|
#define helper_sve_sel_zpzz_b helper_sve_sel_zpzz_b_aarch64eb
|
||||||
|
#define helper_sve_sel_zpzz_d helper_sve_sel_zpzz_d_aarch64eb
|
||||||
|
#define helper_sve_sel_zpzz_h helper_sve_sel_zpzz_h_aarch64eb
|
||||||
|
#define helper_sve_sel_zpzz_s helper_sve_sel_zpzz_s_aarch64eb
|
||||||
#define helper_sve_smax_zpzz_b helper_sve_smax_zpzz_b_aarch64eb
|
#define helper_sve_smax_zpzz_b helper_sve_smax_zpzz_b_aarch64eb
|
||||||
#define helper_sve_smax_zpzz_d helper_sve_smax_zpzz_d_aarch64eb
|
#define helper_sve_smax_zpzz_d helper_sve_smax_zpzz_d_aarch64eb
|
||||||
#define helper_sve_smax_zpzz_h helper_sve_smax_zpzz_h_aarch64eb
|
#define helper_sve_smax_zpzz_h helper_sve_smax_zpzz_h_aarch64eb
|
||||||
|
|
|
@ -3490,6 +3490,10 @@ aarch64_symbols = (
|
||||||
'helper_sve_sdiv_zpzz_d',
|
'helper_sve_sdiv_zpzz_d',
|
||||||
'helper_sve_sdiv_zpzz_s',
|
'helper_sve_sdiv_zpzz_s',
|
||||||
'helper_sve_sel_pppp',
|
'helper_sve_sel_pppp',
|
||||||
|
'helper_sve_sel_zpzz_b',
|
||||||
|
'helper_sve_sel_zpzz_d',
|
||||||
|
'helper_sve_sel_zpzz_h',
|
||||||
|
'helper_sve_sel_zpzz_s',
|
||||||
'helper_sve_smax_zpzz_b',
|
'helper_sve_smax_zpzz_b',
|
||||||
'helper_sve_smax_zpzz_d',
|
'helper_sve_smax_zpzz_d',
|
||||||
'helper_sve_smax_zpzz_h',
|
'helper_sve_smax_zpzz_h',
|
||||||
|
|
|
@ -195,6 +195,15 @@ DEF_HELPER_FLAGS_5(sve_lsl_zpzz_s, TCG_CALL_NO_RWG,
|
||||||
DEF_HELPER_FLAGS_5(sve_lsl_zpzz_d, TCG_CALL_NO_RWG,
|
DEF_HELPER_FLAGS_5(sve_lsl_zpzz_d, TCG_CALL_NO_RWG,
|
||||||
void, ptr, ptr, ptr, ptr, i32)
|
void, ptr, ptr, ptr, ptr, i32)
|
||||||
|
|
||||||
|
DEF_HELPER_FLAGS_5(sve_sel_zpzz_b, TCG_CALL_NO_RWG,
|
||||||
|
void, ptr, ptr, ptr, ptr, i32)
|
||||||
|
DEF_HELPER_FLAGS_5(sve_sel_zpzz_h, TCG_CALL_NO_RWG,
|
||||||
|
void, ptr, ptr, ptr, ptr, i32)
|
||||||
|
DEF_HELPER_FLAGS_5(sve_sel_zpzz_s, TCG_CALL_NO_RWG,
|
||||||
|
void, ptr, ptr, ptr, ptr, i32)
|
||||||
|
DEF_HELPER_FLAGS_5(sve_sel_zpzz_d, TCG_CALL_NO_RWG,
|
||||||
|
void, ptr, ptr, ptr, ptr, i32)
|
||||||
|
|
||||||
DEF_HELPER_FLAGS_5(sve_asr_zpzw_b, TCG_CALL_NO_RWG,
|
DEF_HELPER_FLAGS_5(sve_asr_zpzw_b, TCG_CALL_NO_RWG,
|
||||||
void, ptr, ptr, ptr, ptr, i32)
|
void, ptr, ptr, ptr, ptr, i32)
|
||||||
DEF_HELPER_FLAGS_5(sve_asr_zpzw_h, TCG_CALL_NO_RWG,
|
DEF_HELPER_FLAGS_5(sve_asr_zpzw_h, TCG_CALL_NO_RWG,
|
||||||
|
|
|
@ -98,6 +98,7 @@
|
||||||
&rprr_esz rn=%reg_movprfx
|
&rprr_esz rn=%reg_movprfx
|
||||||
@rdm_pg_rn ........ esz:2 ... ... ... pg:3 rn:5 rd:5 \
|
@rdm_pg_rn ........ esz:2 ... ... ... pg:3 rn:5 rd:5 \
|
||||||
&rprr_esz rm=%reg_movprfx
|
&rprr_esz rm=%reg_movprfx
|
||||||
|
@rd_pg4_rn_rm ........ esz:2 . rm:5 .. pg:4 rn:5 rd:5 &rprr_esz
|
||||||
|
|
||||||
# One register operand, with governing predicate, vector element size
|
# One register operand, with governing predicate, vector element size
|
||||||
@rd_pg_rn ........ esz:2 ... ... ... pg:3 rn:5 rd:5 &rpr_esz
|
@rd_pg_rn ........ esz:2 ... ... ... pg:3 rn:5 rd:5 &rpr_esz
|
||||||
|
@ -466,6 +467,11 @@ RBIT 00000101 .. 1001 11 100 ... ..... ..... @rd_pg_rn
|
||||||
# SVE vector splice (predicated)
|
# SVE vector splice (predicated)
|
||||||
SPLICE 00000101 .. 101 100 100 ... ..... ..... @rdn_pg_rm
|
SPLICE 00000101 .. 101 100 100 ... ..... ..... @rdn_pg_rm
|
||||||
|
|
||||||
|
### SVE Select Vectors Group
|
||||||
|
|
||||||
|
# SVE select vector elements (predicated)
|
||||||
|
SEL_zpzz 00000101 .. 1 ..... 11 .... ..... ..... @rd_pg4_rn_rm
|
||||||
|
|
||||||
### SVE Predicate Logical Operations Group
|
### SVE Predicate Logical Operations Group
|
||||||
|
|
||||||
# SVE predicate logical operations
|
# SVE predicate logical operations
|
||||||
|
|
|
@ -2145,3 +2145,58 @@ void HELPER(sve_splice)(void *vd, void *vn, void *vm, void *vg, uint32_t desc)
|
||||||
}
|
}
|
||||||
swap_memmove(vd + len, vm, opr_sz * 8 - len);
|
swap_memmove(vd + len, vm, opr_sz * 8 - len);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void HELPER(sve_sel_zpzz_b)(void *vd, void *vn, void *vm,
|
||||||
|
void *vg, uint32_t desc)
|
||||||
|
{
|
||||||
|
intptr_t i, opr_sz = simd_oprsz(desc) / 8;
|
||||||
|
uint64_t *d = vd, *n = vn, *m = vm;
|
||||||
|
uint8_t *pg = vg;
|
||||||
|
|
||||||
|
for (i = 0; i < opr_sz; i += 1) {
|
||||||
|
uint64_t nn = n[i], mm = m[i];
|
||||||
|
uint64_t pp = expand_pred_b(pg[H1(i)]);
|
||||||
|
d[i] = (nn & pp) | (mm & ~pp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void HELPER(sve_sel_zpzz_h)(void *vd, void *vn, void *vm,
|
||||||
|
void *vg, uint32_t desc)
|
||||||
|
{
|
||||||
|
intptr_t i, opr_sz = simd_oprsz(desc) / 8;
|
||||||
|
uint64_t *d = vd, *n = vn, *m = vm;
|
||||||
|
uint8_t *pg = vg;
|
||||||
|
|
||||||
|
for (i = 0; i < opr_sz; i += 1) {
|
||||||
|
uint64_t nn = n[i], mm = m[i];
|
||||||
|
uint64_t pp = expand_pred_h(pg[H1(i)]);
|
||||||
|
d[i] = (nn & pp) | (mm & ~pp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void HELPER(sve_sel_zpzz_s)(void *vd, void *vn, void *vm,
|
||||||
|
void *vg, uint32_t desc)
|
||||||
|
{
|
||||||
|
intptr_t i, opr_sz = simd_oprsz(desc) / 8;
|
||||||
|
uint64_t *d = vd, *n = vn, *m = vm;
|
||||||
|
uint8_t *pg = vg;
|
||||||
|
|
||||||
|
for (i = 0; i < opr_sz; i += 1) {
|
||||||
|
uint64_t nn = n[i], mm = m[i];
|
||||||
|
uint64_t pp = expand_pred_s(pg[H1(i)]);
|
||||||
|
d[i] = (nn & pp) | (mm & ~pp);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void HELPER(sve_sel_zpzz_d)(void *vd, void *vn, void *vm,
|
||||||
|
void *vg, uint32_t desc)
|
||||||
|
{
|
||||||
|
intptr_t i, opr_sz = simd_oprsz(desc) / 8;
|
||||||
|
uint64_t *d = vd, *n = vn, *m = vm;
|
||||||
|
uint8_t *pg = vg;
|
||||||
|
|
||||||
|
for (i = 0; i < opr_sz; i += 1) {
|
||||||
|
uint64_t nn = n[i], mm = m[i];
|
||||||
|
d[i] = (pg[H1(i)] & 1 ? nn : mm);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
@ -380,6 +380,8 @@ static bool trans_UDIV_zpzz(DisasContext *s, arg_rprr_esz *a, uint32_t insn)
|
||||||
return do_zpzz_ool(s, a, fns[a->esz]);
|
return do_zpzz_ool(s, a, fns[a->esz]);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
DO_ZPZZ(SEL, sel)
|
||||||
|
|
||||||
#undef DO_ZPZZ
|
#undef DO_ZPZZ
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
Loading…
Reference in a new issue