summaryrefslogtreecommitdiffstats
path: root/llvm/test/MC/Disassembler/PowerPC
diff options
context:
space:
mode:
authorChuang-Yu Cheng <cycheng@multicorewareinc.com>2016-03-26 05:46:11 +0000
committerChuang-Yu Cheng <cycheng@multicorewareinc.com>2016-03-26 05:46:11 +0000
commit065969ec8e492eb8f9724492bda55d3ec9b7e68d (patch)
tree0865e77923eacbad0f8633a5aaf8bd618ec13f9b /llvm/test/MC/Disassembler/PowerPC
parent01e321306b9f505afa2c15428bfcb2143a70a95f (diff)
downloadbcm5719-llvm-065969ec8e492eb8f9724492bda55d3ec9b7e68d.tar.gz
bcm5719-llvm-065969ec8e492eb8f9724492bda55d3ec9b7e68d.zip
[Power9] Implement new altivec instructions: permute, count zero, extend sign, negate, parity, shift/rotate, mul10
This change implements the following vector operations: - vclzlsbb vctzlsbb vctzb vctzd vctzh vctzw - vextsb2w vextsh2w vextsb2d vextsh2d vextsw2d - vnegd vnegw - vprtybd vprtybq vprtybw - vbpermd vpermr - vrlwnm vrlwmi vrldnm vrldmi vslv vsrv - vmul10cuq vmul10uq vmul10ecuq vmul10euq 28 instructions Thanks Nemanja, Kit for invaluable hints and discussion! Reviewers: hal, nemanja, kbarton, tjablin, amehsan Phabricator: http://reviews.llvm.org/D15887 llvm-svn: 264504
Diffstat (limited to 'llvm/test/MC/Disassembler/PowerPC')
-rw-r--r--llvm/test/MC/Disassembler/PowerPC/ppc64-encoding-vmx.txt85
1 files changed, 85 insertions, 0 deletions
diff --git a/llvm/test/MC/Disassembler/PowerPC/ppc64-encoding-vmx.txt b/llvm/test/MC/Disassembler/PowerPC/ppc64-encoding-vmx.txt
index f6011d2565f..7fb37d65d9f 100644
--- a/llvm/test/MC/Disassembler/PowerPC/ppc64-encoding-vmx.txt
+++ b/llvm/test/MC/Disassembler/PowerPC/ppc64-encoding-vmx.txt
@@ -752,3 +752,88 @@
# CHECK: vinsertd 2, 3, 8
0x10 0x48 0x1b 0xcd
+# Power9 instructions
+
+# CHECK: vclzlsbb 2, 3
+0x10 0x40 0x1e 0x02
+
+# CHECK: vctzlsbb 2, 3
+0x10 0x41 0x1e 0x02
+
+# CHECK: vctzb 2, 3
+0x10 0x5c 0x1e 0x02
+
+# CHECK: vctzh 2, 3
+0x10 0x5d 0x1e 0x02
+
+# CHECK: vctzw 2, 3
+0x10 0x5e 0x1e 0x02
+
+# CHECK: vctzd 2, 3
+0x10 0x5f 0x1e 0x02
+
+# CHECK: vextsb2w 2, 3
+0x10 0x50 0x1e 0x02
+
+# CHECK: vextsh2w 2, 3
+0x10 0x51 0x1e 0x02
+
+# CHECK: vextsb2d 2, 3
+0x10 0x58 0x1e 0x02
+
+# CHECK: vextsh2d 2, 3
+0x10 0x59 0x1e 0x02
+
+# CHECK: vextsw2d 2, 3
+0x10 0x5a 0x1e 0x02
+
+# CHECK: vnegw 2, 3
+0x10 0x46 0x1e 0x02
+
+# CHECK: vnegd 2, 3
+0x10 0x47 0x1e 0x02
+
+# CHECK: vprtybw 2, 3
+0x10 0x48 0x1e 0x02
+
+# CHECK: vprtybd 2, 3
+0x10 0x49 0x1e 0x02
+
+# CHECK: vprtybq 2, 3
+0x10 0x4a 0x1e 0x02
+
+# CHECK: vbpermd 2, 5, 17
+0x10 0x45 0x8d 0xcc
+
+# CHECK: vpermr 2, 3, 4, 5
+0x10 0x43 0x21 0x7b
+
+# CHECK: vrlwnm 2, 3, 4
+0x10 0x43 0x21 0x85
+
+# CHECK: vrlwmi 2, 3, 4
+0x10 0x43 0x20 0x85
+
+# CHECK: vrldnm 2, 3, 4
+0x10 0x43 0x21 0xc5
+
+# CHECK: vrldmi 2, 3, 4
+0x10 0x43 0x20 0xc5
+
+# CHECK: vslv 2, 3, 4
+0x10 0x43 0x27 0x44
+
+# CHECK: vsrv 2, 3, 4
+0x10 0x43 0x27 0x04
+
+# CHECK: vmul10uq 2, 3
+0x10 0x43 0x02 0x01
+
+# CHECK: vmul10cuq 2, 3
+0x10 0x43 0x00 0x01
+
+# CHECK: vmul10euq 2, 3, 4
+0x10 0x43 0x22 0x41
+
+# CHECK: vmul10ecuq 2, 3, 4
+0x10 0x43 0x20 0x41
OpenPOWER on IntegriCloud