blob: c7411160604cd5eb2a12fce59e2b26edece96fa6 [file] [log] [blame]
Alexey Bataevdb390212015-05-20 04:24:19 +00001// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp -fexceptions -fcxx-exceptions -x c++ -emit-llvm %s -o - | FileCheck %s
Charles Lifad02412017-01-09 18:24:16 +00002// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp -fexceptions -fcxx-exceptions -x c++ -emit-llvm -std=c++98 %s -o - | FileCheck %s
3// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp -fexceptions -fcxx-exceptions -x c++ -emit-llvm -std=c++11 %s -o - | FileCheck %s
Douglas Katzman3459ce22015-10-08 04:24:12 +00004// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp -fexceptions -fcxx-exceptions -debug-info-kind=line-tables-only -x c++ -emit-llvm %s -o - | FileCheck %s --check-prefix=TERM_DEBUG
Alexey Bataeva8a9153a2017-12-29 18:07:07 +00005
6// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp-simd -fexceptions -fcxx-exceptions -x c++ -emit-llvm %s -o - | FileCheck --check-prefix SIMD-ONLY0 %s
7// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp-simd -fexceptions -fcxx-exceptions -x c++ -emit-llvm -std=c++98 %s -o - | FileCheck --check-prefix SIMD-ONLY0 %s
8// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp-simd -fexceptions -fcxx-exceptions -x c++ -emit-llvm -std=c++11 %s -o - | FileCheck --check-prefix SIMD-ONLY0 %s
9// RUN: %clang_cc1 -verify -triple x86_64-apple-darwin10 -fopenmp-simd -fexceptions -fcxx-exceptions -debug-info-kind=line-tables-only -x c++ -emit-llvm %s -o - | FileCheck --check-prefix SIMD-ONLY0 %s
10// SIMD-ONLY0-NOT: {{__kmpc|__tgt}}
Alexey Bataev36bf0112015-03-10 05:15:26 +000011// expected-no-diagnostics
12
13int a;
Alexey Bataev10fec572015-03-11 04:48:56 +000014int b;
15
16struct St {
Alexey Bataev5a195472015-09-04 12:55:50 +000017 unsigned long field;
Alexey Bataev10fec572015-03-11 04:48:56 +000018 St() {}
19 ~St() {}
20 int &get() { return a; }
21};
22
23// CHECK-LABEL: parallel_atomic_ewc
24void parallel_atomic_ewc() {
Alexey Bataev5a195472015-09-04 12:55:50 +000025 St s;
Alexey Bataev10fec572015-03-11 04:48:56 +000026#pragma omp parallel
27 {
Sean Fertiled900dd02018-10-15 15:43:00 +000028 // CHECK: invoke void @_ZN2StC1Ev(%struct.St* [[TEMP_ST_ADDR:%.+]])
Alexey Bataev10fec572015-03-11 04:48:56 +000029 // CHECK: [[SCALAR_ADDR:%.+]] = invoke dereferenceable(4) i32* @_ZN2St3getEv(%struct.St* [[TEMP_ST_ADDR]])
30 // CHECK: [[SCALAR_VAL:%.+]] = load atomic i32, i32* [[SCALAR_ADDR]] monotonic
31 // CHECK: store i32 [[SCALAR_VAL]], i32* @b
Charles Lifad02412017-01-09 18:24:16 +000032 // CHECK98: invoke void @_ZN2StD1Ev(%struct.St* [[TEMP_ST_ADDR]])
33 // CHECK11: call void @_ZN2StD1Ev(%struct.St* [[TEMP_ST_ADDR]])
Alexey Bataev10fec572015-03-11 04:48:56 +000034#pragma omp atomic read
35 b = St().get();
Sean Fertiled900dd02018-10-15 15:43:00 +000036 // CHECK-DAG: invoke void @_ZN2StC1Ev(%struct.St* [[TEMP_ST_ADDR:%.+]])
Alexey Bataev112a7bf2015-04-23 07:56:25 +000037 // CHECK-DAG: [[SCALAR_ADDR:%.+]] = invoke dereferenceable(4) i32* @_ZN2St3getEv(%struct.St* [[TEMP_ST_ADDR]])
38 // CHECK-DAG: [[B_VAL:%.+]] = load i32, i32* @b
Alexey Bataev10fec572015-03-11 04:48:56 +000039 // CHECK: store atomic i32 [[B_VAL]], i32* [[SCALAR_ADDR]] monotonic
Charles Lifad02412017-01-09 18:24:16 +000040 // CHECK: {{invoke|call}} void @_ZN2StD1Ev(%struct.St* [[TEMP_ST_ADDR]])
Alexey Bataev10fec572015-03-11 04:48:56 +000041#pragma omp atomic write
42 St().get() = b;
Sean Fertiled900dd02018-10-15 15:43:00 +000043 // CHECK: invoke void @_ZN2StC1Ev(%struct.St* [[TEMP_ST_ADDR:%.+]])
Alexey Bataevb4505a72015-03-30 05:20:59 +000044 // CHECK: [[SCALAR_ADDR:%.+]] = invoke dereferenceable(4) i32* @_ZN2St3getEv(%struct.St* [[TEMP_ST_ADDR]])
45 // CHECK: [[B_VAL:%.+]] = load i32, i32* @b
46 // CHECK: [[OLD_VAL:%.+]] = load atomic i32, i32* [[SCALAR_ADDR]] monotonic,
47 // CHECK: br label %[[OMP_UPDATE:.+]]
48 // CHECK: [[OMP_UPDATE]]
49 // CHECK: [[OLD_PHI_VAL:%.+]] = phi i32 [ [[OLD_VAL]], %{{.+}} ], [ [[NEW_OLD_VAL:%.+]], %[[OMP_UPDATE]] ]
50 // CHECK: [[NEW_VAL:%.+]] = srem i32 [[OLD_PHI_VAL]], [[B_VAL]]
Alexey Bataevf0ab5532015-05-15 08:36:34 +000051 // CHECK: store i32 [[NEW_VAL]], i32* [[TEMP:%.+]],
52 // CHECK: [[NEW_VAL:%.+]] = load i32, i32* [[TEMP]],
Alexey Bataevb4505a72015-03-30 05:20:59 +000053 // CHECK: [[RES:%.+]] = cmpxchg i32* [[SCALAR_ADDR]], i32 [[OLD_PHI_VAL]], i32 [[NEW_VAL]] monotonic monotonic
54 // CHECK: [[NEW_OLD_VAL]] = extractvalue { i32, i1 } [[RES]], 0
55 // CHECK: [[COND:%.+]] = extractvalue { i32, i1 } [[RES]], 1
56 // CHECK: br i1 [[COND]], label %[[OMP_DONE:.+]], label %[[OMP_UPDATE]]
57 // CHECK: [[OMP_DONE]]
Charles Lifad02412017-01-09 18:24:16 +000058 // CHECK: {{invoke|call}} void @_ZN2StD1Ev(%struct.St* [[TEMP_ST_ADDR]])
Alexey Bataevb4505a72015-03-30 05:20:59 +000059#pragma omp atomic
60 St().get() %= b;
Alexey Bataev5a195472015-09-04 12:55:50 +000061#pragma omp atomic
62 s.field++;
Sean Fertiled900dd02018-10-15 15:43:00 +000063 // CHECK: invoke void @_ZN2StC1Ev(%struct.St* [[TEMP_ST_ADDR:%.+]])
Alexey Bataev5e018f92015-04-23 06:35:10 +000064 // CHECK: [[SCALAR_ADDR:%.+]] = invoke dereferenceable(4) i32* @_ZN2St3getEv(%struct.St* [[TEMP_ST_ADDR]])
65 // CHECK: [[B_VAL:%.+]] = load i32, i32* @b
66 // CHECK: [[OLD_VAL:%.+]] = load atomic i32, i32* [[SCALAR_ADDR]] monotonic,
67 // CHECK: br label %[[OMP_UPDATE:.+]]
68 // CHECK: [[OMP_UPDATE]]
69 // CHECK: [[OLD_PHI_VAL:%.+]] = phi i32 [ [[OLD_VAL]], %{{.+}} ], [ [[NEW_OLD_VAL:%.+]], %[[OMP_UPDATE]] ]
Alexey Bataevf0ab5532015-05-15 08:36:34 +000070 // CHECK: [[NEW_CALC_VAL:%.+]] = srem i32 [[OLD_PHI_VAL]], [[B_VAL]]
71 // CHECK: store i32 [[NEW_CALC_VAL]], i32* [[TEMP:%.+]],
72 // CHECK: [[NEW_VAL:%.+]] = load i32, i32* [[TEMP]],
Alexey Bataev5e018f92015-04-23 06:35:10 +000073 // CHECK: [[RES:%.+]] = cmpxchg i32* [[SCALAR_ADDR]], i32 [[OLD_PHI_VAL]], i32 [[NEW_VAL]] monotonic monotonic
74 // CHECK: [[NEW_OLD_VAL]] = extractvalue { i32, i1 } [[RES]], 0
75 // CHECK: [[COND:%.+]] = extractvalue { i32, i1 } [[RES]], 1
76 // CHECK: br i1 [[COND]], label %[[OMP_DONE:.+]], label %[[OMP_UPDATE]]
77 // CHECK: [[OMP_DONE]]
Alexey Bataevf0ab5532015-05-15 08:36:34 +000078 // CHECK: store i32 [[NEW_CALC_VAL]], i32* @a,
Charles Lifad02412017-01-09 18:24:16 +000079 // CHECK: {{invoke|call}} void @_ZN2StD1Ev(%struct.St* [[TEMP_ST_ADDR]])
Alexey Bataev5e018f92015-04-23 06:35:10 +000080#pragma omp atomic capture
81 a = St().get() %= b;
Alexey Bataev10fec572015-03-11 04:48:56 +000082 }
83}
84
Alexey Bataev36bf0112015-03-10 05:15:26 +000085int &foo() { return a; }
86
87// TERM_DEBUG-LABEL: parallel_atomic
88void parallel_atomic() {
89#pragma omp parallel
90 {
91#pragma omp atomic read
92 // TERM_DEBUG-NOT: __kmpc_global_thread_num
93 // TERM_DEBUG: invoke {{.*}}foo{{.*}}()
94 // TERM_DEBUG: unwind label %[[TERM_LPAD:.+]],
Alexey Bataev10fec572015-03-11 04:48:56 +000095 // TERM_DEBUG: load atomic i32, i32* @{{.+}} monotonic, {{.*}}!dbg [[READ_LOC:![0-9]+]]
Alexey Bataev36bf0112015-03-10 05:15:26 +000096 foo() = a;
97#pragma omp atomic write
98 // TERM_DEBUG-NOT: __kmpc_global_thread_num
99 // TERM_DEBUG: invoke {{.*}}foo{{.*}}()
100 // TERM_DEBUG: unwind label %[[TERM_LPAD:.+]],
101 // TERM_DEBUG-NOT: __kmpc_global_thread_num
102 // TERM_DEBUG: store atomic i32 {{%.+}}, i32* @{{.+}} monotonic, {{.*}}!dbg [[WRITE_LOC:![0-9]+]]
Alexey Bataev36bf0112015-03-10 05:15:26 +0000103 a = foo();
Alexey Bataevb4505a72015-03-30 05:20:59 +0000104#pragma omp atomic update
105 // TERM_DEBUG-NOT: __kmpc_global_thread_num
106 // TERM_DEBUG: invoke {{.*}}foo{{.*}}()
107 // TERM_DEBUG: unwind label %[[TERM_LPAD:.+]],
108 // TERM_DEBUG-NOT: __kmpc_global_thread_num
109 // TERM_DEBUG: atomicrmw add i32* @{{.+}}, i32 %{{.+}} monotonic, {{.*}}!dbg [[UPDATE_LOC:![0-9]+]]
110 a += foo();
Alexey Bataev5e018f92015-04-23 06:35:10 +0000111#pragma omp atomic capture
112 // TERM_DEBUG-NOT: __kmpc_global_thread_num
113 // TERM_DEBUG: invoke {{.*}}foo{{.*}}()
114 // TERM_DEBUG: unwind label %[[TERM_LPAD:.+]],
115 // TERM_DEBUG-NOT: __kmpc_global_thread_num
116 // TERM_DEBUG: [[OLD_VAL:%.+]] = atomicrmw add i32* @{{.+}}, i32 %{{.+}} monotonic, {{.*}}!dbg [[CAPTURE_LOC:![0-9]+]]
117 // TERM_DEBUG: store i32 [[OLD_VAL]], i32* @b,
118 {b = a; a += foo(); }
Alexey Bataev36bf0112015-03-10 05:15:26 +0000119 }
Alexey Bataevb4505a72015-03-30 05:20:59 +0000120 // TERM_DEBUG: [[TERM_LPAD]]
121 // TERM_DEBUG: call void @__clang_call_terminate
122 // TERM_DEBUG: unreachable
Alexey Bataev36bf0112015-03-10 05:15:26 +0000123}
Alexey Bataev33c56402015-12-14 09:26:19 +0000124// TERM_DEBUG-DAG: [[READ_LOC]] = !DILocation(line: [[@LINE-28]],
125// TERM_DEBUG-DAG: [[WRITE_LOC]] = !DILocation(line: [[@LINE-22]],
126// TERM_DEBUG-DAG: [[UPDATE_LOC]] = !DILocation(line: [[@LINE-16]],
127// TERM_DEBUG-DAG: [[CAPTURE_LOC]] = !DILocation(line: [[@LINE-9]],