mirror of
https://github.com/yuzu-emu/unicorn.git
synced 2024-12-23 10:35:27 +00:00
target/arm: Implement SVE prefetches
Backports commit dec6cf6b43a1e3b18626852064d1e6e863c9b681 from qemu
This commit is contained in:
parent
b78e283513
commit
3a5d095277
|
@ -794,6 +794,29 @@ LD1RQ_zprr 1010010 .. 00 ..... 000 ... ..... ..... \
|
||||||
LD1RQ_zpri 1010010 .. 00 0.... 001 ... ..... ..... \
|
LD1RQ_zpri 1010010 .. 00 0.... 001 ... ..... ..... \
|
||||||
@rpri_load_msz nreg=0
|
@rpri_load_msz nreg=0
|
||||||
|
|
||||||
|
# SVE 32-bit gather prefetch (scalar plus 32-bit scaled offsets)
|
||||||
|
PRF 1000010 00 -1 ----- 0-- --- ----- 0 ----
|
||||||
|
|
||||||
|
# SVE 32-bit gather prefetch (vector plus immediate)
|
||||||
|
PRF 1000010 -- 00 ----- 111 --- ----- 0 ----
|
||||||
|
|
||||||
|
# SVE contiguous prefetch (scalar plus immediate)
|
||||||
|
PRF 1000010 11 1- ----- 0-- --- ----- 0 ----
|
||||||
|
|
||||||
|
# SVE contiguous prefetch (scalar plus scalar)
|
||||||
|
PRF_rr 1000010 -- 00 rm:5 110 --- ----- 0 ----
|
||||||
|
|
||||||
|
### SVE Memory 64-bit Gather Group
|
||||||
|
|
||||||
|
# SVE 64-bit gather prefetch (scalar plus 64-bit scaled offsets)
|
||||||
|
PRF 1100010 00 11 ----- 1-- --- ----- 0 ----
|
||||||
|
|
||||||
|
# SVE 64-bit gather prefetch (scalar plus unpacked 32-bit scaled offsets)
|
||||||
|
PRF 1100010 00 -1 ----- 0-- --- ----- 0 ----
|
||||||
|
|
||||||
|
# SVE 64-bit gather prefetch (vector plus immediate)
|
||||||
|
PRF 1100010 -- 00 ----- 111 --- ----- 0 ----
|
||||||
|
|
||||||
### SVE Memory Store Group
|
### SVE Memory Store Group
|
||||||
|
|
||||||
# SVE contiguous store (scalar plus immediate)
|
# SVE contiguous store (scalar plus immediate)
|
||||||
|
|
|
@ -4465,3 +4465,24 @@ static bool trans_ST1_zprz(DisasContext *s, arg_ST1_zprz *a, uint32_t insn)
|
||||||
cpu_reg_sp(s, a->rn), fn);
|
cpu_reg_sp(s, a->rn), fn);
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
* Prefetches
|
||||||
|
*/
|
||||||
|
|
||||||
|
static bool trans_PRF(DisasContext *s, arg_PRF *a, uint32_t insn)
|
||||||
|
{
|
||||||
|
/* Prefetch is a nop within QEMU. */
|
||||||
|
sve_access_check(s);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
||||||
|
static bool trans_PRF_rr(DisasContext *s, arg_PRF_rr *a, uint32_t insn)
|
||||||
|
{
|
||||||
|
if (a->rm == 31) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
/* Prefetch is a nop within QEMU. */
|
||||||
|
sve_access_check(s);
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in a new issue