mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2025-07-10 15:47:23 +00:00
target/arm: Update BRKA, BRKB, BRKN for PREDDESC
Since b64ee454a4a0, all predicate operations should be using these field macros for predicates. Backports 04c774a25da78eb07d505ee5923167c2010b9f8c
This commit is contained in:
parent
452891c530
commit
7e26827ea5
|
@ -2709,7 +2709,7 @@ static uint32_t do_zero(ARMPredicateReg *d, intptr_t oprsz)
|
||||||
void HELPER(sve_brkpa)(void *vd, void *vn, void *vm, void *vg,
|
void HELPER(sve_brkpa)(void *vd, void *vn, void *vm, void *vg,
|
||||||
uint32_t pred_desc)
|
uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
if (last_active_pred(vn, vg, oprsz)) {
|
if (last_active_pred(vn, vg, oprsz)) {
|
||||||
compute_brk_z(vd, vm, vg, oprsz, true);
|
compute_brk_z(vd, vm, vg, oprsz, true);
|
||||||
} else {
|
} else {
|
||||||
|
@ -2720,7 +2720,7 @@ void HELPER(sve_brkpa)(void *vd, void *vn, void *vm, void *vg,
|
||||||
uint32_t HELPER(sve_brkpas)(void *vd, void *vn, void *vm, void *vg,
|
uint32_t HELPER(sve_brkpas)(void *vd, void *vn, void *vm, void *vg,
|
||||||
uint32_t pred_desc)
|
uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
if (last_active_pred(vn, vg, oprsz)) {
|
if (last_active_pred(vn, vg, oprsz)) {
|
||||||
return compute_brks_z(vd, vm, vg, oprsz, true);
|
return compute_brks_z(vd, vm, vg, oprsz, true);
|
||||||
} else {
|
} else {
|
||||||
|
@ -2731,7 +2731,7 @@ uint32_t HELPER(sve_brkpas)(void *vd, void *vn, void *vm, void *vg,
|
||||||
void HELPER(sve_brkpb)(void *vd, void *vn, void *vm, void *vg,
|
void HELPER(sve_brkpb)(void *vd, void *vn, void *vm, void *vg,
|
||||||
uint32_t pred_desc)
|
uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
if (last_active_pred(vn, vg, oprsz)) {
|
if (last_active_pred(vn, vg, oprsz)) {
|
||||||
compute_brk_z(vd, vm, vg, oprsz, false);
|
compute_brk_z(vd, vm, vg, oprsz, false);
|
||||||
} else {
|
} else {
|
||||||
|
@ -2742,7 +2742,7 @@ void HELPER(sve_brkpb)(void *vd, void *vn, void *vm, void *vg,
|
||||||
uint32_t HELPER(sve_brkpbs)(void *vd, void *vn, void *vm, void *vg,
|
uint32_t HELPER(sve_brkpbs)(void *vd, void *vn, void *vm, void *vg,
|
||||||
uint32_t pred_desc)
|
uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
if (last_active_pred(vn, vg, oprsz)) {
|
if (last_active_pred(vn, vg, oprsz)) {
|
||||||
return compute_brks_z(vd, vm, vg, oprsz, false);
|
return compute_brks_z(vd, vm, vg, oprsz, false);
|
||||||
} else {
|
} else {
|
||||||
|
@ -2752,56 +2752,55 @@ uint32_t HELPER(sve_brkpbs)(void *vd, void *vn, void *vm, void *vg,
|
||||||
|
|
||||||
void HELPER(sve_brka_z)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
void HELPER(sve_brka_z)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
compute_brk_z(vd, vn, vg, oprsz, true);
|
compute_brk_z(vd, vn, vg, oprsz, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t HELPER(sve_brkas_z)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
uint32_t HELPER(sve_brkas_z)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
return compute_brks_z(vd, vn, vg, oprsz, true);
|
return compute_brks_z(vd, vn, vg, oprsz, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void HELPER(sve_brkb_z)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
void HELPER(sve_brkb_z)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
compute_brk_z(vd, vn, vg, oprsz, false);
|
compute_brk_z(vd, vn, vg, oprsz, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t HELPER(sve_brkbs_z)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
uint32_t HELPER(sve_brkbs_z)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
return compute_brks_z(vd, vn, vg, oprsz, false);
|
return compute_brks_z(vd, vn, vg, oprsz, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void HELPER(sve_brka_m)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
void HELPER(sve_brka_m)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
compute_brk_m(vd, vn, vg, oprsz, true);
|
compute_brk_m(vd, vn, vg, oprsz, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t HELPER(sve_brkas_m)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
uint32_t HELPER(sve_brkas_m)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
return compute_brks_m(vd, vn, vg, oprsz, true);
|
return compute_brks_m(vd, vn, vg, oprsz, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void HELPER(sve_brkb_m)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
void HELPER(sve_brkb_m)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
compute_brk_m(vd, vn, vg, oprsz, false);
|
compute_brk_m(vd, vn, vg, oprsz, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
uint32_t HELPER(sve_brkbs_m)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
uint32_t HELPER(sve_brkbs_m)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
return compute_brks_m(vd, vn, vg, oprsz, false);
|
return compute_brks_m(vd, vn, vg, oprsz, false);
|
||||||
}
|
}
|
||||||
|
|
||||||
void HELPER(sve_brkn)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
void HELPER(sve_brkn)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
|
|
||||||
if (!last_active_pred(vn, vg, oprsz)) {
|
if (!last_active_pred(vn, vg, oprsz)) {
|
||||||
do_zero(vd, oprsz);
|
do_zero(vd, oprsz);
|
||||||
}
|
}
|
||||||
|
@ -2826,8 +2825,7 @@ static uint32_t predtest_ones(ARMPredicateReg *d, intptr_t oprsz,
|
||||||
|
|
||||||
uint32_t HELPER(sve_brkns)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
uint32_t HELPER(sve_brkns)(void *vd, void *vn, void *vg, uint32_t pred_desc)
|
||||||
{
|
{
|
||||||
intptr_t oprsz = extract32(pred_desc, 0, SIMD_OPRSZ_BITS) + 2;
|
intptr_t oprsz = FIELD_EX32(pred_desc, PREDDESC, OPRSZ);
|
||||||
|
|
||||||
if (last_active_pred(vn, vg, oprsz)) {
|
if (last_active_pred(vn, vg, oprsz)) {
|
||||||
return predtest_ones(vd, oprsz, -1);
|
return predtest_ones(vd, oprsz, -1);
|
||||||
} else {
|
} else {
|
||||||
|
|
Loading…
Reference in a new issue