xref: /llvm-project/llvm/test/MC/RISCV/rvv/zvknh.s (revision b27f86b40b20942c0e809128214b43d6edde365a)
1# RUN: llvm-mc -triple=riscv32 -show-encoding --mattr=+zve32x --mattr=+zvknha %s \
2# RUN:        | FileCheck %s --check-prefixes=CHECK-ENCODING,CHECK-INST
3# RUN: llvm-mc -triple=riscv64 -show-encoding --mattr=+zve64x --mattr=+zvknhb %s \
4# RUN:        | FileCheck %s --check-prefixes=CHECK-ENCODING,CHECK-INST
5# RUN: llvm-mc -triple=riscv32 -filetype=obj --mattr=+zve32x --mattr=+zvknha %s \
6# RUN:        | llvm-objdump -d --mattr=+zve32x --mattr=+zvknha  - \
7# RUN:        | FileCheck %s --check-prefix=CHECK-INST
8# RUN: llvm-mc -triple=riscv64 -filetype=obj --mattr=+zve64x --mattr=+zvknhb %s \
9# RUN:        | llvm-objdump -d --mattr=+zve64x --mattr=+zvknhb  - \
10# RUN:        | FileCheck %s --check-prefix=CHECK-INST
11# RUN: llvm-mc -triple=riscv32 -filetype=obj --mattr=+zve32x --mattr=+zvknha %s \
12# RUN:        | llvm-objdump -d - | FileCheck %s --check-prefix=CHECK-UNKNOWN
13# RUN: llvm-mc -triple=riscv64 -filetype=obj --mattr=+zve64x --mattr=+zvknhb %s \
14# RUN:        | llvm-objdump -d - | FileCheck %s --check-prefix=CHECK-UNKNOWN
15# RUN: not llvm-mc -triple=riscv32 -show-encoding %s 2>&1 \
16# RUN:        | FileCheck %s --check-prefix=CHECK-ERROR
17
18vsha2ms.vv v10, v9, v8
19# CHECK-INST: vsha2ms.vv v10, v9, v8
20# CHECK-ENCODING: [0x77,0x25,0x94,0xb6]
21# CHECK-UNKNOWN: b6942577 <unknown>
22# CHECK-ERROR: instruction requires the following: 'Zvknha' or 'Zvknhb' (Vector SHA-2){{$}}
23
24vsha2ch.vv v10, v9, v8
25# CHECK-INST: vsha2ch.vv v10, v9, v8
26# CHECK-ENCODING: [0x77,0x25,0x94,0xba]
27# CHECK-UNKNOWN: ba942577 <unknown>
28# CHECK-ERROR: instruction requires the following: 'Zvknha' or 'Zvknhb' (Vector SHA-2){{$}}
29
30vsha2cl.vv v10, v9, v8
31# CHECK-INST: vsha2cl.vv v10, v9, v8
32# CHECK-ENCODING: [0x77,0x25,0x94,0xbe]
33# CHECK-UNKNOWN: be942577 <unknown>
34# CHECK-ERROR: instruction requires the following: 'Zvknha' or 'Zvknhb' (Vector SHA-2){{$}}
35