1 # RUN: llvm-mc %s -triple=riscv32 -mattr=+d -riscv-no-aliases -show-encoding \
2 # RUN: | FileCheck -check-prefixes=CHECK-ASM,CHECK-ASM-AND-OBJ %s
3 # RUN: llvm-mc -filetype=obj -triple=riscv32 -mattr=+d < %s \
4 # RUN: | llvm-objdump -mattr=+d -M no-aliases -d -r - \
5 # RUN: | FileCheck -check-prefixes=CHECK-OBJ,CHECK-ASM-AND-OBJ %s
6 # RUN: llvm-mc %s -triple=riscv64 -mattr=+d -riscv-no-aliases -show-encoding \
7 # RUN: | FileCheck -check-prefixes=CHECK-ASM,CHECK-ASM-AND-OBJ %s
8 # RUN: llvm-mc -filetype=obj -triple=riscv64 -mattr=+d < %s \
9 # RUN: | llvm-objdump -mattr=+d -M no-aliases -d -r - \
10 # RUN: | FileCheck -check-prefixes=CHECK-OBJ,CHECK-ASM-AND-OBJ %s
12 # Support for the 'D' extension implies support for 'F'
13 # CHECK-ASM-AND-OBJ: fadd.s fs10, fs11, ft8
14 # CHECK-ASM: encoding: [0x53,0xfd,0xcd,0x01]
17 # CHECK-ASM-AND-OBJ: fld ft0, 12(a0)
18 # CHECK-ASM: encoding: [0x07,0x30,0xc5,0x00]
20 # CHECK-ASM-AND-OBJ: fld ft1, 4(ra)
21 # CHECK-ASM: encoding: [0x87,0xb0,0x40,0x00]
23 # CHECK-ASM-AND-OBJ: fld ft2, -2048(a3)
24 # CHECK-ASM: encoding: [0x07,0xb1,0x06,0x80]
26 # CHECK-ASM-AND-OBJ: fld ft3, -2048(s1)
27 # CHECK-ASM: encoding: [0x87,0xb1,0x04,0x80]
29 # CHECK-ASM-AND-OBJ: fld ft4, 2047(s2)
30 # CHECK-ASM: encoding: [0x07,0x32,0xf9,0x7f]
32 # CHECK-ASM-AND-OBJ: fld ft5, 0(s3)
33 # CHECK-ASM: encoding: [0x87,0xb2,0x09,0x00]
36 # CHECK-ASM-AND-OBJ: fsd ft6, 2047(s4)
37 # CHECK-ASM: encoding: [0xa7,0x3f,0x6a,0x7e]
39 # CHECK-ASM-AND-OBJ: fsd ft7, -2048(s5)
40 # CHECK-ASM: encoding: [0x27,0xb0,0x7a,0x80]
42 # CHECK-ASM-AND-OBJ: fsd fs0, -2048(s6)
43 # CHECK-ASM: encoding: [0x27,0x30,0x8b,0x80]
45 # CHECK-ASM-AND-OBJ: fsd fs1, 999(s7)
46 # CHECK-ASM: encoding: [0xa7,0xb3,0x9b,0x3e]
49 # CHECK-ASM-AND-OBJ: fmadd.d fa0, fa1, fa2, fa3, dyn
50 # CHECK-ASM: encoding: [0x43,0xf5,0xc5,0x6a]
51 fmadd.d
f10, f11, f12, f13, dyn
52 # CHECK-ASM-AND-OBJ: fmsub.d fa4, fa5, fa6, fa7, dyn
53 # CHECK-ASM: encoding: [0x47,0xf7,0x07,0x8b]
54 fmsub.d
f14, f15, f16, f17, dyn
55 # CHECK-ASM-AND-OBJ: fnmsub.d fs2, fs3, fs4, fs5, dyn
56 # CHECK-ASM: encoding: [0x4b,0xf9,0x49,0xab]
57 fnmsub.d
f18, f19, f20, f21, dyn
58 # CHECK-ASM-AND-OBJ: fnmadd.d fs6, fs7, fs8, fs9, dyn
59 # CHECK-ASM: encoding: [0x4f,0xfb,0x8b,0xcb]
60 fnmadd.d
f22, f23, f24, f25, dyn
62 # CHECK-ASM-AND-OBJ: fadd.d fs10, fs11, ft8, dyn
63 # CHECK-ASM: encoding: [0x53,0xfd,0xcd,0x03]
64 fadd.d
f26, f27, f28, dyn
65 # CHECK-ASM-AND-OBJ: fsub.d ft9, ft10, ft11, dyn
66 # CHECK-ASM: encoding: [0xd3,0x7e,0xff,0x0b]
67 fsub.d
f29, f30, f31, dyn
68 # CHECK-ASM-AND-OBJ: fmul.d ft0, ft1, ft2, dyn
69 # CHECK-ASM: encoding: [0x53,0xf0,0x20,0x12]
70 fmul.d ft0
, ft1
, ft2
, dyn
71 # CHECK-ASM-AND-OBJ: fdiv.d ft3, ft4, ft5, dyn
72 # CHECK-ASM: encoding: [0xd3,0x71,0x52,0x1a]
73 fdiv.d ft3
, ft4
, ft5
, dyn
74 # CHECK-ASM-AND-OBJ: fsqrt.d ft6, ft7, dyn
75 # CHECK-ASM: encoding: [0x53,0xf3,0x03,0x5a]
77 # CHECK-ASM-AND-OBJ: fsgnj.d fs1, fa0, fa1
78 # CHECK-ASM: encoding: [0xd3,0x04,0xb5,0x22]
80 # CHECK-ASM-AND-OBJ: fsgnjn.d fa1, fa3, fa4
81 # CHECK-ASM: encoding: [0xd3,0x95,0xe6,0x22]
82 fsgnjn.d fa1
, fa3
, fa4
83 # CHECK-ASM-AND-OBJ: fsgnjx.d fa3, fa2, fa1
84 # CHECK-ASM: encoding: [0xd3,0x26,0xb6,0x22]
85 fsgnjx.d fa3
, fa2
, fa1
86 # CHECK-ASM-AND-OBJ: fmin.d fa5, fa6, fa7
87 # CHECK-ASM: encoding: [0xd3,0x07,0x18,0x2b]
89 # CHECK-ASM-AND-OBJ: fmax.d fs2, fs3, fs4
90 # CHECK-ASM: encoding: [0x53,0x99,0x49,0x2b]
93 # CHECK-ASM-AND-OBJ: fcvt.s.d fs5, fs6, dyn
94 # CHECK-ASM: encoding: [0xd3,0x7a,0x1b,0x40]
95 fcvt.s.d fs5
, fs6
, dyn
96 # CHECK-ASM-AND-OBJ: fcvt.d.s fs7, fs8
97 # CHECK-ASM: encoding: [0xd3,0x0b,0x0c,0x42]
99 # CHECK-ASM-AND-OBJ: feq.d a1, fs8, fs9
100 # CHECK-ASM: encoding: [0xd3,0x25,0x9c,0xa3]
102 # CHECK-ASM-AND-OBJ: flt.d a2, fs10, fs11
103 # CHECK-ASM: encoding: [0x53,0x16,0xbd,0xa3]
105 # CHECK-ASM-AND-OBJ: fle.d a3, ft8, ft9
106 # CHECK-ASM: encoding: [0xd3,0x06,0xde,0xa3]
108 # CHECK-ASM-AND-OBJ: fclass.d a3, ft10
109 # CHECK-ASM: encoding: [0xd3,0x16,0x0f,0xe2]
112 # CHECK-ASM-AND-OBJ: fcvt.w.d a4, ft11, dyn
113 # CHECK-ASM: encoding: [0x53,0xf7,0x0f,0xc2]
114 fcvt.w.d a4
, ft11
, dyn
115 # CHECK-ASM-AND-OBJ: fcvt.d.w ft0, a5
116 # CHECK-ASM: encoding: [0x53,0x80,0x07,0xd2]
118 # CHECK-ASM-AND-OBJ: fcvt.d.wu ft1, a6
119 # CHECK-ASM: encoding: [0xd3,0x00,0x18,0xd2]
124 # CHECK-ASM-AND-OBJ: fmadd.d fa0, fa1, fa2, fa3, rne
125 # CHECK-ASM: encoding: [0x43,0x85,0xc5,0x6a]
126 fmadd.d
f10, f11, f12, f13, rne
127 # CHECK-ASM-AND-OBJ: fmsub.d fa4, fa5, fa6, fa7, rtz
128 # CHECK-ASM: encoding: [0x47,0x97,0x07,0x8b]
129 fmsub.d
f14, f15, f16, f17, rtz
130 # CHECK-ASM-AND-OBJ: fnmsub.d fs2, fs3, fs4, fs5, rdn
131 # CHECK-ASM: encoding: [0x4b,0xa9,0x49,0xab]
132 fnmsub.d
f18, f19, f20, f21, rdn
133 # CHECK-ASM-AND-OBJ: fnmadd.d fs6, fs7, fs8, fs9, rup
134 # CHECK-ASM: encoding: [0x4f,0xbb,0x8b,0xcb]
135 fnmadd.d
f22, f23, f24, f25, rup
137 # CHECK-ASM-AND-OBJ: fadd.d fs10, fs11, ft8, rmm
138 # CHECK-ASM: encoding: [0x53,0xcd,0xcd,0x03]
139 fadd.d
f26, f27, f28, rmm
140 # CHECK-ASM-AND-OBJ: fsub.d ft9, ft10, ft11
141 # CHECK-ASM: encoding: [0xd3,0x7e,0xff,0x0b]
142 fsub.d
f29, f30, f31, dyn
143 # CHECK-ASM-AND-OBJ: fmul.d ft0, ft1, ft2, rne
144 # CHECK-ASM: encoding: [0x53,0x80,0x20,0x12]
145 fmul.d ft0
, ft1
, ft2
, rne
146 # CHECK-ASM-AND-OBJ: fdiv.d ft3, ft4, ft5, rtz
147 # CHECK-ASM: encoding: [0xd3,0x11,0x52,0x1a]
148 fdiv.d ft3
, ft4
, ft5
, rtz
150 # CHECK-ASM-AND-OBJ: fsqrt.d ft6, ft7, rdn
151 # CHECK-ASM: encoding: [0x53,0xa3,0x03,0x5a]
152 fsqrt.d ft6
, ft7
, rdn
153 # CHECK-ASM-AND-OBJ: fcvt.s.d fs5, fs6, rup
154 # CHECK-ASM: encoding: [0xd3,0x3a,0x1b,0x40]
155 fcvt.s.d fs5
, fs6
, rup
156 # CHECK-ASM-AND-OBJ: fcvt.w.d a4, ft11, rmm
157 # CHECK-ASM: encoding: [0x53,0xc7,0x0f,0xc2]
158 fcvt.w.d a4
, ft11
, rmm
159 # CHECK-ASM-AND-OBJ: fcvt.wu.d a5, ft10, dyn
160 # CHECK-ASM: encoding: [0xd3,0x77,0x1f,0xc2]
161 fcvt.wu.d a5
, ft10
, dyn