aboutsummaryrefslogtreecommitdiffstats
path: root/test/CodeGen/X86/2009-06-12-x86_64-tail-call-conv-out-of-sync-bug.ll
diff options
context:
space:
mode:
authorArnold Schwaighofer <arnold.schwaighofer@gmail.com>2009-06-12 16:26:57 +0000
committerArnold Schwaighofer <arnold.schwaighofer@gmail.com>2009-06-12 16:26:57 +0000
commitbbd8c33ee67f99f5bad7288dfa465d675714e983 (patch)
treeea479bfe2834e1d70be3dae547eef07be8cb7883 /test/CodeGen/X86/2009-06-12-x86_64-tail-call-conv-out-of-sync-bug.ll
parentb3c36c9c9aba3fce8ae35b52eda4192531a9d3df (diff)
downloadexternal_llvm-bbd8c33ee67f99f5bad7288dfa465d675714e983.zip
external_llvm-bbd8c33ee67f99f5bad7288dfa465d675714e983.tar.gz
external_llvm-bbd8c33ee67f99f5bad7288dfa465d675714e983.tar.bz2
Fix Bug 4278: X86-64 with -tailcallopt calling convention
out of sync with regular cc. The only difference between the tail call cc and the normal cc was that one parameter register - R9 - was reserved for calling functions through a function pointer. After time the tail call cc has gotten out of sync with the regular cc. We can use R11 which is also caller saved but not used as parameter register for potential function pointers and remove the special tail call cc on x86-64. git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@73233 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'test/CodeGen/X86/2009-06-12-x86_64-tail-call-conv-out-of-sync-bug.ll')
-rw-r--r--test/CodeGen/X86/2009-06-12-x86_64-tail-call-conv-out-of-sync-bug.ll15
1 files changed, 15 insertions, 0 deletions
diff --git a/test/CodeGen/X86/2009-06-12-x86_64-tail-call-conv-out-of-sync-bug.ll b/test/CodeGen/X86/2009-06-12-x86_64-tail-call-conv-out-of-sync-bug.ll
new file mode 100644
index 0000000..001b7fc
--- /dev/null
+++ b/test/CodeGen/X86/2009-06-12-x86_64-tail-call-conv-out-of-sync-bug.ll
@@ -0,0 +1,15 @@
+; RUN: llvm-as < %s | llc -tailcallopt -march=x86-64 -mattr=+sse2 -mtriple=x86_64-apple-darwin | grep fstpt
+; RUN: llvm-as < %s | llc -tailcallopt -march=x86-64 -mattr=+sse2 -mtriple=x86_64-apple-darwin | grep xmm
+
+; Check that x86-64 tail calls support x86_fp80 and v2f32 types. (Tail call
+; calling convention out of sync with standard c calling convention on x86_64)
+; Bug 4278.
+
+declare fastcc double @tailcallee(x86_fp80, <2 x float>)
+
+define fastcc double @tailcall() {
+entry:
+ %tmp = fpext float 1.000000e+00 to x86_fp80
+ %tmp2 = tail call fastcc double @tailcallee( x86_fp80 %tmp, <2 x float> <float 1.000000e+00, float 1.000000e+00>)
+ ret double %tmp2
+}