2015-11-24 21:36:06 +08:00
|
|
|
// RUN: %clang_tsan %s -o %t -framework Foundation
|
2017-01-25 05:37:50 +08:00
|
|
|
// RUN: %deflake %run %t 2>&1 | FileCheck %s
|
2015-11-24 21:36:06 +08:00
|
|
|
|
|
|
|
#import <Foundation/Foundation.h>
|
|
|
|
|
|
|
|
#import "../test.h"
|
|
|
|
|
|
|
|
long global;
|
|
|
|
|
|
|
|
int main() {
|
|
|
|
NSLog(@"Hello world.");
|
2016-04-07 19:31:02 +08:00
|
|
|
print_address("addr=", 1, &global);
|
2015-11-24 21:36:06 +08:00
|
|
|
barrier_init(&barrier, 2);
|
|
|
|
|
|
|
|
global = 42;
|
|
|
|
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
|
|
|
|
global = 43;
|
|
|
|
barrier_wait(&barrier);
|
|
|
|
});
|
|
|
|
|
|
|
|
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{
|
|
|
|
barrier_wait(&barrier);
|
|
|
|
global = 44;
|
|
|
|
|
|
|
|
dispatch_sync(dispatch_get_main_queue(), ^{
|
|
|
|
CFRunLoopStop(CFRunLoopGetCurrent());
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
CFRunLoopRun();
|
|
|
|
NSLog(@"Done.");
|
|
|
|
}
|
|
|
|
|
|
|
|
// CHECK: Hello world.
|
|
|
|
// CHECK: addr=[[ADDR:0x[0-9,a-f]+]]
|
|
|
|
// CHECK: WARNING: ThreadSanitizer: data race
|
2016-04-07 19:31:02 +08:00
|
|
|
// CHECK: Location is global 'global' {{(of size 8 )?}}at [[ADDR]] (gcd-async-race.mm.tmp+0x{{[0-9,a-f]+}})
|
2015-11-24 21:36:06 +08:00
|
|
|
// CHECK: Done.
|