annotate compiler-rt/test/tsan/ignore_lib5.cpp @ 266:00f31e85ec16 default tip

Added tag current for changeset 31d058e83c98
author Shinji KONO <kono@ie.u-ryukyu.ac.jp>
date Sat, 14 Oct 2023 10:13:55 +0900
parents 1f2b6ac9f198
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
150
anatofuz
parents:
diff changeset
1 // RUN: rm -rf %t-dir
anatofuz
parents:
diff changeset
2 // RUN: mkdir %t-dir
anatofuz
parents:
diff changeset
3
223
5f17cb93ff66 LLVM13 (2021/7/18)
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 150
diff changeset
4 // RUN: %clangxx_tsan -O1 -fno-builtin %s -DLIB -fPIC -fno-sanitize=thread -shared -o %t-dir/libignore_lib1.so
150
anatofuz
parents:
diff changeset
5 // RUN: %clangxx_tsan -O1 %s %link_libcxx_tsan -o %t-dir/executable
anatofuz
parents:
diff changeset
6 // RUN: echo running w/o suppressions:
anatofuz
parents:
diff changeset
7 // RUN: %deflake %run %t-dir/executable | FileCheck %s --check-prefix=CHECK-NOSUPP
anatofuz
parents:
diff changeset
8 // RUN: echo running with suppressions:
anatofuz
parents:
diff changeset
9 // RUN: %env_tsan_opts=suppressions='%s.supp' %run %t-dir/executable 2>&1 | FileCheck %s --check-prefix=CHECK-WITHSUPP
anatofuz
parents:
diff changeset
10
anatofuz
parents:
diff changeset
11 // REQUIRES: stable-runtime
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 223
diff changeset
12 // UNSUPPORTED: target=powerpc64le{{.*}}
150
anatofuz
parents:
diff changeset
13 // FIXME: This test occasionally fails on powerpc64 LE possibly starting with
anatofuz
parents:
diff changeset
14 // r279664. Re-enable the test once the problem(s) have been fixed.
anatofuz
parents:
diff changeset
15
anatofuz
parents:
diff changeset
16 // Previously the test episodically failed with:
anatofuz
parents:
diff changeset
17 // ThreadSanitizer: called_from_lib suppression '/libignore_lib1.so$' is
anatofuz
parents:
diff changeset
18 // matched against 2 libraries: '/libignore_lib1.so' and '/libignore_lib1.so'
anatofuz
parents:
diff changeset
19 // This was caused by non-atomicity of reading of /proc/self/maps.
anatofuz
parents:
diff changeset
20
anatofuz
parents:
diff changeset
21 // ReadProcMaps() on NetBSD does not handle >=1MB of memory layout information
252
1f2b6ac9f198 LLVM16-1
Shinji KONO <kono@ie.u-ryukyu.ac.jp>
parents: 223
diff changeset
22 // UNSUPPORTED: target={{.*netbsd.*}}
150
anatofuz
parents:
diff changeset
23
anatofuz
parents:
diff changeset
24 #ifndef LIB
anatofuz
parents:
diff changeset
25
anatofuz
parents:
diff changeset
26 #include <dlfcn.h>
anatofuz
parents:
diff changeset
27 #include <sys/mman.h>
anatofuz
parents:
diff changeset
28 #include <stdlib.h>
anatofuz
parents:
diff changeset
29 #include <stdio.h>
anatofuz
parents:
diff changeset
30 #include <errno.h>
anatofuz
parents:
diff changeset
31 #include <libgen.h>
anatofuz
parents:
diff changeset
32 #include <string>
anatofuz
parents:
diff changeset
33 #include "test.h"
anatofuz
parents:
diff changeset
34
anatofuz
parents:
diff changeset
35 #ifndef MAP_32BIT
anatofuz
parents:
diff changeset
36 # define MAP_32BIT 0
anatofuz
parents:
diff changeset
37 #endif
anatofuz
parents:
diff changeset
38
anatofuz
parents:
diff changeset
39 #ifdef __APPLE__
anatofuz
parents:
diff changeset
40 # define TSAN_MAP_ANON MAP_ANON
anatofuz
parents:
diff changeset
41 #else
anatofuz
parents:
diff changeset
42 # define TSAN_MAP_ANON MAP_ANONYMOUS
anatofuz
parents:
diff changeset
43 #endif
anatofuz
parents:
diff changeset
44
anatofuz
parents:
diff changeset
45 void *thr(void *arg) {
anatofuz
parents:
diff changeset
46 // This thread creates lots of separate mappings in /proc/self/maps before
anatofuz
parents:
diff changeset
47 // the ignored library.
anatofuz
parents:
diff changeset
48 for (int i = 0; i < 10000; i++) {
anatofuz
parents:
diff changeset
49 if (i == 5000)
anatofuz
parents:
diff changeset
50 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
51 mmap(0, 4096, PROT_READ, TSAN_MAP_ANON | MAP_PRIVATE | MAP_32BIT, -1 , 0);
anatofuz
parents:
diff changeset
52 mmap(0, 4096, PROT_WRITE, TSAN_MAP_ANON | MAP_PRIVATE | MAP_32BIT, -1 , 0);
anatofuz
parents:
diff changeset
53 }
anatofuz
parents:
diff changeset
54 return 0;
anatofuz
parents:
diff changeset
55 }
anatofuz
parents:
diff changeset
56
anatofuz
parents:
diff changeset
57 int main(int argc, char **argv) {
anatofuz
parents:
diff changeset
58 barrier_init(&barrier, 2);
anatofuz
parents:
diff changeset
59 pthread_t th;
anatofuz
parents:
diff changeset
60 pthread_create(&th, 0, thr, 0);
anatofuz
parents:
diff changeset
61 barrier_wait(&barrier);
anatofuz
parents:
diff changeset
62 std::string lib = std::string(dirname(argv[0])) + "/libignore_lib1.so";
anatofuz
parents:
diff changeset
63 void *h = dlopen(lib.c_str(), RTLD_GLOBAL | RTLD_NOW);
anatofuz
parents:
diff changeset
64 if (h == 0)
anatofuz
parents:
diff changeset
65 exit(printf("failed to load the library (%d)\n", errno));
anatofuz
parents:
diff changeset
66 void (*f)() = (void(*)())dlsym(h, "libfunc");
anatofuz
parents:
diff changeset
67 if (f == 0)
anatofuz
parents:
diff changeset
68 exit(printf("failed to find the func (%d)\n", errno));
anatofuz
parents:
diff changeset
69 pthread_join(th, 0);
anatofuz
parents:
diff changeset
70 f();
anatofuz
parents:
diff changeset
71 }
anatofuz
parents:
diff changeset
72
anatofuz
parents:
diff changeset
73 #else // #ifdef LIB
anatofuz
parents:
diff changeset
74
anatofuz
parents:
diff changeset
75 #include "ignore_lib_lib.h"
anatofuz
parents:
diff changeset
76
anatofuz
parents:
diff changeset
77 #endif // #ifdef LIB
anatofuz
parents:
diff changeset
78
anatofuz
parents:
diff changeset
79 // CHECK-NOSUPP: WARNING: ThreadSanitizer: data race
anatofuz
parents:
diff changeset
80 // CHECK-NOSUPP: OK
anatofuz
parents:
diff changeset
81
anatofuz
parents:
diff changeset
82 // CHECK-WITHSUPP-NOT: WARNING: ThreadSanitizer: data race
anatofuz
parents:
diff changeset
83 // CHECK-WITHSUPP: OK