RISC-V: Add support for the Zvknc ISA extension
authorNathan Huckleberry <nhuck@google.com>
Fri, 30 Jun 2023 20:44:37 +0000 (22:44 +0200)
committerJeff Law <jlaw@ventanamicro>
Sat, 1 Jul 2023 13:31:05 +0000 (07:31 -0600)
Zvknc is part of the vector crypto extensions.

Zvknc is shorthand for the following set of extensxions:
- Zvkn
- Zvbc

bfd/ChangeLog:

* elfxx-riscv.c: Define Zvknc extension.

gas/ChangeLog:

* testsuite/gas/riscv/zvknc.d: New test.
* testsuite/gas/riscv/zvknc.s: New test.

Signed-off-by: Nathan Huckleberry <nhuck@google.com>
Signed-off-by: Christoph Müllner <christoph.muellner@vrull.eu>
bfd/elfxx-riscv.c
gas/testsuite/gas/riscv/zvknc.d [new file with mode: 0644]
gas/testsuite/gas/riscv/zvknc.s [new file with mode: 0644]

index e2a7d8cebcdc91c4ec30cc09e302d241489f6de3..95b3ab3c2c712fb60349e9322cc9877207000430 100644 (file)
@@ -1162,6 +1162,8 @@ static struct riscv_implicit_subset riscv_implicit_subsets[] =
   {"zvkn", "zvbb",     check_implicit_always},
   {"zvkng", "zvkn",    check_implicit_always},
   {"zvkng", "zvkg",    check_implicit_always},
+  {"zvknc", "zvkn",    check_implicit_always},
+  {"zvknc", "zvbc",    check_implicit_always},
   {"zvks", "zvksed",   check_implicit_always},
   {"zvks", "zvksh",    check_implicit_always},
   {"zvks", "zvbb",     check_implicit_always},
@@ -1278,6 +1280,7 @@ static struct riscv_supported_ext riscv_supported_std_z_ext[] =
   {"zvkg",             ISA_SPEC_CLASS_DRAFT,           1, 0,  0 },
   {"zvkn",             ISA_SPEC_CLASS_DRAFT,           1, 0,  0 },
   {"zvkng",            ISA_SPEC_CLASS_DRAFT,           1, 0,  0 },
+  {"zvknc",            ISA_SPEC_CLASS_DRAFT,           1, 0,  0 },
   {"zvkned",           ISA_SPEC_CLASS_DRAFT,           1, 0,  0 },
   {"zvknha",           ISA_SPEC_CLASS_DRAFT,           1, 0,  0 },
   {"zvknhb",           ISA_SPEC_CLASS_DRAFT,           1, 0,  0 },
diff --git a/gas/testsuite/gas/riscv/zvknc.d b/gas/testsuite/gas/riscv/zvknc.d
new file mode 100644 (file)
index 0000000..f68103b
--- /dev/null
@@ -0,0 +1,18 @@
+#as: -march=rv64gc_zvknc
+#objdump: -dr
+
+.*:[   ]+file format .*
+
+
+Disassembly of section .text:
+0+000 <.text>:
+[      ]+[0-9a-f]+:[   ]+a280a277[     ]+vaesdf.vv[    ]+v4,v8
+[      ]+[0-9a-f]+:[   ]+ba862277[     ]+vsha2ch.vv[   ]+v4,v8,v12
+[      ]+[0-9a-f]+:[   ]+32862257[     +vclmul.vv[     ]+v4,v8,v12
+[      ]+[0-9a-f]+:[   ]+30862257[     ]+vclmul.vv[    ]+v4,v8,v12,v0.t
+[      ]+[0-9a-f]+:[   ]+3285e257[      ]+vclmul.vx[   ]+v4,v8,a1
+[      ]+[0-9a-f]+:[   ]+3085e257[      ]+vclmul.vx[   ]+v4,v8,a1,v0.t
+[      ]+[0-9a-f]+:[   ]+36862257[      ]+vclmulh.vv[  ]+v4,v8,v12
+[      ]+[0-9a-f]+:[   ]+34862257[      ]+vclmulh.vv[  ]+v4,v8,v12,v0.t
+[      ]+[0-9a-f]+:[   ]+3685e257[      ]+vclmulh.vx[  ]+v4,v8,a1
+[      ]+[0-9a-f]+:[   ]+3485e257[      ]+vclmulh.vx[  ]+v4,v8,a1,v0.t
diff --git a/gas/testsuite/gas/riscv/zvknc.s b/gas/testsuite/gas/riscv/zvknc.s
new file mode 100644 (file)
index 0000000..60b10d8
--- /dev/null
@@ -0,0 +1,10 @@
+       vaesdf.vv v4, v8
+       vsha2ch.vv v4, v8, v12
+       vclmul.vv v4, v8, v12
+       vclmul.vv v4, v8, v12, v0.t
+       vclmul.vx v4, v8, a1
+       vclmul.vx v4, v8, a1, v0.t
+       vclmulh.vv v4, v8, v12
+       vclmulh.vv v4, v8, v12, v0.t
+       vclmulh.vx v4, v8, a1
+       vclmulh.vx v4, v8, a1, v0.t