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-prefix=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-prefix=CHECK-ASM-AND-OBJ %s
11
12# CHECK-ASM-AND-OBJ: mul a4, ra, s0
13# CHECK-ASM: encoding: [0x33,0x87,0x80,0x02]
14mul a4, ra, s0
15# CHECK-ASM-AND-OBJ: mulh ra, zero, zero
16# CHECK-ASM: encoding: [0xb3,0x10,0x00,0x02]
17mulh x1, x0, x0
18# CHECK-ASM-AND-OBJ: mulhsu t0, t2, t1
19# CHECK-ASM: encoding: [0xb3,0xa2,0x63,0x02]
20mulhsu t0, t2, t1
21# CHECK-ASM-AND-OBJ: mulhu a5, a4, a3
22# CHECK-ASM: encoding: [0xb3,0x37,0xd7,0x02]
23mulhu a5, a4, a3
24# CHECK-ASM-AND-OBJ: div s0, s0, s0
25# CHECK-ASM: encoding: [0x33,0x44,0x84,0x02]
26div s0, s0, s0
27# CHECK-ASM-AND-OBJ: divu gp, a0, a1
28# CHECK-ASM: encoding: [0xb3,0x51,0xb5,0x02]
29divu gp, a0, a1
30# CHECK-ASM-AND-OBJ: rem s2, s2, s8
31# CHECK-ASM: encoding: [0x33,0x69,0x89,0x03]
32rem s2, s2, s8
33# CHECK-ASM-AND-OBJ: remu s2, s2, s8
34# CHECK-ASM: encoding: [0x33,0x79,0x89,0x03]
35remu x18, x18, x24
36