[AMDGPU][True16][CodeGen] true16 codegen pattern for v_med3_u/i16 (#121850)
[llvm-project.git] / compiler-rt / test / tsan / inlined_memcpy_race2.cpp
blobcd4bb582eb916c1aa96ebaaaebc2ff7ef90d0695
1 // RUN: %clangxx_tsan -O1 %s -o %t && %deflake %run %t 2>&1 | FileCheck %s
2 #include "test.h"
3 #include <string.h>
5 int y[4], z[4];
7 void *MemMoveThread(void *a) {
8 memmove((int*)a, z, 16);
9 barrier_wait(&barrier);
10 return NULL;
13 void *MemSetThread(void *a) {
14 barrier_wait(&barrier);
15 memset((int*)a, 0, 16);
16 return NULL;
19 int main() {
20 barrier_init(&barrier, 2);
21 pthread_t t[2];
22 // Race on y between memmove and memset
23 pthread_create(&t[0], NULL, MemMoveThread, y);
24 pthread_create(&t[1], NULL, MemSetThread, y);
25 pthread_join(t[0], NULL);
26 pthread_join(t[1], NULL);
28 fprintf(stderr, "PASS\n");
29 return 0;
32 // CHECK: WARNING: ThreadSanitizer: data race
33 // CHECK: #0 {{.*}}memset
34 // CHECK: #{{[12]}} MemSetThread
35 // CHECK: Previous write
36 // CHECK: #0 {{.*mem(cpy|move)}}
37 // CHECK: #{{[12]}} MemMoveThread