annotate compiler-rt/test/tsan/Darwin/debug_external.cpp @ 150:1d019706d866

LLVM10
author anatofuz
date Thu, 13 Feb 2020 15:10:13 +0900
parents
children c4bab56944e8
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: %clangxx_tsan -O1 %s -o %t
anatofuz
parents:
diff changeset
2 // RUN: %deflake %run %t 2>&1 | FileCheck %s
anatofuz
parents:
diff changeset
3
anatofuz
parents:
diff changeset
4 #include <pthread.h>
anatofuz
parents:
diff changeset
5 #include <stdio.h>
anatofuz
parents:
diff changeset
6 #include <stdlib.h>
anatofuz
parents:
diff changeset
7 #include <string.h>
anatofuz
parents:
diff changeset
8
anatofuz
parents:
diff changeset
9 #include "../test.h"
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 extern "C" {
anatofuz
parents:
diff changeset
12 void __tsan_on_report(void *report);
anatofuz
parents:
diff changeset
13 int __tsan_get_report_loc(void *report, unsigned long idx, const char **type,
anatofuz
parents:
diff changeset
14 void **addr, void **start,
anatofuz
parents:
diff changeset
15 unsigned long *size, int *tid, int *fd,
anatofuz
parents:
diff changeset
16 int *suppressable, void **trace,
anatofuz
parents:
diff changeset
17 unsigned long trace_size);
anatofuz
parents:
diff changeset
18 int __tsan_get_report_loc_object_type(void *report, unsigned long idx,
anatofuz
parents:
diff changeset
19 const char **object_type);
anatofuz
parents:
diff changeset
20 }
anatofuz
parents:
diff changeset
21
anatofuz
parents:
diff changeset
22 void *Thread(void *arg) {
anatofuz
parents:
diff changeset
23 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
24 *((long *)arg) = 42;
anatofuz
parents:
diff changeset
25 return NULL;
anatofuz
parents:
diff changeset
26 }
anatofuz
parents:
diff changeset
27
anatofuz
parents:
diff changeset
28 int main() {
anatofuz
parents:
diff changeset
29 barrier_init(&barrier, 2);
anatofuz
parents:
diff changeset
30 void *tag = __tsan_external_register_tag("MyObject");
anatofuz
parents:
diff changeset
31 long *obj = (long *)malloc(sizeof(long));
anatofuz
parents:
diff changeset
32 fprintf(stderr, "obj = %p\n", obj);
anatofuz
parents:
diff changeset
33 // CHECK: obj = [[ADDR:0x[0-9a-f]+]]
anatofuz
parents:
diff changeset
34 __tsan_external_assign_tag(obj, tag);
anatofuz
parents:
diff changeset
35
anatofuz
parents:
diff changeset
36 pthread_t t;
anatofuz
parents:
diff changeset
37 pthread_create(&t, 0, Thread, obj);
anatofuz
parents:
diff changeset
38 *obj = 41;
anatofuz
parents:
diff changeset
39 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
40 pthread_join(t, 0);
anatofuz
parents:
diff changeset
41 fprintf(stderr, "Done.\n");
anatofuz
parents:
diff changeset
42 return 0;
anatofuz
parents:
diff changeset
43 }
anatofuz
parents:
diff changeset
44
anatofuz
parents:
diff changeset
45 void __tsan_on_report(void *report) {
anatofuz
parents:
diff changeset
46 const char *type;
anatofuz
parents:
diff changeset
47 void *addr;
anatofuz
parents:
diff changeset
48 void *start;
anatofuz
parents:
diff changeset
49 unsigned long size;
anatofuz
parents:
diff changeset
50 int tid, fd, suppressable;
anatofuz
parents:
diff changeset
51 void *trace[16] = {0};
anatofuz
parents:
diff changeset
52 __tsan_get_report_loc(report, 0, &type, &addr, &start, &size, &tid, &fd,
anatofuz
parents:
diff changeset
53 &suppressable, trace, 16);
anatofuz
parents:
diff changeset
54 fprintf(stderr, "type = %s, start = %p, size = %ld\n", type, start, size);
anatofuz
parents:
diff changeset
55 // CHECK: type = heap, start = [[ADDR]], size = 8
anatofuz
parents:
diff changeset
56
anatofuz
parents:
diff changeset
57 const char *object_type;
anatofuz
parents:
diff changeset
58 __tsan_get_report_loc_object_type(report, 0, &object_type);
anatofuz
parents:
diff changeset
59 fprintf(stderr, "object_type = %s\n", object_type);
anatofuz
parents:
diff changeset
60 // CHECK: object_type = MyObject
anatofuz
parents:
diff changeset
61 }
anatofuz
parents:
diff changeset
62
anatofuz
parents:
diff changeset
63 // CHECK: Done.
anatofuz
parents:
diff changeset
64 // CHECK: ThreadSanitizer: reported 1 warnings