]> git.ipfire.org Git - thirdparty/binutils-gdb.git/commitdiff
RISC-V: Scalar crypto instruction and entropy source CSR testcases.
authorjiawei <jiawei@iscas.ac.cn>
Mon, 15 Nov 2021 03:03:43 +0000 (11:03 +0800)
committerNelson Chu <nelson.chu@sifive.com>
Tue, 16 Nov 2021 03:48:23 +0000 (11:48 +0800)
Add testcases for Scalar Crypto extension, with total testcase contain all
instructions in k-ext/k-ext-64 and sub-extension testcase for zbk* zk*. Also
add testcase for new CSR name 'seed' which is the Entropy Source in zkr.

In fact these whole testcases can be combined into one file, after we have
supported the .option arch +-= directives.

gas/
* testsuite/gas/riscv/k-ext-64.d: New testcase for crypto instructions.
* testsuite/gas/riscv/k-ext-64.s: Likewise.
* testsuite/gas/riscv/k-ext.d: Likewise.
* testsuite/gas/riscv/k-ext.s: Likewise.
* testsuite/gas/riscv/zbkb-32.d: Likewise.
* testsuite/gas/riscv/zbkb-32.s: Likewise.
* testsuite/gas/riscv/zbkb-64.d: Likewise.
* testsuite/gas/riscv/zbkb-64.s: Likewise.
* testsuite/gas/riscv/zbkc-32.d: Likewise.
* testsuite/gas/riscv/zbkc-64.d: Likewise.
* testsuite/gas/riscv/zbkc.s: Likewise.
* testsuite/gas/riscv/zbkx-32.d: Likewise.
* testsuite/gas/riscv/zbkx-64.d: Likewise.
* testsuite/gas/riscv/zbkx.s: Likewise.
* testsuite/gas/riscv/zknd-32.d: Likewise.
* testsuite/gas/riscv/zknd-32.s: Likewise.
* testsuite/gas/riscv/zknd-64.d: Likewise.
* testsuite/gas/riscv/zknd-64.s: Likewise.
* testsuite/gas/riscv/zkne-32.d: Likewise.
* testsuite/gas/riscv/zkne-32.s: Likewise.
* testsuite/gas/riscv/zkne-64.d: Likewise.
* testsuite/gas/riscv/zkne-64.s: Likewise.
* testsuite/gas/riscv/zknh-32.d: Likewise.
* testsuite/gas/riscv/zknh-32.s: Likewise.
* testsuite/gas/riscv/zknh-64.d: Likewise.
* testsuite/gas/riscv/zknh-64.s: Likewise.
* testsuite/gas/riscv/zksed-32.d: Likewise.
* testsuite/gas/riscv/zksed-64.d: Likewise.
* testsuite/gas/riscv/zksed.s: Likewise.
* testsuite/gas/riscv/zksh-32.d: Likewise.
* testsuite/gas/riscv/zksh-64.d: Likewise.
* testsuite/gas/riscv/zksh.s: Likewise.
* testsuite/gas/riscv/priv-reg-fail-zkr.d: New testcase for zkr
csr check.
* testsuite/gas/riscv/priv-reg-fail-zkr.l: Likewise.
* testsuite/gas/riscv/priv-reg-fail-version-1p10.d: Updated march to
rv32if_zkr.
* testsuite/gas/riscv/priv-reg-fail-version-1p11.d: Likewise.
* testsuite/gas/riscv/priv-reg-fail-version-1p9p1.d: Likewise.
* testsuite/gas/riscv/priv-reg-version-1p10.d: Added Crypto seed csr.
* testsuite/gas/riscv/priv-reg-version-1p11.d: Likewise.
* testsuite/gas/riscv/priv-reg-version-1p9p1.d: Likewise.
* testsuite/gas/riscv/priv-reg.s: Likewise.

41 files changed:
gas/testsuite/gas/riscv/k-ext-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/k-ext-64.s [new file with mode: 0644]
gas/testsuite/gas/riscv/k-ext.d [new file with mode: 0644]
gas/testsuite/gas/riscv/k-ext.s [new file with mode: 0644]
gas/testsuite/gas/riscv/priv-reg-fail-version-1p10.d
gas/testsuite/gas/riscv/priv-reg-fail-version-1p11.d
gas/testsuite/gas/riscv/priv-reg-fail-version-1p9p1.d
gas/testsuite/gas/riscv/priv-reg-fail-zkr.d [new file with mode: 0644]
gas/testsuite/gas/riscv/priv-reg-fail-zkr.l [new file with mode: 0644]
gas/testsuite/gas/riscv/priv-reg-version-1p10.d
gas/testsuite/gas/riscv/priv-reg-version-1p11.d
gas/testsuite/gas/riscv/priv-reg-version-1p9p1.d
gas/testsuite/gas/riscv/priv-reg.s
gas/testsuite/gas/riscv/zbkb-32.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkb-32.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkb-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkb-64.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkc-32.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkc-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkc.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkx-32.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkx-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zbkx.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zknd-32.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zknd-32.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zknd-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zknd-64.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zkne-32.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zkne-32.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zkne-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zkne-64.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zknh-32.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zknh-32.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zknh-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zknh-64.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zksed-32.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zksed-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zksed.s [new file with mode: 0644]
gas/testsuite/gas/riscv/zksh-32.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zksh-64.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zksh.s [new file with mode: 0644]

diff --git a/gas/testsuite/gas/riscv/k-ext-64.d b/gas/testsuite/gas/riscv/k-ext-64.d
new file mode 100644 (file)
index 0000000..06f4756
--- /dev/null
@@ -0,0 +1,47 @@
+#as: -march=rv64i_zbkb_zbkc_zbkx_zknd_zkne_zknh_zkr_zksed_zksh_zkt
+#source: k-ext-64.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+ror[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rol[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rori[         ]+a0,a1,0x2
+[      ]+.*:[  ]+.*[   ]+rorw[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rolw[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+roriw[        ]+a0,a1,0x2
+[      ]+.*:[  ]+.*[   ]+andn[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+orn[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xnor[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+pack[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+packh[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+packw[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+brev8[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+rev8[         ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+clmul[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+clmulh[       ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xperm4[       ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xperm8[       ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64ds[      ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64dsm[     ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64im[      ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+aes64ks1i[    ]+a0,a1,0x4
+[      ]+.*:[  ]+.*[   ]+aes64ks2[     ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64es[      ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64esm[     ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha256sig0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sig1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sum0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sum1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sig0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sig1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sum0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sum1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sm4ed[        ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+sm4ks[        ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+sm3p0[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sm3p1[        ]+a0,a0
diff --git a/gas/testsuite/gas/riscv/k-ext-64.s b/gas/testsuite/gas/riscv/k-ext-64.s
new file mode 100644 (file)
index 0000000..302b82e
--- /dev/null
@@ -0,0 +1,38 @@
+target:
+        ror     a0, a1, a2
+        rol     a0, a1, a2
+        rori    a0, a1, 2
+        rorw    a0, a1, a2
+        rolw    a0, a1, a2
+        roriw   a0, a1, 2
+        andn    a0, a1, a2
+        orn     a0, a1, a2
+        xnor    a0, a1, a2
+        pack    a0, a1, a2
+        packh   a0, a1, a2
+        packw   a0, a1, a2
+        brev8   a0, a0
+        rev8    a0, a0
+        clmul   a0, a1, a2
+        clmulh  a0, a1, a2
+        xperm4  a0, a1, a2
+        xperm8  a0, a1, a2
+        aes64ds     a0, a1, a2
+        aes64dsm    a0, a1, a2
+        aes64im     a0, a0
+        aes64ks1i   a0, a1, 4
+        aes64ks2    a0, a1, a2
+        aes64es     a0, a1, a2
+        aes64esm    a0, a1, a2
+        sha256sig0  a0, a0
+        sha256sig1  a0, a0
+        sha256sum0  a0, a0
+        sha256sum1  a0, a0
+        sha512sig0  a0, a0
+        sha512sig1  a0, a0
+        sha512sum0  a0, a0
+        sha512sum1  a0, a0
+        sm4ed   a0, a1, a2, 2
+        sm4ks   a0, a1, a2, 2
+        sm3p0   a0, a0
+        sm3p1   a0, a0
diff --git a/gas/testsuite/gas/riscv/k-ext.d b/gas/testsuite/gas/riscv/k-ext.d
new file mode 100644 (file)
index 0000000..3ba65aa
--- /dev/null
@@ -0,0 +1,44 @@
+#as: -march=rv32i_zbkb_zbkc_zbkx_zknd_zkne_zknh_zkr_zksed_zksh_zkt
+#source: k-ext.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+ror[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rol[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rori[         ]+a0,a1,0x2
+[      ]+.*:[  ]+.*[   ]+andn[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+orn[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xnor[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+pack[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+packh[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+brev8[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+rev8[         ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+zip[  ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+unzip[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+clmul[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+clmulh[       ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xperm4[       ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xperm8[       ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes32dsi[     ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+aes32dsmi[    ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+aes32esi[     ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+aes32esmi[    ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+sha256sig0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sig1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sum0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sum1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sig0h[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sig0l[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sig1h[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sig1l[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sum0r[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sum1r[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sm4ed[        ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+sm4ks[        ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+sm3p0[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sm3p1[        ]+a0,a0
diff --git a/gas/testsuite/gas/riscv/k-ext.s b/gas/testsuite/gas/riscv/k-ext.s
new file mode 100644 (file)
index 0000000..8eb2768
--- /dev/null
@@ -0,0 +1,35 @@
+target:
+        ror     a0, a1, a2
+        rol     a0, a1, a2
+        rori    a0, a1, 2
+        andn    a0, a1, a2
+        orn     a0, a1, a2
+        xnor    a0, a1, a2
+        pack    a0, a1, a2
+        packh   a0, a1, a2
+        brev8   a0, a0
+        rev8    a0, a0
+        zip     a0, a0
+        unzip   a0, a0
+        clmul   a0, a1, a2
+        clmulh  a0, a1, a2
+        xperm4  a0, a1, a2
+        xperm8  a0, a1, a2
+        aes32dsi    a0, a1, a2, 2
+        aes32dsmi   a0, a1, a2, 2
+        aes32esi    a0, a1, a2, 2
+        aes32esmi   a0, a1, a2, 2
+        sha256sig0  a0, a0
+        sha256sig1  a0, a0
+        sha256sum0  a0, a0
+        sha256sum1  a0, a0
+        sha512sig0h    a0, a1, a2
+        sha512sig0l    a0, a1, a2
+        sha512sig1h    a0, a1, a2
+        sha512sig1l    a0, a1, a2
+        sha512sum0r    a0, a1, a2
+        sha512sum1r    a0, a1, a2
+        sm4ed   a0, a1, a2, 2
+        sm4ks   a0, a1, a2, 2
+        sm3p0   a0, a0
+        sm3p1   a0, a0
index 07cf05a9c29922eca8cd039af1aa51eb34561e9d..68acc09122f997ed8532533161d9fdf33fa19d97 100644 (file)
@@ -1,4 +1,4 @@
-#as: -march=rv32if -mcsr-check -mpriv-spec=1.10 -march-attr
+#as: -march=rv32if_zkr -mcsr-check -mpriv-spec=1.10 -march-attr
 #source: priv-reg.s
 #warning_output: priv-reg-fail-version-1p10.l
 #readelf: -A
index bf4b1db3ed6321f3d073d062c7f74a4d9a8dd842..3aa611c3a2b04d3408e6edbab59a39d8f98b9b7d 100644 (file)
@@ -1,4 +1,4 @@
-#as: -march=rv32if -mcsr-check -mpriv-spec=1.11 -march-attr
+#as: -march=rv32if_zkr -mcsr-check -mpriv-spec=1.11 -march-attr
 #source: priv-reg.s
 #warning_output: priv-reg-fail-version-1p11.l
 #readelf: -A
index e2c33d81dc874b0440d020371e437e0e839007b5..e08381aee8281ac835ef3bc4e00e6f5d350e82c5 100644 (file)
@@ -1,4 +1,4 @@
-#as: -march=rv32if -mcsr-check -mpriv-spec=1.9.1 -march-attr
+#as: -march=rv32if_zkr -mcsr-check -mpriv-spec=1.9.1 -march-attr
 #source: priv-reg.s
 #warning_output: priv-reg-fail-version-1p9p1.l
 #readelf: -A
diff --git a/gas/testsuite/gas/riscv/priv-reg-fail-zkr.d b/gas/testsuite/gas/riscv/priv-reg-fail-zkr.d
new file mode 100644 (file)
index 0000000..d65d510
--- /dev/null
@@ -0,0 +1,3 @@
+#as: -march=rv32if -mcsr-check
+#source: priv-reg.s
+#warning_output: priv-reg-fail-zkr.l
diff --git a/gas/testsuite/gas/riscv/priv-reg-fail-zkr.l b/gas/testsuite/gas/riscv/priv-reg-fail-zkr.l
new file mode 100644 (file)
index 0000000..107e597
--- /dev/null
@@ -0,0 +1,4 @@
+.*Assembler messages:
+#...
+.*Warning: invalid CSR `seed' for the current ISA
+#...
index 3ad8eebe8512b25a759cce481ccebe7e19c40e2d..78c683d3deab1a69b2e13ead25182135bc685599 100644 (file)
@@ -265,3 +265,4 @@ Disassembly of section .text:
 [      ]+[0-9a-f]+:[   ]+7a102573[     ]+csrr[         ]+a0,tdata1
 [      ]+[0-9a-f]+:[   ]+7a302573[     ]+csrr[         ]+a0,tdata3
 [      ]+[0-9a-f]+:[   ]+7a302573[     ]+csrr[         ]+a0,tdata3
+[      ]+[0-9a-f]+:[   ]+01502573[     ]+csrr[         ]+a0,seed
index 5824bc5e1f67bd9aba432ff180d74a9b75f9b736..6c1cc70479b30fa514824ee0add6c2d263dc1205 100644 (file)
@@ -265,3 +265,4 @@ Disassembly of section .text:
 [      ]+[0-9a-f]+:[   ]+7a102573[     ]+csrr[         ]+a0,tdata1
 [      ]+[0-9a-f]+:[   ]+7a302573[     ]+csrr[         ]+a0,tdata3
 [      ]+[0-9a-f]+:[   ]+7a302573[     ]+csrr[         ]+a0,tdata3
+[      ]+[0-9a-f]+:[   ]+01502573[     ]+csrr[         ]+a0,seed
index 569b9587e29ab8044c09e7eab5d0674263357f05..3d2ab74eb358db4ab576e42fbbee0801d5c726a0 100644 (file)
@@ -265,3 +265,4 @@ Disassembly of section .text:
 [      ]+[0-9a-f]+:[   ]+7a102573[     ]+csrr[         ]+a0,tdata1
 [      ]+[0-9a-f]+:[   ]+7a302573[     ]+csrr[         ]+a0,tdata3
 [      ]+[0-9a-f]+:[   ]+7a302573[     ]+csrr[         ]+a0,tdata3
+[      ]+[0-9a-f]+:[   ]+01502573[     ]+csrr[         ]+a0,seed
index c40d28862b710a698984879a0722c10931ad448b..85ff2a6f4669dd113874ce7d62365ac165324746 100644 (file)
        csr etrigger            # 0x7a1, alias to tdata1
        csr textra32            # 0x7a3, alias to tdata3
        csr textra64            # 0x7a3, alias to tdata3
+
+       # Scalar crypto
+       csr seed                # 0x015, Entropy Source
diff --git a/gas/testsuite/gas/riscv/zbkb-32.d b/gas/testsuite/gas/riscv/zbkb-32.d
new file mode 100644 (file)
index 0000000..75a9259
--- /dev/null
@@ -0,0 +1,22 @@
+#as: -march=rv32i_zbkb
+#source: zbkb-32.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+ror[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rol[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rori[         ]+a0,a1,0x2
+[      ]+.*:[  ]+.*[   ]+andn[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+orn[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xnor[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+pack[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+packh[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+brev8[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+rev8[         ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+zip[  ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+unzip[        ]+a0,a0
diff --git a/gas/testsuite/gas/riscv/zbkb-32.s b/gas/testsuite/gas/riscv/zbkb-32.s
new file mode 100644 (file)
index 0000000..6f91715
--- /dev/null
@@ -0,0 +1,13 @@
+target:
+        ror     a0, a1, a2
+        rol     a0, a1, a2
+        rori    a0, a1, 2
+        andn    a0, a1, a2
+        orn     a0, a1, a2
+        xnor    a0, a1, a2
+        pack    a0, a1, a2
+        packh   a0, a1, a2
+        brev8   a0, a0
+        rev8    a0, a0
+        zip     a0, a0
+        unzip     a0, a0
diff --git a/gas/testsuite/gas/riscv/zbkb-64.d b/gas/testsuite/gas/riscv/zbkb-64.d
new file mode 100644 (file)
index 0000000..2f51db1
--- /dev/null
@@ -0,0 +1,24 @@
+#as: -march=rv64i_zbkb
+#source: zbkb-64.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+ror[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rol[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rori[         ]+a0,a1,0x2
+[      ]+.*:[  ]+.*[   ]+rorw[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+rolw[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+roriw[        ]+a0,a1,0x2
+[      ]+.*:[  ]+.*[   ]+andn[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+orn[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xnor[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+pack[         ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+packh[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+packw[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+brev8[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+rev8[         ]+a0,a0
diff --git a/gas/testsuite/gas/riscv/zbkb-64.s b/gas/testsuite/gas/riscv/zbkb-64.s
new file mode 100644 (file)
index 0000000..b5cf79f
--- /dev/null
@@ -0,0 +1,15 @@
+target:
+        ror     a0, a1, a2
+        rol     a0, a1, a2
+        rori    a0, a1, 2
+        rorw    a0, a1, a2
+        rolw    a0, a1, a2
+        roriw   a0, a1, 2
+        andn    a0, a1, a2
+        orn     a0, a1, a2
+        xnor    a0, a1, a2
+        pack    a0, a1, a2
+        packh   a0, a1, a2
+        packw   a0, a1, a2
+        brev8   a0, a0
+        rev8    a0, a0
diff --git a/gas/testsuite/gas/riscv/zbkc-32.d b/gas/testsuite/gas/riscv/zbkc-32.d
new file mode 100644 (file)
index 0000000..7052f4b
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv32i_zbkc
+#source: zbkc.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+clmul[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+clmulh[       ]+a0,a1,a2
diff --git a/gas/testsuite/gas/riscv/zbkc-64.d b/gas/testsuite/gas/riscv/zbkc-64.d
new file mode 100644 (file)
index 0000000..1620ea9
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv64i_zbkc
+#source: zbkc.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+clmul[        ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+clmulh[       ]+a0,a1,a2
diff --git a/gas/testsuite/gas/riscv/zbkc.s b/gas/testsuite/gas/riscv/zbkc.s
new file mode 100644 (file)
index 0000000..2a98774
--- /dev/null
@@ -0,0 +1,3 @@
+target:
+        clmul   a0, a1, a2
+        clmulh  a0, a1, a2
diff --git a/gas/testsuite/gas/riscv/zbkx-32.d b/gas/testsuite/gas/riscv/zbkx-32.d
new file mode 100644 (file)
index 0000000..3306ab4
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv32i_zbkx
+#source: zbkx.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+xperm4[       ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xperm8[       ]+a0,a1,a2
diff --git a/gas/testsuite/gas/riscv/zbkx-64.d b/gas/testsuite/gas/riscv/zbkx-64.d
new file mode 100644 (file)
index 0000000..95cca8e
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv64i_zbkx
+#source: zbkx.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+xperm4[       ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+xperm8[       ]+a0,a1,a2
diff --git a/gas/testsuite/gas/riscv/zbkx.s b/gas/testsuite/gas/riscv/zbkx.s
new file mode 100644 (file)
index 0000000..8c30771
--- /dev/null
@@ -0,0 +1,3 @@
+target:
+        xperm4  a0, a1, a2
+        xperm8  a0, a1, a2
diff --git a/gas/testsuite/gas/riscv/zknd-32.d b/gas/testsuite/gas/riscv/zknd-32.d
new file mode 100644 (file)
index 0000000..4571261
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv32i_zknd
+#source: zknd-32.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+aes32dsi[     ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+aes32dsmi[    ]+a0,a1,a2,0x2
diff --git a/gas/testsuite/gas/riscv/zknd-32.s b/gas/testsuite/gas/riscv/zknd-32.s
new file mode 100644 (file)
index 0000000..0d09bad
--- /dev/null
@@ -0,0 +1,3 @@
+target:
+        aes32dsi    a0, a1, a2, 2
+        aes32dsmi   a0, a1, a2, 2
diff --git a/gas/testsuite/gas/riscv/zknd-64.d b/gas/testsuite/gas/riscv/zknd-64.d
new file mode 100644 (file)
index 0000000..e12b3ef
--- /dev/null
@@ -0,0 +1,15 @@
+#as: -march=rv64i_zknd
+#source: zknd-64.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+aes64ds[      ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64dsm[     ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64im[      ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+aes64ks1i[    ]+a0,a1,0x4
+[      ]+.*:[  ]+.*[   ]+aes64ks2[     ]+a0,a1,a2
diff --git a/gas/testsuite/gas/riscv/zknd-64.s b/gas/testsuite/gas/riscv/zknd-64.s
new file mode 100644 (file)
index 0000000..4846e93
--- /dev/null
@@ -0,0 +1,6 @@
+target:
+        aes64ds     a0, a1, a2
+        aes64dsm    a0, a1, a2
+        aes64im     a0, a0
+        aes64ks1i   a0, a1, 4
+        aes64ks2    a0, a1, a2
diff --git a/gas/testsuite/gas/riscv/zkne-32.d b/gas/testsuite/gas/riscv/zkne-32.d
new file mode 100644 (file)
index 0000000..2f57359
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv32i_zkne
+#source: zkne-32.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+aes32esi[     ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+aes32esmi[    ]+a0,a1,a2,0x2
diff --git a/gas/testsuite/gas/riscv/zkne-32.s b/gas/testsuite/gas/riscv/zkne-32.s
new file mode 100644 (file)
index 0000000..f864fc1
--- /dev/null
@@ -0,0 +1,3 @@
+target:
+        aes32esi    a0, a1, a2, 2
+        aes32esmi   a0, a1, a2, 2
diff --git a/gas/testsuite/gas/riscv/zkne-64.d b/gas/testsuite/gas/riscv/zkne-64.d
new file mode 100644 (file)
index 0000000..6f6e9c3
--- /dev/null
@@ -0,0 +1,14 @@
+#as: -march=rv64i_zkne
+#source: zkne-64.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+aes64es[      ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64esm[     ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+aes64ks1i[    ]+a0,a1,0x4
+[      ]+.*:[  ]+.*[   ]+aes64ks2[     ]+a0,a1,a2
diff --git a/gas/testsuite/gas/riscv/zkne-64.s b/gas/testsuite/gas/riscv/zkne-64.s
new file mode 100644 (file)
index 0000000..9b56120
--- /dev/null
@@ -0,0 +1,5 @@
+target:
+        aes64es     a0, a1, a2
+        aes64esm    a0, a1, a2
+        aes64ks1i   a0, a1, 4
+        aes64ks2    a0, a1, a2
diff --git a/gas/testsuite/gas/riscv/zknh-32.d b/gas/testsuite/gas/riscv/zknh-32.d
new file mode 100644 (file)
index 0000000..ac4b244
--- /dev/null
@@ -0,0 +1,20 @@
+#as: -march=rv32i_zknh
+#source: zknh-32.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+sha256sig0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sig1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sum0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sum1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sig0h[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sig0l[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sig1h[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sig1l[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sum0r[  ]+a0,a1,a2
+[      ]+.*:[  ]+.*[   ]+sha512sum1r[  ]+a0,a1,a2
diff --git a/gas/testsuite/gas/riscv/zknh-32.s b/gas/testsuite/gas/riscv/zknh-32.s
new file mode 100644 (file)
index 0000000..dc2cd3c
--- /dev/null
@@ -0,0 +1,11 @@
+target:
+        sha256sig0  a0, a0
+        sha256sig1  a0, a0
+        sha256sum0  a0, a0
+        sha256sum1  a0, a0
+        sha512sig0h    a0, a1, a2
+        sha512sig0l    a0, a1, a2
+        sha512sig1h    a0, a1, a2
+        sha512sig1l    a0, a1, a2
+        sha512sum0r    a0, a1, a2
+        sha512sum1r    a0, a1, a2
diff --git a/gas/testsuite/gas/riscv/zknh-64.d b/gas/testsuite/gas/riscv/zknh-64.d
new file mode 100644 (file)
index 0000000..890d5d8
--- /dev/null
@@ -0,0 +1,18 @@
+#as: -march=rv64i_zknh
+#source: zknh-64.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+sha256sig0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sig1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sum0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha256sum1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sig0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sig1[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sum0[   ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sha512sum1[   ]+a0,a0
diff --git a/gas/testsuite/gas/riscv/zknh-64.s b/gas/testsuite/gas/riscv/zknh-64.s
new file mode 100644 (file)
index 0000000..897dc0b
--- /dev/null
@@ -0,0 +1,9 @@
+target:
+        sha256sig0  a0, a0
+        sha256sig1  a0, a0
+        sha256sum0  a0, a0
+        sha256sum1  a0, a0
+        sha512sig0  a0, a0
+        sha512sig1  a0, a0
+        sha512sum0  a0, a0
+        sha512sum1  a0, a0
diff --git a/gas/testsuite/gas/riscv/zksed-32.d b/gas/testsuite/gas/riscv/zksed-32.d
new file mode 100644 (file)
index 0000000..228130a
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv32i_zksed
+#source: zksed.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+sm4ed[        ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+sm4ks[        ]+a0,a1,a2,0x2
diff --git a/gas/testsuite/gas/riscv/zksed-64.d b/gas/testsuite/gas/riscv/zksed-64.d
new file mode 100644 (file)
index 0000000..9a4efdf
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv64i_zksed
+#source: zksed.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+sm4ed[        ]+a0,a1,a2,0x2
+[      ]+.*:[  ]+.*[   ]+sm4ks[        ]+a0,a1,a2,0x2
diff --git a/gas/testsuite/gas/riscv/zksed.s b/gas/testsuite/gas/riscv/zksed.s
new file mode 100644 (file)
index 0000000..ee95c7a
--- /dev/null
@@ -0,0 +1,3 @@
+target:
+        sm4ed   a0, a1, a2, 2
+        sm4ks   a0, a1, a2, 2
diff --git a/gas/testsuite/gas/riscv/zksh-32.d b/gas/testsuite/gas/riscv/zksh-32.d
new file mode 100644 (file)
index 0000000..ab22b3f
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv32i_zksh
+#source: zksh.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+sm3p0[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sm3p1[        ]+a0,a0
diff --git a/gas/testsuite/gas/riscv/zksh-64.d b/gas/testsuite/gas/riscv/zksh-64.d
new file mode 100644 (file)
index 0000000..91a3f16
--- /dev/null
@@ -0,0 +1,12 @@
+#as: -march=rv64i_zksh
+#source: zksh.s
+#objdump: -d
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+
+0+000 <target>:
+[      ]+.*:[  ]+.*[   ]+sm3p0[        ]+a0,a0
+[      ]+.*:[  ]+.*[   ]+sm3p1[        ]+a0,a0
diff --git a/gas/testsuite/gas/riscv/zksh.s b/gas/testsuite/gas/riscv/zksh.s
new file mode 100644 (file)
index 0000000..b321c26
--- /dev/null
@@ -0,0 +1,3 @@
+target:
+        sm3p0   a0, a0
+        sm3p1   a0, a0