diff options
| author | Fariborz Jahanian <fjahanian@apple.com> | 2012-11-02 22:51:18 +0000 |
|---|---|---|
| committer | Fariborz Jahanian <fjahanian@apple.com> | 2012-11-02 22:51:18 +0000 |
| commit | 2dd78192676a842bdd86b3b6fab85bc3e5fe3275 (patch) | |
| tree | b5566f601456ac767705c1d7c1d73a28cbc9f8cd /clang/lib/CodeGen/CGObjCMac.cpp | |
| parent | 3b0af848d31e5fbab4d03c0f58ea3d915874fd2f (diff) | |
| download | bcm5719-llvm-2dd78192676a842bdd86b3b6fab85bc3e5fe3275.tar.gz bcm5719-llvm-2dd78192676a842bdd86b3b6fab85bc3e5fe3275.zip | |
objective-C mrr block. Block variable layout metadata in
mrr mode.
llvm-svn: 167331
Diffstat (limited to 'clang/lib/CodeGen/CGObjCMac.cpp')
| -rw-r--r-- | clang/lib/CodeGen/CGObjCMac.cpp | 31 |
1 files changed, 26 insertions, 5 deletions
diff --git a/clang/lib/CodeGen/CGObjCMac.cpp b/clang/lib/CodeGen/CGObjCMac.cpp index 676f22ebc5a..514f550ad49 100644 --- a/clang/lib/CodeGen/CGObjCMac.cpp +++ b/clang/lib/CodeGen/CGObjCMac.cpp @@ -942,6 +942,8 @@ protected: unsigned int BytePos, bool ForStrongLayout, bool &HasUnion); + Qualifiers::ObjCLifetime GetObjCLifeTime(QualType QT); + void UpdateRunSkipBlockVars(bool IsByref, Qualifiers::ObjCLifetime LifeTime, unsigned FieldOffset, @@ -1962,6 +1964,25 @@ llvm::Constant *CGObjCCommonMac::BuildGCBlockLayout(CodeGenModule &CGM, return C; } +Qualifiers::ObjCLifetime CGObjCCommonMac::GetObjCLifeTime(QualType FQT) { + if (CGM.getLangOpts().ObjCAutoRefCount) + return FQT.getObjCLifetime(); + + // MRR, is more ad hoc. + if (FQT.isObjCGCStrong()) + return Qualifiers::OCL_Strong; + if (FQT.isObjCGCWeak()) + return Qualifiers::OCL_Weak; + + if (FQT->isObjCObjectPointerType() || FQT->isBlockPointerType()) + return Qualifiers::OCL_Strong; + + if (const PointerType *PT = FQT->getAs<PointerType>()) + return (GetObjCLifeTime(PT->getPointeeType())); + + return Qualifiers::OCL_None; +} + void CGObjCCommonMac::UpdateRunSkipBlockVars(bool IsByref, Qualifiers::ObjCLifetime LifeTime, unsigned FieldOffset, @@ -2074,7 +2095,7 @@ void CGObjCCommonMac::BuildRCRecordLayout(const llvm::StructLayout *RecLayout, } } else { UpdateRunSkipBlockVars(false, - Field->getType().getObjCLifetime(), + GetObjCLifeTime(FQT), BytePos + FieldOffset, FieldSize); } @@ -2089,7 +2110,7 @@ void CGObjCCommonMac::BuildRCRecordLayout(const llvm::StructLayout *RecLayout, ((BitFieldSize % ByteSizeInBits) != 0); Size += LastBitfieldOrUnnamedOffset; UpdateRunSkipBlockVars(false, - LastFieldBitfieldOrUnnamed->getType().getObjCLifetime(), + GetObjCLifeTime(LastFieldBitfieldOrUnnamed->getType()), BytePos + LastBitfieldOrUnnamedOffset, Size*ByteSizeInBits); } else { @@ -2098,7 +2119,7 @@ void CGObjCCommonMac::BuildRCRecordLayout(const llvm::StructLayout *RecLayout, unsigned FieldSize = CGM.getContext().getTypeSize(LastFieldBitfieldOrUnnamed->getType()); UpdateRunSkipBlockVars(false, - LastFieldBitfieldOrUnnamed->getType().getObjCLifetime(), + GetObjCLifeTime(LastFieldBitfieldOrUnnamed->getType()), BytePos + LastBitfieldOrUnnamedOffset, FieldSize); } @@ -2106,7 +2127,7 @@ void CGObjCCommonMac::BuildRCRecordLayout(const llvm::StructLayout *RecLayout, if (MaxField) UpdateRunSkipBlockVars(false, - MaxField->getType().getObjCLifetime(), + GetObjCLifeTime(MaxField->getType()), BytePos + MaxFieldOffset, MaxUnionSize); } @@ -2274,7 +2295,7 @@ llvm::Constant *CGObjCCommonMac::BuildRCBlockLayout(CodeGenModule &CGM, } unsigned fieldSize = ci->isByRef() ? WordSizeInBits : CGM.getContext().getTypeSize(type); - UpdateRunSkipBlockVars(ci->isByRef(), type.getObjCLifetime(), + UpdateRunSkipBlockVars(ci->isByRef(), GetObjCLifeTime(type), fieldOffset, fieldSize); } |

