fast-isel sret. We actually don't need to do anything special on x86. :) rdar:/...
authorEli Friedman <eli.friedman@gmail.com>
Wed, 27 Apr 2011 23:58:52 +0000 (23:58 +0000)
committerEli Friedman <eli.friedman@gmail.com>
Wed, 27 Apr 2011 23:58:52 +0000 (23:58 +0000)
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@130348 91177308-0d34-0410-b5e6-96231b3b80d8

lib/Target/X86/X86FastISel.cpp
test/CodeGen/X86/fast-isel-x86-64.ll

index 82ed9bad43b79c02e1c966682f51533f2d21152b..9d25f4ecdcecf2822a6341a5cc8ad4dba08f753c 100644 (file)
@@ -1618,7 +1618,6 @@ 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;
index e5f1a7c1660f5c291bdc73f6034afc08fd0a215e..40f90cf4023fdc7fadd89dad6baa749ecedf6119 100644 (file)
@@ -238,3 +238,16 @@ define void @test19(double* %p1) {
 ; CHECK: test19:
 ; CHECK: pxor
 }
+
+; 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)