| # RUN: llvm-mc %s -triple=riscv32 -mattr=+m,+zbb,+zba,+zcb -M no-aliases -show-encoding \ |
| # RUN: | FileCheck -check-prefixes=CHECK-ASM,CHECK-ASM-AND-OBJ %s |
| # RUN: llvm-mc -filetype=obj -triple=riscv32 -mattr=+m,+zbb,+zba,+zcb < %s \ |
| # RUN: | llvm-objdump --mattr=+m,+zbb,+zba,+zcb --no-print-imm-hex -M no-aliases -d -r - \ |
| # RUN: | FileCheck --check-prefixes=CHECK-ASM-AND-OBJ %s |
| # RUN: llvm-mc %s -triple=riscv64 -mattr=+m,+zbb,+zba,+zcb -M no-aliases -show-encoding \ |
| # RUN: | FileCheck -check-prefixes=CHECK-ASM,CHECK-ASM-AND-OBJ %s |
| # RUN: llvm-mc -filetype=obj -triple=riscv64 -mattr=+m,+zbb,+zba,+zcb < %s \ |
| # RUN: | llvm-objdump --mattr=+m,+zbb,+zba,zcb --no-print-imm-hex -M no-aliases -d -r - \ |
| # RUN: | FileCheck --check-prefixes=CHECK-ASM-AND-OBJ %s |
| # |
| # RUN: not llvm-mc -triple riscv32 \ |
| # RUN: -M no-aliases -show-encoding < %s 2>&1 \ |
| # RUN: | FileCheck -check-prefixes=CHECK-NO-EXT %s |
| # RUN: not llvm-mc -triple riscv64 \ |
| # RUN: -M no-aliases -show-encoding < %s 2>&1 \ |
| # RUN: | FileCheck -check-prefixes=CHECK-NO-EXT %s |
| |
| # CHECK-ASM-AND-OBJ: c.zext.b s0 |
| # CHECK-ASM: encoding: [0x61,0x9c] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.zext.b s0 |
| |
| # CHECK-ASM-AND-OBJ: c.sext.b s0 |
| # CHECK-ASM: encoding: [0x65,0x9c] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zbb' (Basic Bit-Manipulation), 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.sext.b s0 |
| |
| # CHECK-ASM-AND-OBJ: c.zext.h s0 |
| # CHECK-ASM: encoding: [0x69,0x9c] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zbb' (Basic Bit-Manipulation), 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.zext.h s0 |
| |
| # CHECK-ASM-AND-OBJ: c.sext.h s0 |
| # CHECK-ASM: encoding: [0x6d,0x9c] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zbb' (Basic Bit-Manipulation), 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.sext.h s0 |
| |
| # CHECK-ASM-AND-OBJ: c.not s0 |
| # CHECK-ASM: encoding: [0x75,0x9c] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.not s0 |
| |
| # CHECK-ASM-AND-OBJ: c.mul s0, s1 |
| # CHECK-ASM: encoding: [0x45,0x9c] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zcb' (Compressed basic bit manipulation instructions), 'Zmmul' (Integer Multiplication) |
| c.mul s0, s1 |
| |
| # CHECK-ASM-AND-OBJ: c.lbu a5, 2(a4) |
| # CHECK-ASM: encoding: [0x3c,0x83] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.lbu a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.lhu a5, 2(a4) |
| # CHECK-ASM: encoding: [0x3c,0x87] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.lhu a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.lh a5, 2(a4) |
| # CHECK-ASM: encoding: [0x7c,0x87] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.lh a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.sb a5, 2(a4) |
| # CHECK-ASM: encoding: [0x3c,0x8b] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.sb a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.sh a5, 2(a4) |
| # CHECK-ASM: encoding: [0x3c,0x8f] |
| # CHECK-NO-EXT: error: instruction requires the following: 'Zcb' (Compressed basic bit manipulation instructions){{$}} |
| c.sh a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.mul s0, s1 |
| # CHECK-ASM: encoding: [0x45,0x9c] |
| mul s0, s1, s0 |
| |
| # CHECK-ASM-AND-OBJ: c.mul s0, s1 |
| # CHECK-ASM: encoding: [0x45,0x9c] |
| mul s0, s0, s1 |
| |
| # CHECK-ASM-AND-OBJ: c.sext.b s0 |
| # CHECK-ASM: encoding: [0x65,0x9c] |
| sext.b s0, s0 |
| |
| # CHECK-ASM-AND-OBJ: c.sext.h s0 |
| # CHECK-ASM: encoding: [0x6d,0x9c] |
| sext.h s0, s0 |
| |
| # CHECK-ASM-AND-OBJ: c.zext.h s0 |
| # CHECK-ASM: encoding: [0x69,0x9c] |
| zext.h s0, s0 |
| |
| # CHECK-ASM-AND-OBJ: c.zext.b s0 |
| # CHECK-ASM: encoding: [0x61,0x9c] |
| andi s0, s0, 255 |
| |
| # CHECK-ASM-AND-OBJ: c.not s0 |
| # CHECK-ASM: encoding: [0x75,0x9c] |
| xori s0, s0, -1 |
| |
| # CHECK-ASM-AND-OBJ: c.lh a5, 2(a4) |
| # CHECK-ASM: encoding: [0x7c,0x87] |
| lh a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.lbu a5, 2(a4) |
| # CHECK-ASM: encoding: [0x3c,0x83] |
| lbu a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.lhu a5, 2(a4) |
| # CHECK-ASM: encoding: [0x3c,0x87] |
| lhu a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.sb a5, 2(a4) |
| # CHECK-ASM: encoding: [0x3c,0x8b] |
| sb a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.sh a5, 2(a4) |
| # CHECK-ASM: encoding: [0x3c,0x8f] |
| sh a5, 2(a4) |
| |
| # CHECK-ASM-AND-OBJ: c.lbu s0, 0(s1) |
| # CHECK-ASM: encoding: [0x80,0x80] |
| c.lbu s0, (s1) |
| |
| # CHECK-ASM-AND-OBJ: c.lhu s0, 0(s1) |
| # CHECK-ASM: encoding: [0x80,0x84] |
| c.lhu s0, (s1) |
| |
| # CHECK-ASM-AND-OBJ: c.lh s0, 0(s1) |
| # CHECK-ASM: encoding: [0xc0,0x84] |
| c.lh s0, (s1) |
| |
| # CHECK-ASM-AND-OBJ: c.sb s0, 0(s1) |
| # CHECK-ASM: encoding: [0x80,0x88] |
| c.sb s0, (s1) |
| |
| # CHECK-ASM-AND-OBJ: c.sh s0, 0(s1) |
| # CHECK-ASM: encoding: [0x80,0x8c] |
| c.sh s0, (s1) |