Skip to content

Commit 0fc2907

Browse files
davemgreenaokblast
authored andcommitted
[ARM] Update and cleanup lround/llround tests. NFC
Similar to f4370fb, the fp16 tests do not work yet.
1 parent 5d215a4 commit 0fc2907

File tree

2 files changed

+94
-26
lines changed

2 files changed

+94
-26
lines changed
Lines changed: 60 additions & 14 deletions
Original file line numberDiff line numberDiff line change
@@ -1,25 +1,71 @@
1-
; RUN: llc < %s -mtriple=arm-eabi -float-abi=soft | FileCheck %s --check-prefix=SOFTFP
2-
; RUN: llc < %s -mtriple=arm-eabi -float-abi=hard | FileCheck %s --check-prefix=HARDFP
1+
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
2+
; RUN: llc < %s -mtriple=armv7-none-eabi -float-abi=soft | FileCheck %s --check-prefixes=CHECK,CHECK-SOFT
3+
; RUN: llc < %s -mtriple=armv7-none-eabihf -mattr=+vfp2 -float-abi=hard | FileCheck %s --check-prefixes=CHECK,CHECK-NOFP16
4+
; RUN: llc < %s -mtriple=armv8-none-eabihf -mattr=+fp-armv8,+fullfp16 -float-abi=hard | FileCheck %s --check-prefixes=CHECK,CHECK-FP16
5+
6+
define i64 @testmsxh_builtin(half %x) {
7+
; CHECK-SOFT-LABEL: testmsxh_builtin:
8+
; CHECK-SOFT: @ %bb.0: @ %entry
9+
; CHECK-SOFT-NEXT: .save {r11, lr}
10+
; CHECK-SOFT-NEXT: push {r11, lr}
11+
; CHECK-SOFT-NEXT: bl __aeabi_h2f
12+
; CHECK-SOFT-NEXT: bl llroundf
13+
; CHECK-SOFT-NEXT: pop {r11, pc}
14+
;
15+
; CHECK-NOFP16-LABEL: testmsxh_builtin:
16+
; CHECK-NOFP16: @ %bb.0: @ %entry
17+
; CHECK-NOFP16-NEXT: .save {r11, lr}
18+
; CHECK-NOFP16-NEXT: push {r11, lr}
19+
; CHECK-NOFP16-NEXT: vmov r0, s0
20+
; CHECK-NOFP16-NEXT: bl __aeabi_h2f
21+
; CHECK-NOFP16-NEXT: vmov s0, r0
22+
; CHECK-NOFP16-NEXT: bl llroundf
23+
; CHECK-NOFP16-NEXT: pop {r11, pc}
24+
;
25+
; CHECK-FP16-LABEL: testmsxh_builtin:
26+
; CHECK-FP16: @ %bb.0: @ %entry
27+
; CHECK-FP16-NEXT: .save {r11, lr}
28+
; CHECK-FP16-NEXT: push {r11, lr}
29+
; CHECK-FP16-NEXT: vcvtb.f32.f16 s0, s0
30+
; CHECK-FP16-NEXT: bl llroundf
31+
; CHECK-FP16-NEXT: pop {r11, pc}
32+
entry:
33+
%0 = tail call i64 @llvm.llround.i64.f16(half %x)
34+
ret i64 %0
35+
}
336

4-
; SOFTFP-LABEL: testmsxs_builtin:
5-
; SOFTFP: bl llroundf
6-
; HARDFP-LABEL: testmsxs_builtin:
7-
; HARDFP: bl llroundf
837
define i64 @testmsxs_builtin(float %x) {
38+
; CHECK-LABEL: testmsxs_builtin:
39+
; CHECK: @ %bb.0: @ %entry
40+
; CHECK-NEXT: .save {r11, lr}
41+
; CHECK-NEXT: push {r11, lr}
42+
; CHECK-NEXT: bl llroundf
43+
; CHECK-NEXT: pop {r11, pc}
944
entry:
10-
%0 = tail call i64 @llvm.llround.f32(float %x)
45+
%0 = tail call i64 @llvm.llround.i64.f32(float %x)
1146
ret i64 %0
1247
}
1348

14-
; SOFTFP-LABEL: testmsxd_builtin:
15-
; SOFTFP: bl llround
16-
; HARDFP-LABEL: testmsxd_builtin:
17-
; HARDFP: bl llround
1849
define i64 @testmsxd_builtin(double %x) {
50+
; CHECK-LABEL: testmsxd_builtin:
51+
; CHECK: @ %bb.0: @ %entry
52+
; CHECK-NEXT: .save {r11, lr}
53+
; CHECK-NEXT: push {r11, lr}
54+
; CHECK-NEXT: bl llround
55+
; CHECK-NEXT: pop {r11, pc}
1956
entry:
20-
%0 = tail call i64 @llvm.llround.f64(double %x)
57+
%0 = tail call i64 @llvm.llround.i64.f64(double %x)
2158
ret i64 %0
2259
}
2360

24-
declare i64 @llvm.llround.f32(float) nounwind readnone
25-
declare i64 @llvm.llround.f64(double) nounwind readnone
61+
define i64 @testmsxq_builtin(fp128 %x) {
62+
; CHECK-LABEL: testmsxq_builtin:
63+
; CHECK: @ %bb.0: @ %entry
64+
; CHECK-NEXT: .save {r11, lr}
65+
; CHECK-NEXT: push {r11, lr}
66+
; CHECK-NEXT: bl llroundl
67+
; CHECK-NEXT: pop {r11, pc}
68+
entry:
69+
%0 = tail call i64 @llvm.llround.i64.f128(fp128 %x)
70+
ret i64 %0
71+
}
Lines changed: 34 additions & 12 deletions
Original file line numberDiff line numberDiff line change
@@ -1,25 +1,47 @@
1-
; RUN: llc < %s -mtriple=arm-eabi -float-abi=soft | FileCheck %s --check-prefix=SOFTFP
2-
; RUN: llc < %s -mtriple=arm-eabi -float-abi=hard | FileCheck %s --check-prefix=HARDFP
1+
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 5
2+
; RUN: llc < %s -mtriple=armv7-none-eabi -float-abi=soft | FileCheck %s --check-prefixes=CHECK,CHECK-SOFT
3+
; RUN: llc < %s -mtriple=armv7-none-eabihf -mattr=+vfp2 -float-abi=hard | FileCheck %s --check-prefixes=CHECK,CHECK-NOFP16
4+
; RUN: llc < %s -mtriple=armv8-none-eabihf -mattr=+fp-armv8 -float-abi=hard | FileCheck %s --check-prefixes=CHECK,CHECK-FPv8
5+
; RUN: llc < %s -mtriple=armv8-none-eabihf -mattr=+fp-armv8,+fullfp16 -float-abi=hard | FileCheck %s --check-prefixes=CHECK,CHECK-FP16
6+
7+
;define i32 @testmswh_builtin(half %x) {
8+
;entry:
9+
; %0 = tail call i32 @llvm.lround.i32.f16(half %x)
10+
; ret i32 %0
11+
;}
312

4-
; SOFTFP-LABEL: testmsws_builtin:
5-
; SOFTFP: bl lroundf
6-
; HARDFP-LABEL: testmsws_builtin:
7-
; HARDFP: bl lroundf
813
define i32 @testmsws_builtin(float %x) {
14+
; CHECK-LABEL: testmsws_builtin:
15+
; CHECK: @ %bb.0: @ %entry
16+
; CHECK-NEXT: b lroundf
917
entry:
1018
%0 = tail call i32 @llvm.lround.i32.f32(float %x)
1119
ret i32 %0
1220
}
1321

14-
; SOFTFP-LABEL: testmswd_builtin:
15-
; SOFTFP: bl lround
16-
; HARDFP-LABEL: testmswd_builtin:
17-
; HARDFP: bl lround
1822
define i32 @testmswd_builtin(double %x) {
23+
; CHECK-LABEL: testmswd_builtin:
24+
; CHECK: @ %bb.0: @ %entry
25+
; CHECK-NEXT: b lround
1926
entry:
2027
%0 = tail call i32 @llvm.lround.i32.f64(double %x)
2128
ret i32 %0
2229
}
2330

24-
declare i32 @llvm.lround.i32.f32(float) nounwind readnone
25-
declare i32 @llvm.lround.i32.f64(double) nounwind readnone
31+
define i32 @testmswq_builtin(fp128 %x) {
32+
; CHECK-LABEL: testmswq_builtin:
33+
; CHECK: @ %bb.0: @ %entry
34+
; CHECK-NEXT: .save {r11, lr}
35+
; CHECK-NEXT: push {r11, lr}
36+
; CHECK-NEXT: bl lroundl
37+
; CHECK-NEXT: pop {r11, pc}
38+
entry:
39+
%0 = tail call i32 @llvm.lround.i32.f128(fp128 %x)
40+
ret i32 %0
41+
}
42+
43+
;; NOTE: These prefixes are unused and the list is autogenerated. Do not add tests below this line:
44+
; CHECK-FP16: {{.*}}
45+
; CHECK-FPv8: {{.*}}
46+
; CHECK-NOFP16: {{.*}}
47+
; CHECK-SOFT: {{.*}}

0 commit comments

Comments
 (0)