From: Douglas Gregor Date: Sat, 7 May 2011 20:12:26 +0000 (+0000) Subject: Revert r130717, which caused a regression (). X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=6f0877744517fa1daf3ac9d2e5c63c9acfcfa562;p=clang Revert r130717, which caused a regression (). git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@131057 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGCall.cpp b/lib/CodeGen/CGCall.cpp index 8e3856131a..a765f0f343 100644 --- a/lib/CodeGen/CGCall.cpp +++ b/lib/CodeGen/CGCall.cpp @@ -1166,15 +1166,6 @@ void CodeGenFunction::EmitCallArg(CallArgList &args, const Expr *E, return args.add(EmitReferenceBindingToExpr(E, /*InitializedDecl=*/0), type); - if (hasAggregateLLVMType(type) && isa(E) && - cast(E)->getCastKind() == CK_LValueToRValue) { - LValue L = EmitLValue(cast(E)->getSubExpr()); - assert(L.isSimple()); - args.add(RValue::getAggregate(L.getAddress(), L.isVolatileQualified()), - type, /*NeedsCopy*/true); - return; - } - args.add(EmitAnyExprToTemp(E), type); } @@ -1240,10 +1231,6 @@ RValue CodeGenFunction::EmitCall(const CGFunctionInfo &CallInfo, Alignment, I->Ty); else StoreComplexToAddr(RV.getComplexVal(), Args.back(), false); - } else if (I->NeedsCopy && !ArgInfo.getIndirectByVal()) { - Args.push_back(CreateMemTemp(I->Ty)); - EmitAggregateCopy(Args.back(), RV.getAggregateAddr(), I->Ty, - RV.isVolatileQualified()); } else { Args.push_back(RV.getAggregateAddr()); } diff --git a/lib/CodeGen/CGCall.h b/lib/CodeGen/CGCall.h index 160a62eab3..3f600c04e5 100644 --- a/lib/CodeGen/CGCall.h +++ b/lib/CodeGen/CGCall.h @@ -47,9 +47,8 @@ namespace CodeGen { struct CallArg { RValue RV; QualType Ty; - bool NeedsCopy; - CallArg(RValue rv, QualType ty, bool needscopy) - : RV(rv), Ty(ty), NeedsCopy(needscopy) + CallArg(RValue rv, QualType ty) + : RV(rv), Ty(ty) { } }; @@ -58,8 +57,8 @@ namespace CodeGen { class CallArgList : public llvm::SmallVector { public: - void add(RValue rvalue, QualType type, bool needscopy = false) { - push_back(CallArg(rvalue, type, needscopy)); + void add(RValue rvalue, QualType type) { + push_back(CallArg(rvalue, type)); } }; diff --git a/test/CodeGen/byval-memcpy-elim.c b/test/CodeGen/byval-memcpy-elim.c deleted file mode 100644 index 8aa08fb07b..0000000000 --- a/test/CodeGen/byval-memcpy-elim.c +++ /dev/null @@ -1,20 +0,0 @@ -// RUN: %clang_cc1 -emit-llvm -triple x86_64-apple-darwin10 < %s | FileCheck %s - -struct Test1S { - long NumDecls; - long X; - long Y; -}; -struct Test2S { - long NumDecls; - long X; -}; - -// Make sure we don't generate extra memcpy for lvalues -void test1a(struct Test1S, struct Test2S); -// CHECK: define void @test1( -// CHECK-NOT: memcpy -// CHECK: call void @test1a -void test1(struct Test1S *A, struct Test2S *B) { - test1a(*A, *B); -}