1*7c3d14c8STreehugger Robot// RUN: %clang_tsan %s -o %t -framework Foundation 2*7c3d14c8STreehugger Robot// RUN: %env_tsan_opts=ignore_interceptors_accesses=1 %deflake %run %t 2>&1 | FileCheck %s 3*7c3d14c8STreehugger Robot 4*7c3d14c8STreehugger Robot#import <Foundation/Foundation.h> 5*7c3d14c8STreehugger Robot 6*7c3d14c8STreehugger Robot#import "../test.h" 7*7c3d14c8STreehugger Robot 8*7c3d14c8STreehugger Robotlong global; 9*7c3d14c8STreehugger Robot 10*7c3d14c8STreehugger Robotint main() { 11*7c3d14c8STreehugger Robot NSLog(@"Hello world."); 12*7c3d14c8STreehugger Robot print_address("addr=", 1, &global); 13*7c3d14c8STreehugger Robot barrier_init(&barrier, 2); 14*7c3d14c8STreehugger Robot 15*7c3d14c8STreehugger Robot dispatch_queue_t q1 = dispatch_queue_create("my.queue1", DISPATCH_QUEUE_CONCURRENT); 16*7c3d14c8STreehugger Robot dispatch_queue_t q2 = dispatch_queue_create("my.queue2", DISPATCH_QUEUE_CONCURRENT); 17*7c3d14c8STreehugger Robot 18*7c3d14c8STreehugger Robot global = 42; 19*7c3d14c8STreehugger Robot dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ 20*7c3d14c8STreehugger Robot dispatch_sync(q1, ^{ 21*7c3d14c8STreehugger Robot global = 43; 22*7c3d14c8STreehugger Robot barrier_wait(&barrier); 23*7c3d14c8STreehugger Robot }); 24*7c3d14c8STreehugger Robot }); 25*7c3d14c8STreehugger Robot dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ 26*7c3d14c8STreehugger Robot dispatch_sync(q2, ^{ 27*7c3d14c8STreehugger Robot barrier_wait(&barrier); 28*7c3d14c8STreehugger Robot global = 44; 29*7c3d14c8STreehugger Robot 30*7c3d14c8STreehugger Robot dispatch_sync(dispatch_get_main_queue(), ^{ 31*7c3d14c8STreehugger Robot CFRunLoopStop(CFRunLoopGetCurrent()); 32*7c3d14c8STreehugger Robot }); 33*7c3d14c8STreehugger Robot }); 34*7c3d14c8STreehugger Robot }); 35*7c3d14c8STreehugger Robot 36*7c3d14c8STreehugger Robot CFRunLoopRun(); 37*7c3d14c8STreehugger Robot NSLog(@"Done."); 38*7c3d14c8STreehugger Robot} 39*7c3d14c8STreehugger Robot 40*7c3d14c8STreehugger Robot// CHECK: Hello world. 41*7c3d14c8STreehugger Robot// CHECK: addr=[[ADDR:0x[0-9,a-f]+]] 42*7c3d14c8STreehugger Robot// CHECK: WARNING: ThreadSanitizer: data race 43*7c3d14c8STreehugger Robot// CHECK: Location is global 'global' {{(of size 8 )?}}at [[ADDR]] (gcd-sync-race.mm.tmp+0x{{[0-9,a-f]+}}) 44*7c3d14c8STreehugger Robot// CHECK: Done. 45