aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJohn McCall <rjmccall@apple.com>2010-10-28 21:37:57 +0000
committerJohn McCall <rjmccall@apple.com>2010-10-28 21:37:57 +0000
commit46ec70e2e6541a067d33b2513505bec74582b53c (patch)
tree7dd72398444fc34975e4a2a4fbdd0b2e2acfedf0
parentb14eed0ed44ed3af881219dab7dc6464cad5303b (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.cpp2
-rw-r--r--test/CodeGen/blocks.c7
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) {} });
+}