From: Fariborz Jahanian Date: Fri, 20 Feb 2009 01:14:43 +0000 (+0000) Subject: More objc gc's ir-gen fixes. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=4f54526a31458c19aad19e5d3fb4ba2a5275ecb6;p=clang More objc gc's ir-gen fixes. git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@65097 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/lib/CodeGen/CGExpr.cpp b/lib/CodeGen/CGExpr.cpp index aa1585b2db..5da0de9cbb 100644 --- a/lib/CodeGen/CGExpr.cpp +++ b/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: