[InstCombine] Signed saturation patterns
[llvm-core.git] / test / MC / RISCV / rv32m-valid.s
blobfcefdda034dd3530fc2db01803f869a13c99daf9
1 # RUN: llvm-mc %s -triple=riscv32 -mattr=+m -riscv-no-aliases -show-encoding \
2 # RUN: | FileCheck -check-prefixes=CHECK-ASM,CHECK-ASM-AND-OBJ %s
3 # RUN: llvm-mc %s -triple=riscv64 -mattr=+m -riscv-no-aliases -show-encoding \
4 # RUN: | FileCheck -check-prefixes=CHECK-ASM,CHECK-ASM-AND-OBJ %s
5 # RUN: llvm-mc -filetype=obj -triple=riscv32 -mattr=+m < %s \
6 # RUN: | llvm-objdump -mattr=+m -M no-aliases -d -r - \
7 # RUN: | FileCheck -check-prefixes=CHECK-OBJ,CHECK-ASM-AND-OBJ %s
8 # RUN: llvm-mc -filetype=obj -triple=riscv64 -mattr=+m < %s \
9 # RUN: | llvm-objdump -mattr=+m -M no-aliases -d -r - \
10 # RUN: | FileCheck -check-prefixes=CHECK-OBJ,CHECK-ASM-AND-OBJ %s
12 # CHECK-ASM-AND-OBJ: mul a4, ra, s0
13 # CHECK-ASM: encoding: [0x33,0x87,0x80,0x02]
14 mul a4, ra, s0
15 # CHECK-ASM-AND-OBJ: mulh ra, zero, zero
16 # CHECK-ASM: encoding: [0xb3,0x10,0x00,0x02]
17 mulh x1, x0, x0
18 # CHECK-ASM-AND-OBJ: mulhsu t0, t2, t1
19 # CHECK-ASM: encoding: [0xb3,0xa2,0x63,0x02]
20 mulhsu t0, t2, t1
21 # CHECK-ASM-AND-OBJ: mulhu a5, a4, a3
22 # CHECK-ASM: encoding: [0xb3,0x37,0xd7,0x02]
23 mulhu a5, a4, a3
24 # CHECK-ASM-AND-OBJ: div s0, s0, s0
25 # CHECK-ASM: encoding: [0x33,0x44,0x84,0x02]
26 div s0, s0, s0
27 # CHECK-ASM-AND-OBJ: divu gp, a0, a1
28 # CHECK-ASM: encoding: [0xb3,0x51,0xb5,0x02]
29 divu gp, a0, a1
30 # CHECK-ASM-AND-OBJ: rem s2, s2, s8
31 # CHECK-ASM: encoding: [0x33,0x69,0x89,0x03]
32 rem s2, s2, s8
33 # CHECK-ASM-AND-OBJ: remu s2, s2, s8
34 # CHECK-ASM: encoding: [0x33,0x79,0x89,0x03]
35 remu x18, x18, x24