| # RUN: llvm-mc -triple=riscv64 -show-encoding --mattr=+v %s \ |
| # RUN: | FileCheck %s --check-prefixes=CHECK-ENCODING,CHECK-INST |
| # RUN: not llvm-mc -triple=riscv64 -show-encoding %s 2>&1 \ |
| # RUN: | FileCheck %s --check-prefix=CHECK-ERROR |
| # RUN: llvm-mc -triple=riscv64 -filetype=obj --mattr=+v %s \ |
| # RUN: | llvm-objdump -d --mattr=+v --no-print-imm-hex - \ |
| # RUN: | FileCheck %s --check-prefix=CHECK-INST |
| # RUN: llvm-mc -triple=riscv64 -filetype=obj --mattr=+v %s \ |
| # RUN: | llvm-objdump -d - | FileCheck %s --check-prefix=CHECK-UNKNOWN |
| |
| # reserved filed: vlmul[2:0]=4, vsew[2:0]=0b1xx, non-zero bits 8/9/10. |
| vsetvli a2, a0, 0x224 |
| # CHECK-INST: vsetvli a2, a0, 548 |
| # CHECK-ENCODING: [0x57,0x76,0x45,0x22] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 22457657 <unknown> |
| |
| vsetvli a2, a0, 0xd0 |
| # CHECK-INST: vsetvli a2, a0, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d057657 <unknown> |
| |
| vsetvli a2, a0, 0xd1 |
| # CHECK-INST: vsetvli a2, a0, e32, m2, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x15,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d157657 <unknown> |
| |
| vsetvli a2, a0, 0x50 |
| # CHECK-INST: vsetvli a2, a0, e32, m1, ta, mu |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x05] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 05057657 <unknown> |
| |
| vsetvli a2, a0, 0x90 |
| # CHECK-INST: vsetvli a2, a0, e32, m1, tu, ma |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x09] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 09057657 <unknown> |
| |
| vsetvli a2, a0, 144 |
| # CHECK-INST: vsetvli a2, a0, e32, m1, tu, ma |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x09] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 09057657 <unknown> |
| |
| vsetvli a2, a0, e32, m1, ta, ma |
| # CHECK-INST: vsetvli a2, a0, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d057657 <unknown> |
| |
| vsetvli a2, a0, e32, m2, ta, ma |
| # CHECK-INST: vsetvli a2, a0, e32, m2, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x15,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d157657 <unknown> |
| |
| vsetvli a2, a0, e32, m4, ta, ma |
| # CHECK-INST: vsetvli a2, a0, e32, m4, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x25,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d257657 <unknown> |
| |
| vsetvli a2, a0, e32, m8, ta, ma |
| # CHECK-INST: vsetvli a2, a0, e32, m8, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x35,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d357657 <unknown> |
| |
| vsetvli a2, a0, e32, mf2, ta, ma |
| # CHECK-INST: vsetvli a2, a0, e32, mf2, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x75,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d757657 <unknown> |
| |
| vsetvli a2, a0, e32, mf4, ta, ma |
| # CHECK-INST: vsetvli a2, a0, e32, mf4, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x65,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d657657 <unknown> |
| |
| vsetvli a2, a0, e32, mf8, ta, ma |
| # CHECK-INST: vsetvli a2, a0, e32, mf8, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x55,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d557657 <unknown> |
| |
| vsetvli a2, a0, e32, m1, ta, ma |
| # CHECK-INST: vsetvli a2, a0, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x0d] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 0d057657 <unknown> |
| |
| vsetvli a2, a0, e32, m1, tu, ma |
| # CHECK-INST: vsetvli a2, a0, e32, m1, tu, ma |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x09] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 09057657 <unknown> |
| |
| vsetvli a2, a0, e32, m1, ta, mu |
| # CHECK-INST: vsetvli a2, a0, e32, m1, ta, mu |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x05] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 05057657 <unknown> |
| |
| vsetvli a2, a0, e32, m1, tu, mu |
| # CHECK-INST: vsetvli a2, a0, e32, m1 |
| # CHECK-ENCODING: [0x57,0x76,0x05,0x01] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 01057657 <unknown> |
| |
| vsetvl a2, a0, a1 |
| # CHECK-INST: vsetvl a2, a0, a1 |
| # CHECK-ENCODING: [0x57,0x76,0xb5,0x80] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: 80b57657 <unknown> |
| |
| # reserved filed: vlmul[2:0]=4, vsew[2:0]=0b1xx, non-zero bits 8/9/10. |
| vsetivli a2, 0, 0x224 |
| # CHECK-INST: vsetivli a2, 0, 548 |
| # CHECK-ENCODING: [0x57,0x76,0x40,0xe2] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: e2407657 <unknown> |
| |
| vsetivli a2, 0, 0xd0 |
| # CHECK-INST: vsetivli a2, 0, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x00,0xcd] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: cd007657 <unknown> |
| |
| vsetivli a2, 15, 0xd0 |
| # CHECK-INST: vsetivli a2, 15, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0xf6,0x07,0xcd] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: cd07f657 <unknown> |
| |
| vsetivli a2, 15, 208 |
| # CHECK-INST: vsetivli a2, 15, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0xf6,0x07,0xcd] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: cd07f657 <unknown> |
| |
| vsetivli a2, 0, e32, m1, ta, ma |
| # CHECK-INST: vsetivli a2, 0, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0x76,0x00,0xcd] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: cd007657 <unknown> |
| |
| vsetivli a2, 15, e32, m1, ta, ma |
| # CHECK-INST: vsetivli a2, 15, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0xf6,0x07,0xcd] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: cd07f657 <unknown> |
| |
| vsetivli a2, 31, e32, m1, ta, ma |
| # CHECK-INST: vsetivli a2, 31, e32, m1, ta, ma |
| # CHECK-ENCODING: [0x57,0xf6,0x0f,0xcd] |
| # CHECK-ERROR: instruction requires the following: 'V' (Vector Extension for Application Processors), 'Zve32x' (Vector Extensions for Embedded Processors){{$}} |
| # CHECK-UNKNOWN: cd0ff657 <unknown> |