diff options
author | Eli Friedman <eli.friedman@gmail.com> | 2011-04-28 18:06:10 +0000 |
---|---|---|
committer | Eli Friedman <eli.friedman@gmail.com> | 2011-04-28 18:06:10 +0000 |
commit | 6cf31b0a1a786385d8fb13d45abf0f9c3030dc6f (patch) | |
tree | f52f3f27c620d7d54c18d88692107e61c3f3f49a | |
parent | 4cdcb4772d95b9e801a0f3cd43776cef3af3b530 (diff) | |
download | llvm-6cf31b0a1a786385d8fb13d45abf0f9c3030dc6f.tar.gz llvm-6cf31b0a1a786385d8fb13d45abf0f9c3030dc6f.tar.bz2 llvm-6cf31b0a1a786385d8fb13d45abf0f9c3030dc6f.tar.xz |
Revert r130348; causing buildbot issues on x86-32.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@130412 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/Target/X86/X86FastISel.cpp | 1 | ||||
-rw-r--r-- | test/CodeGen/X86/fast-isel-x86-64.ll | 13 |
2 files changed, 14 insertions, 0 deletions
diff --git a/lib/Target/X86/X86FastISel.cpp b/lib/Target/X86/X86FastISel.cpp index 9d25f4ecdc..82ed9bad43 100644 --- a/lib/Target/X86/X86FastISel.cpp +++ b/lib/Target/X86/X86FastISel.cpp @@ -1618,6 +1618,7 @@ bool X86FastISel::X86SelectCall(const Instruction *I) { // FIXME: Only handle *easy* calls for now. if (CS.paramHasAttr(AttrInd, Attribute::InReg) || + CS.paramHasAttr(AttrInd, Attribute::StructRet) || CS.paramHasAttr(AttrInd, Attribute::Nest) || CS.paramHasAttr(AttrInd, Attribute::ByVal)) return false; diff --git a/test/CodeGen/X86/fast-isel-x86-64.ll b/test/CodeGen/X86/fast-isel-x86-64.ll index f7bfe722b3..1bc25d9565 100644 --- a/test/CodeGen/X86/fast-isel-x86-64.ll +++ b/test/CodeGen/X86/fast-isel-x86-64.ll @@ -260,3 +260,16 @@ define void @test21(double* %p1) { ; CHECK-NOT: pxor ; CHECK: movsd LCPI } + +; Check that we fast-isel sret +%struct.a = type { i64, i64, i64 } +define void @test20() nounwind ssp { +entry: + %tmp = alloca %struct.a, align 8 + call void @test20sret(%struct.a* sret %tmp) + ret void +; CHECK: test20: +; CHECK: leaq (%rsp), %rdi +; CHECK: callq _test20sret +} +declare void @test20sret(%struct.a* sret) |