forked from OSchip/llvm-project
[CodeGen] Fix assignments of inline layouts into the byref structure
When using blocks, a byref structure is created to represent the closure. The "byref.layout" field of this structure is an i8*. However, some 'inline' layouts are represented as i64's, not i8*'s. Prior to r246985 we cast the i64 'inline' layout to an i8* before assigning it into the byref structure. This patch brings the cast back and adds a regression test. rdar://23713871 llvm-svn: 256185
This commit is contained in:
parent
b2910ea67e
commit
eb37ec87e4
|
|
@ -2517,7 +2517,8 @@ llvm::Constant *CGObjCCommonMac::getBitmapBlockLayout(bool ComputeByrefLayout) {
|
||||||
printf(", BL_WEAK:%d", (int) numWeak);
|
printf(", BL_WEAK:%d", (int) numWeak);
|
||||||
printf(", BL_OPERATOR:0\n");
|
printf(", BL_OPERATOR:0\n");
|
||||||
}
|
}
|
||||||
return llvm::ConstantInt::get(CGM.IntPtrTy, Result);
|
return llvm::ConstantExpr::getIntToPtr(
|
||||||
|
llvm::ConstantInt::get(CGM.IntPtrTy, Result), CGM.Int8PtrTy);
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned char inst = (BLOCK_LAYOUT_OPERATOR << 4) | 0;
|
unsigned char inst = (BLOCK_LAYOUT_OPERATOR << 4) | 0;
|
||||||
|
|
|
||||||
|
|
@ -275,8 +275,11 @@ public:
|
||||||
const CodeGen::CGBlockInfo &blockInfo) = 0;
|
const CodeGen::CGBlockInfo &blockInfo) = 0;
|
||||||
virtual llvm::Constant *BuildRCBlockLayout(CodeGen::CodeGenModule &CGM,
|
virtual llvm::Constant *BuildRCBlockLayout(CodeGen::CodeGenModule &CGM,
|
||||||
const CodeGen::CGBlockInfo &blockInfo) = 0;
|
const CodeGen::CGBlockInfo &blockInfo) = 0;
|
||||||
|
|
||||||
|
/// Returns an i8* which points to the byref layout information.
|
||||||
virtual llvm::Constant *BuildByrefLayout(CodeGen::CodeGenModule &CGM,
|
virtual llvm::Constant *BuildByrefLayout(CodeGen::CodeGenModule &CGM,
|
||||||
QualType T) = 0;
|
QualType T) = 0;
|
||||||
|
|
||||||
virtual llvm::GlobalVariable *GetClassGlobal(const std::string &Name,
|
virtual llvm::GlobalVariable *GetClassGlobal(const std::string &Name,
|
||||||
bool Weak = false) = 0;
|
bool Weak = false) = 0;
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -68,3 +68,18 @@ class CaptureThisAndAnotherPointer {
|
||||||
takeBlock(^{ useValues(ptr, this); });
|
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
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue