From c86fb5ecb4e7327ca0dcd8570d0d93d08cf5d622 Mon Sep 17 00:00:00 2001 From: Fariborz Jahanian Date: Fri, 20 Feb 2009 01:14:43 +0000 Subject: More objc gc's ir-gen fixes. llvm-svn: 65097 --- clang/lib/CodeGen/CGExpr.cpp | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) (limited to 'clang/lib/CodeGen/CGExpr.cpp') diff --git a/clang/lib/CodeGen/CGExpr.cpp b/clang/lib/CodeGen/CGExpr.cpp index aa1585b2dbe..5da0de9cbb6 100644 --- a/clang/lib/CodeGen/CGExpr.cpp +++ b/clang/lib/CodeGen/CGExpr.cpp @@ -626,8 +626,12 @@ LValue CodeGenFunction::EmitDeclRefLValue(const DeclRefExpr *E) { else { llvm::Value *V = LocalDeclMap[VD]; assert(V && "BlockVarDecl not entered in LocalDeclMap?"); - LV = LValue::MakeAddr(V, E->getType().getCVRQualifiers(), - getContext().getObjCGCAttrKind(E->getType())); + // local variables do not get their gc attribute set. + QualType::GCAttrTypes attr = QualType::GCNone; + // local static? + if (VD->getStorageClass() == VarDecl::Static) + attr = getContext().getObjCGCAttrKind(E->getType()); + LV = LValue::MakeAddr(V, E->getType().getCVRQualifiers(), attr); } return LV; } else if (VD && VD->isFileVarDecl()) { @@ -665,7 +669,8 @@ LValue CodeGenFunction::EmitUnaryOpLValue(const UnaryOperator *E) { { QualType T = E->getSubExpr()->getType()->getAsPointerType()->getPointeeType(); return LValue::MakeAddr(EmitScalarExpr(E->getSubExpr()), - ExprTy->getAsPointerType()->getPointeeType().getCVRQualifiers(), + ExprTy->getAsPointerType()->getPointeeType() + .getCVRQualifiers(), getContext().getObjCGCAttrKind(T)); } case UnaryOperator::Real: -- cgit v1.2.3