summaryrefslogtreecommitdiffstats
path: root/clang/test
diff options
context:
space:
mode:
authorVedant Kumar <vsk@apple.com>2015-12-21 20:21:15 +0000
committerVedant Kumar <vsk@apple.com>2015-12-21 20:21:15 +0000
commit2f5bb1150d4b877954b0bde3915dcbe3b8fdb687 (patch)
tree2128155d9c032e058547530b789361f96d2304e9 /clang/test
parent0234640882a53a4674d1f5bfaaa32ac3f101b516 (diff)
downloadbcm5719-llvm-2f5bb1150d4b877954b0bde3915dcbe3b8fdb687.tar.gz
bcm5719-llvm-2f5bb1150d4b877954b0bde3915dcbe3b8fdb687.zip
Reapply "[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. The original version of this patch was too invasive. This version only adds the cast to BuildByrefLayout. Differential Revision: http://reviews.llvm.org/D15674 rdar://23713871 llvm-svn: 256190
Diffstat (limited to 'clang/test')
-rw-r--r--clang/test/CodeGenObjCXX/blocks.mm15
1 files changed, 15 insertions, 0 deletions
diff --git a/clang/test/CodeGenObjCXX/blocks.mm b/clang/test/CodeGenObjCXX/blocks.mm
index fd93437ff65..63a1b33f355 100644
--- a/clang/test/CodeGenObjCXX/blocks.mm
+++ b/clang/test/CodeGenObjCXX/blocks.mm
@@ -68,3 +68,18 @@ 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
OpenPOWER on IntegriCloud