diff options
author | Anders Carlsson <andersca@mac.com> | 2010-02-03 16:38:03 +0000 |
---|---|---|
committer | Anders Carlsson <andersca@mac.com> | 2010-02-03 16:38:03 +0000 |
commit | 3b227bd6294e00952131ab08d2812caa8f6cfb45 (patch) | |
tree | a9c19179b6ce04a95ebc063fc8353f31e1972c15 /clang | |
parent | 5bb4efdf3c83f3d60298ab6037606f4cb79a5d99 (diff) | |
download | bcm5719-llvm-3b227bd6294e00952131ab08d2812caa8f6cfb45.tar.gz bcm5719-llvm-3b227bd6294e00952131ab08d2812caa8f6cfb45.zip |
Revert the new reference binding code; I came up with a way simpler solution for the reference binding bug that is preventing self-hosting.
llvm-svn: 95223
Diffstat (limited to 'clang')
-rw-r--r-- | clang/lib/CodeGen/CGCall.cpp | 5 | ||||
-rw-r--r-- | clang/lib/CodeGen/CGClass.cpp | 2 | ||||
-rw-r--r-- | clang/lib/CodeGen/CGDecl.cpp | 6 | ||||
-rw-r--r-- | clang/lib/CodeGen/CGDeclCXX.cpp | 4 | ||||
-rw-r--r-- | clang/lib/CodeGen/CGExpr.cpp | 25 | ||||
-rw-r--r-- | clang/lib/CodeGen/CodeGenFunction.h | 5 | ||||
-rw-r--r-- | clang/lib/Sema/SemaInit.cpp | 19 |
7 files changed, 8 insertions, 58 deletions
diff --git a/clang/lib/CodeGen/CGCall.cpp b/clang/lib/CodeGen/CGCall.cpp index e1fe0d29a2d..ce361f08fef 100644 --- a/clang/lib/CodeGen/CGCall.cpp +++ b/clang/lib/CodeGen/CGCall.cpp @@ -802,11 +802,8 @@ void CodeGenFunction::EmitFunctionEpilog(const CGFunctionInfo &FI, } RValue CodeGenFunction::EmitCallArg(const Expr *E, QualType ArgType) { - if (const CXXBindReferenceExpr *BE = dyn_cast<CXXBindReferenceExpr>(E)) - return RValue::get(EmitCXXBindReferenceExpr(BE)); - if (ArgType->isReferenceType()) - return EmitReferenceBindingToExpr(E, ArgType); + return EmitReferenceBindingToExpr(E); return EmitAnyExprToTemp(E); } diff --git a/clang/lib/CodeGen/CGClass.cpp b/clang/lib/CodeGen/CGClass.cpp index 8362945e1ed..70973a45604 100644 --- a/clang/lib/CodeGen/CGClass.cpp +++ b/clang/lib/CodeGen/CGClass.cpp @@ -838,7 +838,7 @@ static void EmitMemberInitializer(CodeGenFunction &CGF, // was implicitly generated, we shouldn't be zeroing memory. RValue RHS; if (FieldType->isReferenceType()) { - RHS = CGF.EmitReferenceBindingToExpr(MemberInit->getInit(), FieldType, + RHS = CGF.EmitReferenceBindingToExpr(MemberInit->getInit(), /*IsInitializer=*/true); CGF.EmitStoreThroughLValue(RHS, LHS, FieldType); } else if (FieldType->isArrayType() && !MemberInit->getInit()) { diff --git a/clang/lib/CodeGen/CGDecl.cpp b/clang/lib/CodeGen/CGDecl.cpp index 6ba537e528c..e27c5e4e51a 100644 --- a/clang/lib/CodeGen/CGDecl.cpp +++ b/clang/lib/CodeGen/CGDecl.cpp @@ -507,12 +507,8 @@ void CodeGenFunction::EmitLocalBlockVarDecl(const VarDecl &D) { Builder.CreateCall4(CGM.getMemCpyFn(), Loc, SrcPtr, SizeVal, AlignVal); } - } else if (const CXXBindReferenceExpr *BE = - dyn_cast<CXXBindReferenceExpr>(Init)) { - llvm::Value *V = EmitCXXBindReferenceExpr(BE); - EmitStoreOfScalar(V, Loc, /*Volatile=*/false, Ty); } else if (Ty->isReferenceType()) { - RValue RV = EmitReferenceBindingToExpr(Init, Ty, /*IsInitializer=*/true); + RValue RV = EmitReferenceBindingToExpr(Init, /*IsInitializer=*/true); EmitStoreOfScalar(RV.getScalarVal(), Loc, false, Ty); } else if (!hasAggregateLLVMType(Init->getType())) { llvm::Value *V = EmitScalarExpr(Init); diff --git a/clang/lib/CodeGen/CGDeclCXX.cpp b/clang/lib/CodeGen/CGDeclCXX.cpp index 3f1a7225fbc..3d5a4e8051b 100644 --- a/clang/lib/CodeGen/CGDeclCXX.cpp +++ b/clang/lib/CodeGen/CGDeclCXX.cpp @@ -81,7 +81,7 @@ void CodeGenFunction::EmitCXXGlobalVarDeclInit(const VarDecl &D, return; } if (Init->isLvalue(getContext()) == Expr::LV_Valid) { - RValue RV = EmitReferenceBindingToExpr(Init, T, /*IsInitializer=*/true); + RValue RV = EmitReferenceBindingToExpr(Init, /*IsInitializer=*/true); EmitStoreOfScalar(RV.getScalarVal(), DeclPtr, false, T); return; } @@ -225,7 +225,7 @@ CodeGenFunction::EmitStaticCXXBlockVarDeclInit(const VarDecl &D, QualType T = D.getType(); // We don't want to pass true for IsInitializer here, because a static // reference to a temporary does not extend its lifetime. - RValue RV = EmitReferenceBindingToExpr(D.getInit(), T, + RValue RV = EmitReferenceBindingToExpr(D.getInit(), /*IsInitializer=*/false); EmitStoreOfScalar(RV.getScalarVal(), GV, /*Volatile=*/false, T); diff --git a/clang/lib/CodeGen/CGExpr.cpp b/clang/lib/CodeGen/CGExpr.cpp index ab4f8f19353..2ceefae0a0f 100644 --- a/clang/lib/CodeGen/CGExpr.cpp +++ b/clang/lib/CodeGen/CGExpr.cpp @@ -92,31 +92,8 @@ RValue CodeGenFunction::EmitAnyExprToTemp(const Expr *E, IsInitializer); } -llvm::Value * -CodeGenFunction::EmitCXXBindReferenceExpr(const CXXBindReferenceExpr *E) { - QualType T = E->getType(); - assert(T->isAnyComplexType() && "FIXME: Unhandled bind expression!"); - - const Expr *SubExpr = E->getSubExpr(); - - if (!E->requiresTemporaryCopy()) - return EmitLValue(SubExpr).getAddress(); - - llvm::Value *Value = CreateTempAlloca(ConvertTypeForMem(T), "reftmp"); - - if (T->isAnyComplexType()) - EmitComplexExprIntoAddr(SubExpr, Value, /*DestIsVolatile=*/false); - else - assert(false && "Unhandled bind expression"); - - return Value; -} - RValue CodeGenFunction::EmitReferenceBindingToExpr(const Expr* E, - QualType DestType, bool IsInitializer) { - assert(!E->getType()->isAnyComplexType() && - "Should not use this function for complex types!"); bool ShouldDestroyTemporaries = false; unsigned OldNumLiveTemporaries = 0; @@ -478,8 +455,6 @@ LValue CodeGenFunction::EmitLValue(const Expr *E) { return EmitCXXConstructLValue(cast<CXXConstructExpr>(E)); case Expr::CXXBindTemporaryExprClass: return EmitCXXBindTemporaryLValue(cast<CXXBindTemporaryExpr>(E)); - case Expr::CXXBindReferenceExprClass: - return EmitLValue(cast<CXXBindReferenceExpr>(E)->getSubExpr()); case Expr::CXXExprWithTemporariesClass: return EmitCXXExprWithTemporariesLValue(cast<CXXExprWithTemporaries>(E)); case Expr::CXXZeroInitValueExprClass: diff --git a/clang/lib/CodeGen/CodeGenFunction.h b/clang/lib/CodeGen/CodeGenFunction.h index 5de91ee3351..3e47469e76c 100644 --- a/clang/lib/CodeGen/CodeGenFunction.h +++ b/clang/lib/CodeGen/CodeGenFunction.h @@ -1111,10 +1111,7 @@ public: /// EmitReferenceBindingToExpr - Emits a reference binding to the passed in /// expression. Will emit a temporary variable if E is not an LValue. - RValue EmitReferenceBindingToExpr(const Expr* E, QualType DestType, - bool IsInitializer = false); - - llvm::Value *EmitCXXBindReferenceExpr(const CXXBindReferenceExpr *E); + RValue EmitReferenceBindingToExpr(const Expr* E, bool IsInitializer = false); //===--------------------------------------------------------------------===// // Expression Emission diff --git a/clang/lib/Sema/SemaInit.cpp b/clang/lib/Sema/SemaInit.cpp index 7c52df5f7c4..1f1e76c9999 100644 --- a/clang/lib/Sema/SemaInit.cpp +++ b/clang/lib/Sema/SemaInit.cpp @@ -3304,31 +3304,16 @@ InitializationSequence::Perform(Sema &S, // Check exception specifications if (S.CheckExceptionSpecCompatibility(CurInitExpr, DestType)) return S.ExprError(); - - // FIXME: We should do this for all types. - if (DestType->isAnyComplexType()) { - CurInit = - S.Owned(CXXBindReferenceExpr::Create(S.Context, - CurInit.takeAs<Expr>(), - /*ExtendsLifetime=*/false, - /*RequiresTemporaryCopy=*/false)); - } break; case SK_BindReferenceToTemporary: + // Reference binding does not have any corresponding ASTs. + // Check exception specifications if (S.CheckExceptionSpecCompatibility(CurInitExpr, DestType)) return S.ExprError(); - // FIXME: We should do this for all types. - if (DestType->isAnyComplexType()) { - CurInit = - S.Owned(CXXBindReferenceExpr::Create(S.Context, - CurInit.takeAs<Expr>(), - /*ExtendsLifetime=*/false, - /*RequiresTemporaryCopy=*/true)); - } break; case SK_UserConversion: { |