diff options
author | John McCall <rjmccall@apple.com> | 2010-10-28 21:37:57 +0000 |
---|---|---|
committer | John McCall <rjmccall@apple.com> | 2010-10-28 21:37:57 +0000 |
commit | 46ec70e2e6541a067d33b2513505bec74582b53c (patch) | |
tree | 7dd72398444fc34975e4a2a4fbdd0b2e2acfedf0 | |
parent | b14eed0ed44ed3af881219dab7dc6464cad5303b (diff) |
When emitting l-values for bool non-__block decl references, make a pointer
using the memory type; fixes an assert.
Fixes rdar://problem/8605032
git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@117610 91177308-0d34-0410-b5e6-96231b3b80d8
-rw-r--r-- | lib/CodeGen/CGBlocks.cpp | 2 | ||||
-rw-r--r-- | test/CodeGen/blocks.c | 7 |
2 files changed, 8 insertions, 1 deletions
diff --git a/lib/CodeGen/CGBlocks.cpp b/lib/CodeGen/CGBlocks.cpp index ca78781ec6..44e0833daf 100644 --- a/lib/CodeGen/CGBlocks.cpp +++ b/lib/CodeGen/CGBlocks.cpp @@ -611,7 +611,7 @@ llvm::Value *CodeGenFunction::GetAddrOfBlockDecl(const ValueDecl *VD, if (VD->getType()->isReferenceType()) V = Builder.CreateLoad(V); } else { - const llvm::Type *Ty = CGM.getTypes().ConvertType(VD->getType()); + const llvm::Type *Ty = CGM.getTypes().ConvertTypeForMem(VD->getType()); Ty = llvm::PointerType::get(Ty, 0); V = Builder.CreateBitCast(V, Ty); if (VD->getType()->isReferenceType()) diff --git a/test/CodeGen/blocks.c b/test/CodeGen/blocks.c index 6888356a5a..b7b6a2d505 100644 --- a/test/CodeGen/blocks.c +++ b/test/CodeGen/blocks.c @@ -33,3 +33,10 @@ typedef double ftype(double); ftype ^test2 = ^ftype { return 0; }; + +// rdar://problem/8605032 +void f3_helper(void (^)(void)); +void f3() { + _Bool b = 0; + f3_helper(^{ if (b) {} }); +} |