Author: vedantk Date: Mon Dec 21 13:43:25 2015 New Revision: 256186 URL: http://llvm.org/viewvc/llvm-project?rev=256186&view=rev Log: Revert "[CodeGen] Fix assignments of inline layouts into the byref structure"
This reverts commit r256185. It breaks CodeGenObjC/fragile-arc.m. Modified: cfe/trunk/lib/CodeGen/CGObjCMac.cpp cfe/trunk/lib/CodeGen/CGObjCRuntime.h cfe/trunk/test/CodeGenObjCXX/blocks.mm Modified: cfe/trunk/lib/CodeGen/CGObjCMac.cpp URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGObjCMac.cpp?rev=256186&r1=256185&r2=256186&view=diff ============================================================================== --- cfe/trunk/lib/CodeGen/CGObjCMac.cpp (original) +++ cfe/trunk/lib/CodeGen/CGObjCMac.cpp Mon Dec 21 13:43:25 2015 @@ -2517,8 +2517,7 @@ llvm::Constant *CGObjCCommonMac::getBitm printf(", BL_WEAK:%d", (int) numWeak); printf(", BL_OPERATOR:0\n"); } - return llvm::ConstantExpr::getIntToPtr( - llvm::ConstantInt::get(CGM.IntPtrTy, Result), CGM.Int8PtrTy); + return llvm::ConstantInt::get(CGM.IntPtrTy, Result); } unsigned char inst = (BLOCK_LAYOUT_OPERATOR << 4) | 0; Modified: cfe/trunk/lib/CodeGen/CGObjCRuntime.h URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGObjCRuntime.h?rev=256186&r1=256185&r2=256186&view=diff ============================================================================== --- cfe/trunk/lib/CodeGen/CGObjCRuntime.h (original) +++ cfe/trunk/lib/CodeGen/CGObjCRuntime.h Mon Dec 21 13:43:25 2015 @@ -275,11 +275,8 @@ public: const CodeGen::CGBlockInfo &blockInfo) = 0; virtual llvm::Constant *BuildRCBlockLayout(CodeGen::CodeGenModule &CGM, const CodeGen::CGBlockInfo &blockInfo) = 0; - - /// Returns an i8* which points to the byref layout information. virtual llvm::Constant *BuildByrefLayout(CodeGen::CodeGenModule &CGM, QualType T) = 0; - virtual llvm::GlobalVariable *GetClassGlobal(const std::string &Name, bool Weak = false) = 0; Modified: cfe/trunk/test/CodeGenObjCXX/blocks.mm URL: http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGenObjCXX/blocks.mm?rev=256186&r1=256185&r2=256186&view=diff ============================================================================== --- cfe/trunk/test/CodeGenObjCXX/blocks.mm (original) +++ cfe/trunk/test/CodeGenObjCXX/blocks.mm Mon Dec 21 13:43:25 2015 @@ -68,18 +68,3 @@ class CaptureThisAndAnotherPointer { takeBlock(^{ useValues(ptr, this); }); } }; - -// rdar://problem/23713871 -// Check that we don't crash when using BLOCK_LAYOUT_STRONG. -#pragma clang assume_nonnull begin -@interface NSUUID @end -#pragma clang assume_nonnull end - -struct Wrapper1 { NSUUID *Ref; }; -struct Wrapper2 { Wrapper1 W1; }; - -@implementation B -- (void) captureStrongRef { - __block Wrapper2 W2; -} -@end _______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org http://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits