diff options
author | Peter Maydell <peter.maydell@linaro.org> | 2021-08-13 17:11:56 +0100 |
---|---|---|
committer | Peter Maydell <peter.maydell@linaro.org> | 2021-08-25 10:48:50 +0100 |
commit | 0f31e37c7f0b9577c6ce46304158ccd7c935006b (patch) | |
tree | fbcb2f0f86862ee0c3a48a32e2bd3a1cfcd7add6 /target/arm/t32.decode | |
parent | fea3958fa11c75b4f3f335ac0ce4cfc5cf0af7de (diff) | |
download | qemu-0f31e37c7f0b9577c6ce46304158ccd7c935006b.zip qemu-0f31e37c7f0b9577c6ce46304158ccd7c935006b.tar.gz qemu-0f31e37c7f0b9577c6ce46304158ccd7c935006b.tar.bz2 |
target/arm: Implement MVE VCTP
Implement the MVE VCTP insn, which sets the VPR.P0 predicate bits so
as to predicate any element at index Rn or greater is predicated. As
with VPNOT, this insn itself is predicable and subject to beatwise
execution.
The calculation of the mask is the same as is used to determine
ltpmask in mve_element_mask(), but we precalculate masklen in
generated code to avoid having to have 4 helpers specialized by size.
We put the decode line in with the low-overhead-loop insns in
t32.decode because it's logically part of that collection of insn
patterns, even though it is an MVE only insn.
Signed-off-by: Peter Maydell <peter.maydell@linaro.org>
Reviewed-by: Richard Henderson <richard.henderson@linaro.org>
Diffstat (limited to 'target/arm/t32.decode')
-rw-r--r-- | target/arm/t32.decode | 1 |
1 files changed, 1 insertions, 0 deletions
diff --git a/target/arm/t32.decode b/target/arm/t32.decode index 2d47f31..78fadef 100644 --- a/target/arm/t32.decode +++ b/target/arm/t32.decode @@ -748,5 +748,6 @@ BL 1111 0. .......... 11.1 ............ @branch24 # This is DLSTP DLS 1111 0 0000 0 size:2 rn:4 1110 0000 0000 0001 } + VCTP 1111 0 0000 0 size:2 rn:4 1110 1000 0000 0001 ] } |