summaryrefslogtreecommitdiffstats
path: root/llvm/test/CodeGen/ARM/Windows/integer-floating-point-conversion.ll
diff options
context:
space:
mode:
authorSaleem Abdulrasool <compnerd@compnerd.org>2014-05-16 05:41:33 +0000
committerSaleem Abdulrasool <compnerd@compnerd.org>2014-05-16 05:41:33 +0000
commit056fc3da4a971ebb7068d0cbc0ce056bf4e4e488 (patch)
tree49edd9a196898246cfa0e71eff8b68194a780aa4 /llvm/test/CodeGen/ARM/Windows/integer-floating-point-conversion.ll
parent540c3cd817f75cac10ef42ae173736c24600ac6b (diff)
downloadbcm5719-llvm-056fc3da4a971ebb7068d0cbc0ce056bf4e4e488.tar.gz
bcm5719-llvm-056fc3da4a971ebb7068d0cbc0ce056bf4e4e488.zip
ARM: add some integer/floating point conversion libcalls
Add some Windows on ARM specific library calls. These are provided by msvcrt, and can be used to perform integer to floating-point conversions (and vice-versa) mirroring similar functions in the RTABI. llvm-svn: 208949
Diffstat (limited to 'llvm/test/CodeGen/ARM/Windows/integer-floating-point-conversion.ll')
-rw-r--r--llvm/test/CodeGen/ARM/Windows/integer-floating-point-conversion.ll74
1 files changed, 74 insertions, 0 deletions
diff --git a/llvm/test/CodeGen/ARM/Windows/integer-floating-point-conversion.ll b/llvm/test/CodeGen/ARM/Windows/integer-floating-point-conversion.ll
new file mode 100644
index 00000000000..acf21a1caad
--- /dev/null
+++ b/llvm/test/CodeGen/ARM/Windows/integer-floating-point-conversion.ll
@@ -0,0 +1,74 @@
+; RUN: llc -mtriple thumbv7-windows -filetype asm -o - %s | FileCheck %s
+
+define arm_aapcs_vfpcc i64 @stoi64(float %f) {
+entry:
+ %conv = fptosi float %f to i64
+ ret i64 %conv
+}
+
+; CHECK-LABEL: stoi64
+; CHECK: bl __stoi64
+
+define arm_aapcs_vfpcc i64 @stou64(float %f) {
+entry:
+ %conv = fptoui float %f to i64
+ ret i64 %conv
+}
+
+; CHECK-LABEL: stou64
+; CHECK: bl __stou64
+
+define arm_aapcs_vfpcc float @i64tos(i64 %i64) {
+entry:
+ %conv = sitofp i64 %i64 to float
+ ret float %conv
+}
+
+; CHECK-LABEL: i64tos
+; CHECK: bl __i64tos
+
+define arm_aapcs_vfpcc float @u64tos(i64 %u64) {
+entry:
+ %conv = uitofp i64 %u64 to float
+ ret float %conv
+}
+
+; CHECK-LABEL: u64tos
+; CHECK: bl __u64tos
+
+define arm_aapcs_vfpcc i64 @dtoi64(double %d) {
+entry:
+ %conv = fptosi double %d to i64
+ ret i64 %conv
+}
+
+; CHECK-LABEL: dtoi64
+; CHECK: bl __dtoi64
+
+define arm_aapcs_vfpcc i64 @dtou64(double %d) {
+entry:
+ %conv = fptoui double %d to i64
+ ret i64 %conv
+}
+
+; CHECK-LABEL: dtou64
+; CHECK: bl __dtou64
+
+define arm_aapcs_vfpcc double @i64tod(i64 %i64) {
+entry:
+ %conv = sitofp i64 %i64 to double
+ ret double %conv
+}
+
+; CHECK-LABEL: i64tod
+; CHECK: bl __i64tod
+
+define arm_aapcs_vfpcc double @u64tod(i64 %i64) {
+entry:
+ %conv = uitofp i64 %i64 to double
+ ret double %conv
+}
+
+; CHECK-LABEL: u64tod
+; CHECK: bl __u64tod
+
OpenPOWER on IntegriCloud