[compiler-rt] r254226 - [tsan] Add a testcase for a race on a Obj-C instance variable

Kuba Brecka via llvm-commits llvm-commits at lists.llvm.org
Sat Nov 28 02:32:06 PST 2015


Author: kuba.brecka
Date: Sat Nov 28 04:32:05 2015
New Revision: 254226

URL: http://llvm.org/viewvc/llvm-project?rev=254226&view=rev
Log:
[tsan] Add a testcase for a race on a Obj-C instance variable

Let's add a testcase for a race on a Obj-C instance variable.

Differential Revision: http://reviews.llvm.org/D14988


Added:
    compiler-rt/trunk/test/tsan/Darwin/objc-race.mm

Added: compiler-rt/trunk/test/tsan/Darwin/objc-race.mm
URL: http://llvm.org/viewvc/llvm-project/compiler-rt/trunk/test/tsan/Darwin/objc-race.mm?rev=254226&view=auto
==============================================================================
--- compiler-rt/trunk/test/tsan/Darwin/objc-race.mm (added)
+++ compiler-rt/trunk/test/tsan/Darwin/objc-race.mm Sat Nov 28 04:32:05 2015
@@ -0,0 +1,55 @@
+// RUN: %clang_tsan %s -o %t -framework Foundation
+// RUN: %deflake %run %t 2>&1
+
+#import <Foundation/Foundation.h>
+
+#import "../test.h"
+
+ at interface MyClass : NSObject {
+  long instance_variable;
+}
+- (void)method:(long)value;
+ at end
+
+ at implementation MyClass
+
+- (void)method:(long)value {
+  self->instance_variable = value;
+}
+
+ at end
+
+int main() {
+  NSLog(@"Hello world.");
+  barrier_init(&barrier, 2);
+  
+  MyClass *my_object = [MyClass new];
+  [my_object method:42];
+  
+  dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
+    [my_object method:43];
+    barrier_wait(&barrier);
+  });
+  
+  dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
+    barrier_wait(&barrier);
+    [my_object method:44];
+
+    dispatch_sync(dispatch_get_main_queue(), ^{
+      CFRunLoopStop(CFRunLoopGetCurrent());
+    });
+  });
+  
+  CFRunLoopRun();
+  NSLog(@"Done.");
+  return 0;
+}
+
+// CHECK: Hello world.
+// CHECK: WARNING: ThreadSanitizer: data race
+// CHECK:   Write of size 8
+// CHECK:     #0 -[MyClass method:]
+// CHECK:   Write of size 8
+// CHECK:     #0 -[MyClass method:]
+// CHECK:   Location is heap block
+// CHECK: Done.




More information about the llvm-commits mailing list