diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2011-05-19 21:13:08 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2011-05-19 21:13:08 +0000 |
commit | 24a69c7be213b693b58ac752efeb4a86fe744927 (patch) | |
tree | be5f144916685fbf6a656608688e81df6f3e4214 | |
parent | 861b9c6a397f2ed4b5601cacbc9121d0b07d1f65 (diff) |
Fix up this test to use explicit triples (Win64 passes a different number of arguments in registers).
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@131676 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | test/CodeGen/X86/vararg_tailcall.ll | 39 |
1 files changed, 26 insertions, 13 deletions
diff --git a/test/CodeGen/X86/vararg_tailcall.ll b/test/CodeGen/X86/vararg_tailcall.ll index 1187afcd7a..d50b83acc8 100644 --- a/test/CodeGen/X86/vararg_tailcall.ll +++ b/test/CodeGen/X86/vararg_tailcall.ll @@ -1,4 +1,5 @@ -; RUN: llc < %s -march=x86-64 | FileCheck %s +; RUN: llc < %s -mtriple=x86_64-apple-darwin10 | FileCheck %s -check-prefix=X64 +; RUN: llc < %s -mtriple=x86_64-pc-win32 | FileCheck %s -check-prefix=WIN64 @.str = private unnamed_addr constant [5 x i8] c"%ld\0A\00" @sel = external global i8* @@ -8,8 +9,10 @@ @sel6 = external global i8* @sel7 = external global i8* -; CHECK: @foo -; CHECK: jmp +; X64: @foo +; X64: jmp +; WIN64: @foo +; WIN64: jmp define void @foo(i64 %arg) nounwind optsize ssp noredzone { entry: %call = tail call i32 (i8*, ...)* @printf(i8* getelementptr inbounds ([5 x i8]* @.str, i64 0, i64 0), i64 %arg) nounwind optsize noredzone @@ -18,8 +21,10 @@ entry: declare i32 @printf(i8*, ...) optsize noredzone -; CHECK: @bar -; CHECK: jmp +; X64: @bar +; X64: jmp +; WIN64: @bar +; WIN64: jmp define void @bar(i64 %arg) nounwind optsize ssp noredzone { entry: tail call void @bar2(i8* getelementptr inbounds ([5 x i8]* @.str, i64 0, i64 0), i64 %arg) nounwind optsize noredzone @@ -28,8 +33,10 @@ entry: declare void @bar2(i8*, i64) optsize noredzone -; CHECK: @foo2 -; CHECK: jmp +; X64: @foo2 +; X64: jmp +; WIN64: @foo2 +; WIN64: jmp define i8* @foo2(i8* %arg) nounwind optsize ssp noredzone { entry: %tmp1 = load i8** @sel, align 8, !tbaa !0 @@ -39,8 +46,10 @@ entry: declare i8* @x2(i8*, i8*, ...) optsize noredzone -; CHECK: @foo6 -; CHECK: jmp +; X64: @foo6 +; X64: jmp +; WIN64: @foo6 +; WIN64: callq define i8* @foo6(i8* %arg1, i8* %arg2) nounwind optsize ssp noredzone { entry: %tmp2 = load i8** @sel3, align 8, !tbaa !0 @@ -53,8 +62,10 @@ entry: declare i8* @x3(i8*, i8*, i8*, ...) optsize noredzone -; CHECK: @foo7 -; CHECK: callq +; X64: @foo7 +; X64: callq +; WIN64: @foo7 +; WIN64: callq define i8* @foo7(i8* %arg1, i8* %arg2) nounwind optsize ssp noredzone { entry: %tmp2 = load i8** @sel3, align 8, !tbaa !0 @@ -68,8 +79,10 @@ entry: declare i8* @x7(i8*, i8*, i8*, i8*, i8*, i8*, i8*, ...) optsize noredzone -; CHECK: @foo8 -; CHECK: callq +; X64: @foo8 +; X64: callq +; WIN64: @foo8 +; WIN64: callq define i8* @foo8(i8* %arg1, i8* %arg2) nounwind optsize ssp noredzone { entry: %tmp2 = load i8** @sel3, align 8, !tbaa !0 |