1
1
// 32-bit x86 returns float types differently to avoid the x87 stack.
2
2
// 32-bit systems will return 128bit values using a return area pointer.
3
- //@ revisions: x86 bit32 bit64
3
+ // Emscripten aligns f128 to 8 bytes, not 16.
4
+ //@ revisions: x86 bit32 bit64 emscripten
4
5
//@[x86] only-x86
5
6
//@[bit32] ignore-x86
7
+ //@[bit32] ignore-emscripten
6
8
//@[bit32] only-32bit
7
9
//@[bit64] ignore-x86
10
+ //@[bit64] ignore-emscripten
8
11
//@[bit64] only-64bit
12
+ //@[emscripten] only-emscripten
9
13
10
14
// Verify that our intrinsics generate the correct LLVM calls for f128
11
15
@@ -59,6 +63,7 @@ pub fn f128_le(a: f128, b: f128) -> bool {
59
63
// x86-LABEL: void @f128_neg({{.*}}sret([16 x i8])
60
64
// bit32-LABEL: void @f128_neg({{.*}}sret([16 x i8])
61
65
// bit64-LABEL: fp128 @f128_neg(
66
+ // emscripten-LABEL: void @f128_neg({{.*}}sret([16 x i8])
62
67
#[ no_mangle]
63
68
pub fn f128_neg ( a : f128 ) -> f128 {
64
69
// CHECK: fneg fp128
@@ -68,6 +73,7 @@ pub fn f128_neg(a: f128) -> f128 {
68
73
// x86-LABEL: void @f128_add({{.*}}sret([16 x i8])
69
74
// bit32-LABEL: void @f128_add({{.*}}sret([16 x i8])
70
75
// bit64-LABEL: fp128 @f128_add(
76
+ // emscripten-LABEL: void @f128_add({{.*}}sret([16 x i8])
71
77
#[ no_mangle]
72
78
pub fn f128_add ( a : f128 , b : f128 ) -> f128 {
73
79
// CHECK: fadd fp128 %{{.+}}, %{{.+}}
@@ -77,6 +83,7 @@ pub fn f128_add(a: f128, b: f128) -> f128 {
77
83
// x86-LABEL: void @f128_sub({{.*}}sret([16 x i8])
78
84
// bit32-LABEL: void @f128_sub({{.*}}sret([16 x i8])
79
85
// bit64-LABEL: fp128 @f128_sub(
86
+ // emscripten-LABEL: void @f128_sub({{.*}}sret([16 x i8])
80
87
#[ no_mangle]
81
88
pub fn f128_sub ( a : f128 , b : f128 ) -> f128 {
82
89
// CHECK: fsub fp128 %{{.+}}, %{{.+}}
@@ -86,6 +93,7 @@ pub fn f128_sub(a: f128, b: f128) -> f128 {
86
93
// x86-LABEL: void @f128_mul({{.*}}sret([16 x i8])
87
94
// bit32-LABEL: void @f128_mul({{.*}}sret([16 x i8])
88
95
// bit64-LABEL: fp128 @f128_mul(
96
+ // emscripten-LABEL: void @f128_mul({{.*}}sret([16 x i8])
89
97
#[ no_mangle]
90
98
pub fn f128_mul ( a : f128 , b : f128 ) -> f128 {
91
99
// CHECK: fmul fp128 %{{.+}}, %{{.+}}
@@ -95,6 +103,7 @@ pub fn f128_mul(a: f128, b: f128) -> f128 {
95
103
// x86-LABEL: void @f128_div({{.*}}sret([16 x i8])
96
104
// bit32-LABEL: void @f128_div({{.*}}sret([16 x i8])
97
105
// bit64-LABEL: fp128 @f128_div(
106
+ // emscripten-LABEL: void @f128_div({{.*}}sret([16 x i8])
98
107
#[ no_mangle]
99
108
pub fn f128_div ( a : f128 , b : f128 ) -> f128 {
100
109
// CHECK: fdiv fp128 %{{.+}}, %{{.+}}
@@ -104,6 +113,7 @@ pub fn f128_div(a: f128, b: f128) -> f128 {
104
113
// x86-LABEL: void @f128_rem({{.*}}sret([16 x i8])
105
114
// bit32-LABEL: void @f128_rem({{.*}}sret([16 x i8])
106
115
// bit64-LABEL: fp128 @f128_rem(
116
+ // emscripten-LABEL: void @f128_rem({{.*}}sret([16 x i8])
107
117
#[ no_mangle]
108
118
pub fn f128_rem ( a : f128 , b : f128 ) -> f128 {
109
119
// CHECK: frem fp128 %{{.+}}, %{{.+}}
@@ -164,6 +174,7 @@ pub fn f128_as_f16(a: f128) -> f16 {
164
174
// x86-LABEL: i32 @f128_as_f32(
165
175
// bit32-LABEL: float @f128_as_f32(
166
176
// bit64-LABEL: float @f128_as_f32(
177
+ // emscripten-LABEL: float @f128_as_f32(
167
178
#[ no_mangle]
168
179
pub fn f128_as_f32 ( a : f128 ) -> f32 {
169
180
// CHECK: fptrunc fp128 %{{.+}} to float
@@ -173,6 +184,7 @@ pub fn f128_as_f32(a: f128) -> f32 {
173
184
// x86-LABEL: void @f128_as_f64(
174
185
// bit32-LABEL: double @f128_as_f64(
175
186
// bit64-LABEL: double @f128_as_f64(
187
+ // emscripten-LABEL: double @f128_as_f64(
176
188
#[ no_mangle]
177
189
pub fn f128_as_f64 ( a : f128 ) -> f64 {
178
190
// CHECK: fptrunc fp128 %{{.+}} to double
@@ -182,17 +194,20 @@ pub fn f128_as_f64(a: f128) -> f64 {
182
194
// x86-LABEL: void @f128_as_self({{.*}}sret([16 x i8])
183
195
// bit32-LABEL: void @f128_as_self({{.*}}sret([16 x i8])
184
196
// bit64-LABEL: fp128 @f128_as_self(
197
+ // emscripten-LABEL: void @f128_as_self({{.*}}sret([16 x i8])
185
198
#[ no_mangle]
186
199
pub fn f128_as_self ( a : f128 ) -> f128 {
187
200
// x86: store fp128 %a, ptr %_0, align 16
188
201
// bit32: store fp128 %a, ptr %_0, align 16
189
202
// bit64: ret fp128 %{{.+}}
203
+ // emscripten: store fp128 %a, ptr %_0, align 8
190
204
a as f128
191
205
}
192
206
193
207
// x86-LABEL: void @f16_as_f128({{.*}}sret([16 x i8])
194
208
// bit32-LABEL: void @f16_as_f128({{.*}}sret([16 x i8])
195
209
// bit64-LABEL: fp128 @f16_as_f128(
210
+ // emscripten-LABEL: void @f16_as_f128({{.*}}sret([16 x i8])
196
211
#[ no_mangle]
197
212
pub fn f16_as_f128 ( a : f16 ) -> f128 {
198
213
// CHECK: fpext half %{{.+}} to fp128
@@ -202,6 +217,7 @@ pub fn f16_as_f128(a: f16) -> f128 {
202
217
// x86-LABEL: void @f32_as_f128({{.*}}sret([16 x i8])
203
218
// bit32-LABEL: void @f32_as_f128({{.*}}sret([16 x i8])
204
219
// bit64-LABEL: fp128 @f32_as_f128(
220
+ // emscripten-LABEL: void @f32_as_f128({{.*}}sret([16 x i8])
205
221
#[ no_mangle]
206
222
pub fn f32_as_f128 ( a : f32 ) -> f128 {
207
223
// CHECK: fpext float %{{.+}} to fp128
@@ -211,6 +227,7 @@ pub fn f32_as_f128(a: f32) -> f128 {
211
227
// x86-LABEL: void @f64_as_f128({{.*}}sret([16 x i8])
212
228
// bit32-LABEL: void @f64_as_f128({{.*}}sret([16 x i8])
213
229
// bit64-LABEL: fp128 @f64_as_f128(
230
+ // emscripten-LABEL: void @f64_as_f128({{.*}}sret([16 x i8])
214
231
#[ no_mangle]
215
232
pub fn f64_as_f128 ( a : f64 ) -> f128 {
216
233
// CHECK: fpext double %{{.+}} to fp128
@@ -249,6 +266,7 @@ pub fn f128_as_u64(a: f128) -> u64 {
249
266
// x86-LABEL: void @f128_as_u128({{.*}}sret([16 x i8])
250
267
// bit32-LABEL: void @f128_as_u128({{.*}}sret([16 x i8])
251
268
// bit64-LABEL: i128 @f128_as_u128(
269
+ // emscripten-LABEL: void @f128_as_u128({{.*}}sret([16 x i8])
252
270
#[ no_mangle]
253
271
pub fn f128_as_u128 ( a : f128 ) -> u128 {
254
272
// CHECK: call i128 @llvm.fptoui.sat.i128.f128(fp128 %{{.+}})
@@ -285,6 +303,7 @@ pub fn f128_as_i64(a: f128) -> i64 {
285
303
// x86-LABEL: void @f128_as_i128({{.*}}sret([16 x i8])
286
304
// bit32-LABEL: void @f128_as_i128({{.*}}sret([16 x i8])
287
305
// bit64-LABEL: i128 @f128_as_i128(
306
+ // emscripten-LABEL: void @f128_as_i128({{.*}}sret([16 x i8])
288
307
#[ no_mangle]
289
308
pub fn f128_as_i128 ( a : f128 ) -> i128 {
290
309
// CHECK: call i128 @llvm.fptosi.sat.i128.f128(fp128 %{{.+}})
@@ -296,6 +315,7 @@ pub fn f128_as_i128(a: f128) -> i128 {
296
315
// x86-LABEL: void @u8_as_f128({{.*}}sret([16 x i8])
297
316
// bit32-LABEL: void @u8_as_f128({{.*}}sret([16 x i8])
298
317
// bit64-LABEL: fp128 @u8_as_f128(
318
+ // emscripten-LABEL: void @u8_as_f128({{.*}}sret([16 x i8])
299
319
#[ no_mangle]
300
320
pub fn u8_as_f128 ( a : u8 ) -> f128 {
301
321
// CHECK: uitofp i8 %{{.+}} to fp128
@@ -305,6 +325,7 @@ pub fn u8_as_f128(a: u8) -> f128 {
305
325
// x86-LABEL: void @u16_as_f128({{.*}}sret([16 x i8])
306
326
// bit32-LABEL: void @u16_as_f128({{.*}}sret([16 x i8])
307
327
// bit64-LABEL: fp128 @u16_as_f128(
328
+ // emscripten-LABEL: void @u16_as_f128({{.*}}sret([16 x i8])
308
329
#[ no_mangle]
309
330
pub fn u16_as_f128 ( a : u16 ) -> f128 {
310
331
// CHECK: uitofp i16 %{{.+}} to fp128
@@ -314,6 +335,7 @@ pub fn u16_as_f128(a: u16) -> f128 {
314
335
// x86-LABEL: void @u32_as_f128({{.*}}sret([16 x i8])
315
336
// bit32-LABEL: void @u32_as_f128({{.*}}sret([16 x i8])
316
337
// bit64-LABEL: fp128 @u32_as_f128(
338
+ // emscripten-LABEL: void @u32_as_f128({{.*}}sret([16 x i8])
317
339
#[ no_mangle]
318
340
pub fn u32_as_f128 ( a : u32 ) -> f128 {
319
341
// CHECK: uitofp i32 %{{.+}} to fp128
@@ -323,6 +345,7 @@ pub fn u32_as_f128(a: u32) -> f128 {
323
345
// x86-LABEL: void @u64_as_f128({{.*}}sret([16 x i8])
324
346
// bit32-LABEL: void @u64_as_f128({{.*}}sret([16 x i8])
325
347
// bit64-LABEL: fp128 @u64_as_f128(
348
+ // emscripten-LABEL: void @u64_as_f128({{.*}}sret([16 x i8])
326
349
#[ no_mangle]
327
350
pub fn u64_as_f128 ( a : u64 ) -> f128 {
328
351
// CHECK: uitofp i64 %{{.+}} to fp128
@@ -332,6 +355,7 @@ pub fn u64_as_f128(a: u64) -> f128 {
332
355
// x86-LABEL: void @u128_as_f128({{.*}}sret([16 x i8])
333
356
// bit32-LABEL: void @u128_as_f128({{.*}}sret([16 x i8])
334
357
// bit64-LABEL: fp128 @u128_as_f128(
358
+ // emscripten-LABEL: void @u128_as_f128({{.*}}sret([16 x i8])
335
359
#[ no_mangle]
336
360
pub fn u128_as_f128 ( a : u128 ) -> f128 {
337
361
// CHECK: uitofp i128 %{{.+}} to fp128
@@ -341,6 +365,7 @@ pub fn u128_as_f128(a: u128) -> f128 {
341
365
// x86-LABEL: void @i8_as_f128({{.*}}sret([16 x i8])
342
366
// bit32-LABEL: void @i8_as_f128({{.*}}sret([16 x i8])
343
367
// bit64-LABEL: fp128 @i8_as_f128(
368
+ // emscripten-LABEL: void @i8_as_f128({{.*}}sret([16 x i8])
344
369
#[ no_mangle]
345
370
pub fn i8_as_f128 ( a : i8 ) -> f128 {
346
371
// CHECK: sitofp i8 %{{.+}} to fp128
@@ -350,6 +375,7 @@ pub fn i8_as_f128(a: i8) -> f128 {
350
375
// x86-LABEL: void @i16_as_f128({{.*}}sret([16 x i8])
351
376
// bit32-LABEL: void @i16_as_f128({{.*}}sret([16 x i8])
352
377
// bit64-LABEL: fp128 @i16_as_f128(
378
+ // emscripten-LABEL: void @i16_as_f128({{.*}}sret([16 x i8])
353
379
#[ no_mangle]
354
380
pub fn i16_as_f128 ( a : i16 ) -> f128 {
355
381
// CHECK: sitofp i16 %{{.+}} to fp128
@@ -359,6 +385,7 @@ pub fn i16_as_f128(a: i16) -> f128 {
359
385
// x86-LABEL: void @i32_as_f128({{.*}}sret([16 x i8])
360
386
// bit32-LABEL: void @i32_as_f128({{.*}}sret([16 x i8])
361
387
// bit64-LABEL: fp128 @i32_as_f128(
388
+ // emscripten-LABEL: void @i32_as_f128({{.*}}sret([16 x i8])
362
389
#[ no_mangle]
363
390
pub fn i32_as_f128 ( a : i32 ) -> f128 {
364
391
// CHECK: sitofp i32 %{{.+}} to fp128
@@ -368,6 +395,7 @@ pub fn i32_as_f128(a: i32) -> f128 {
368
395
// x86-LABEL: void @i64_as_f128({{.*}}sret([16 x i8])
369
396
// bit32-LABEL: void @i64_as_f128({{.*}}sret([16 x i8])
370
397
// bit64-LABEL: fp128 @i64_as_f128(
398
+ // emscripten-LABEL: void @i64_as_f128({{.*}}sret([16 x i8])
371
399
#[ no_mangle]
372
400
pub fn i64_as_f128 ( a : i64 ) -> f128 {
373
401
// CHECK: sitofp i64 %{{.+}} to fp128
@@ -377,6 +405,7 @@ pub fn i64_as_f128(a: i64) -> f128 {
377
405
// x86-LABEL: void @i128_as_f128({{.*}}sret([16 x i8])
378
406
// bit32-LABEL: void @i128_as_f128({{.*}}sret([16 x i8])
379
407
// bit64-LABEL: fp128 @i128_as_f128(
408
+ // emscripten-LABEL: void @i128_as_f128({{.*}}sret([16 x i8])
380
409
#[ no_mangle]
381
410
pub fn i128_as_f128 ( a : i128 ) -> f128 {
382
411
// CHECK: sitofp i128 %{{.+}} to fp128
0 commit comments