1*a2dbfb6bSGiorgis Georgakoudis // NOTE: Assertions have been autogenerated by utils/update_cc_test_checks.py UTC_ARGS: --function-signature --include-generated-funcs --replace-function-regex "__omp_offloading_[0-9a-z]+_[0-9a-z]+"
2*a2dbfb6bSGiorgis Georgakoudis // Test target codegen - host bc file has to be created first.
3*a2dbfb6bSGiorgis Georgakoudis // RUN: %clang_cc1 -verify -fopenmp -fopenmp-cuda-mode -x c++ -triple powerpc64le-unknown-unknown -fopenmp-targets=nvptx64-nvidia-cuda -emit-llvm-bc %s -o %t-ppc-host.bc
4*a2dbfb6bSGiorgis Georgakoudis // RUN: %clang_cc1 -verify -fopenmp -fopenmp-cuda-mode -x c++ -triple nvptx64-unknown-unknown -fopenmp-targets=nvptx64-nvidia-cuda -emit-llvm %s -fopenmp-is-device -fopenmp-host-ir-file-path %t-ppc-host.bc -o - -disable-llvm-optzns | FileCheck %s --check-prefix CHECK1
5*a2dbfb6bSGiorgis Georgakoudis // RUN: %clang_cc1 -verify -fopenmp -fopenmp-cuda-mode -x c++ -triple i386-unknown-unknown -fopenmp-targets=nvptx-nvidia-cuda -emit-llvm-bc %s -o %t-x86-host.bc
6*a2dbfb6bSGiorgis Georgakoudis // RUN: %clang_cc1 -verify -fopenmp -fopenmp-cuda-mode -x c++ -triple nvptx-unknown-unknown -fopenmp-targets=nvptx-nvidia-cuda -emit-llvm %s -fopenmp-is-device -fopenmp-host-ir-file-path %t-x86-host.bc -o - -disable-llvm-optzns | FileCheck %s --check-prefix CHECK2
7*a2dbfb6bSGiorgis Georgakoudis // RUN: %clang_cc1 -verify -fopenmp -fopenmp-cuda-mode -fexceptions -fcxx-exceptions -x c++ -triple nvptx-unknown-unknown -fopenmp-targets=nvptx-nvidia-cuda -emit-llvm %s -fopenmp-is-device -fopenmp-host-ir-file-path %t-x86-host.bc -o - -disable-llvm-optzns | FileCheck %s --check-prefix CHECK3
8*a2dbfb6bSGiorgis Georgakoudis 
9*a2dbfb6bSGiorgis Georgakoudis // expected-no-diagnostics
10*a2dbfb6bSGiorgis Georgakoudis #ifndef HEADER
11*a2dbfb6bSGiorgis Georgakoudis #define HEADER
12*a2dbfb6bSGiorgis Georgakoudis 
13*a2dbfb6bSGiorgis Georgakoudis void work();
14*a2dbfb6bSGiorgis Georgakoudis 
15*a2dbfb6bSGiorgis Georgakoudis void use() {
16*a2dbfb6bSGiorgis Georgakoudis       #pragma omp parallel
17*a2dbfb6bSGiorgis Georgakoudis       work();
18*a2dbfb6bSGiorgis Georgakoudis }
19*a2dbfb6bSGiorgis Georgakoudis 
20*a2dbfb6bSGiorgis Georgakoudis int main() {
21*a2dbfb6bSGiorgis Georgakoudis       #pragma omp target parallel
22*a2dbfb6bSGiorgis Georgakoudis       {  use(); }
23*a2dbfb6bSGiorgis Georgakoudis         #pragma omp target
24*a2dbfb6bSGiorgis Georgakoudis         {  use(); }
25*a2dbfb6bSGiorgis Georgakoudis }
26*a2dbfb6bSGiorgis Georgakoudis 
27*a2dbfb6bSGiorgis Georgakoudis #endif
28*a2dbfb6bSGiorgis Georgakoudis // CHECK1-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l21
29*a2dbfb6bSGiorgis Georgakoudis // CHECK1-SAME: () #[[ATTR0:[0-9]+]] {
30*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:  entry:
31*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[CAPTURED_VARS_ADDRS:%.*]] = alloca [0 x i8*], align 8
32*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_NUM_THREADS:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
33*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_spmd_kernel_init(i32 [[NVPTX_NUM_THREADS]], i16 1)
34*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_data_sharing_init_stack_spmd()
35*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTEXECUTE:%.*]]
36*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .execute:
37*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP0:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB1:[0-9]+]])
38*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP1:%.*]] = bitcast [0 x i8*]* [[CAPTURED_VARS_ADDRS]] to i8**
39*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_parallel_51(%struct.ident_t* @[[GLOB1]], i32 [[TMP0]], i32 1, i32 -1, i32 -1, i8* bitcast (void (i32*, i32*)* @__omp_outlined__ to i8*), i8* null, i8** [[TMP1]], i64 0)
40*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTOMP_DEINIT:%.*]]
41*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .omp.deinit:
42*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_spmd_kernel_deinit_v2(i16 1)
43*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTEXIT:%.*]]
44*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .exit:
45*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    ret void
46*a2dbfb6bSGiorgis Georgakoudis //
47*a2dbfb6bSGiorgis Georgakoudis //
48*a2dbfb6bSGiorgis Georgakoudis // CHECK1-LABEL: define {{[^@]+}}@__omp_outlined__
49*a2dbfb6bSGiorgis Georgakoudis // CHECK1-SAME: (i32* noalias [[DOTGLOBAL_TID_:%.*]], i32* noalias [[DOTBOUND_TID_:%.*]]) #[[ATTR0]] {
50*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:  entry:
51*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[DOTGLOBAL_TID__ADDR:%.*]] = alloca i32*, align 8
52*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[DOTBOUND_TID__ADDR:%.*]] = alloca i32*, align 8
53*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    store i32* [[DOTGLOBAL_TID_]], i32** [[DOTGLOBAL_TID__ADDR]], align 8
54*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    store i32* [[DOTBOUND_TID_]], i32** [[DOTBOUND_TID__ADDR]], align 8
55*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @_Z3usev() #[[ATTR7:[0-9]+]]
56*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    ret void
57*a2dbfb6bSGiorgis Georgakoudis //
58*a2dbfb6bSGiorgis Georgakoudis //
59*a2dbfb6bSGiorgis Georgakoudis // CHECK1-LABEL: define {{[^@]+}}@_Z3usev
60*a2dbfb6bSGiorgis Georgakoudis // CHECK1-SAME: () #[[ATTR2:[0-9]+]] {
61*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:  entry:
62*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[CAPTURED_VARS_ADDRS:%.*]] = alloca [0 x i8*], align 8
63*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP0:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB1]])
64*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP1:%.*]] = bitcast [0 x i8*]* [[CAPTURED_VARS_ADDRS]] to i8**
65*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_parallel_51(%struct.ident_t* @[[GLOB1]], i32 [[TMP0]], i32 1, i32 -1, i32 -1, i8* bitcast (void (i32*, i32*)* @__omp_outlined__1 to i8*), i8* null, i8** [[TMP1]], i64 0)
66*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    ret void
67*a2dbfb6bSGiorgis Georgakoudis //
68*a2dbfb6bSGiorgis Georgakoudis //
69*a2dbfb6bSGiorgis Georgakoudis // CHECK1-LABEL: define {{[^@]+}}@__omp_outlined__1
70*a2dbfb6bSGiorgis Georgakoudis // CHECK1-SAME: (i32* noalias [[DOTGLOBAL_TID_:%.*]], i32* noalias [[DOTBOUND_TID_:%.*]]) #[[ATTR0]] {
71*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:  entry:
72*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[DOTGLOBAL_TID__ADDR:%.*]] = alloca i32*, align 8
73*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[DOTBOUND_TID__ADDR:%.*]] = alloca i32*, align 8
74*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    store i32* [[DOTGLOBAL_TID_]], i32** [[DOTGLOBAL_TID__ADDR]], align 8
75*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    store i32* [[DOTBOUND_TID_]], i32** [[DOTBOUND_TID__ADDR]], align 8
76*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @_Z4workv() #[[ATTR7]]
77*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    ret void
78*a2dbfb6bSGiorgis Georgakoudis //
79*a2dbfb6bSGiorgis Georgakoudis //
80*a2dbfb6bSGiorgis Georgakoudis // CHECK1-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23_worker
81*a2dbfb6bSGiorgis Georgakoudis // CHECK1-SAME: () #[[ATTR5:[0-9]+]] {
82*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:  entry:
83*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[WORK_FN:%.*]] = alloca i8*, align 8
84*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[EXEC_STATUS:%.*]] = alloca i8, align 1
85*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    store i8* null, i8** [[WORK_FN]], align 8
86*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    store i8 0, i8* [[EXEC_STATUS]], align 1
87*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTAWAIT_WORK:%.*]]
88*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .await.work:
89*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
90*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP0:%.*]] = call i1 @__kmpc_kernel_parallel(i8** [[WORK_FN]])
91*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP1:%.*]] = zext i1 [[TMP0]] to i8
92*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    store i8 [[TMP1]], i8* [[EXEC_STATUS]], align 1
93*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP2:%.*]] = load i8*, i8** [[WORK_FN]], align 8
94*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[SHOULD_TERMINATE:%.*]] = icmp eq i8* [[TMP2]], null
95*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br i1 [[SHOULD_TERMINATE]], label [[DOTEXIT:%.*]], label [[DOTSELECT_WORKERS:%.*]]
96*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .select.workers:
97*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP3:%.*]] = load i8, i8* [[EXEC_STATUS]], align 1
98*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[IS_ACTIVE:%.*]] = icmp ne i8 [[TMP3]], 0
99*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br i1 [[IS_ACTIVE]], label [[DOTEXECUTE_PARALLEL:%.*]], label [[DOTBARRIER_PARALLEL:%.*]]
100*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .execute.parallel:
101*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP4:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB2:[0-9]+]])
102*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP5:%.*]] = bitcast i8* [[TMP2]] to void (i16, i32)*
103*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void [[TMP5]](i16 0, i32 [[TMP4]])
104*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTTERMINATE_PARALLEL:%.*]]
105*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .terminate.parallel:
106*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_kernel_end_parallel()
107*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTBARRIER_PARALLEL]]
108*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .barrier.parallel:
109*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
110*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTAWAIT_WORK]]
111*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .exit:
112*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    ret void
113*a2dbfb6bSGiorgis Georgakoudis //
114*a2dbfb6bSGiorgis Georgakoudis //
115*a2dbfb6bSGiorgis Georgakoudis // CHECK1-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23
116*a2dbfb6bSGiorgis Georgakoudis // CHECK1-SAME: () #[[ATTR0]] {
117*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:  entry:
118*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_TID:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.tid.x()
119*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_NUM_THREADS:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
120*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_WARP_SIZE:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
121*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[THREAD_LIMIT:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS]], [[NVPTX_WARP_SIZE]]
122*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP0:%.*]] = icmp ult i32 [[NVPTX_TID]], [[THREAD_LIMIT]]
123*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br i1 [[TMP0]], label [[DOTWORKER:%.*]], label [[DOTMASTERCHECK:%.*]]
124*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .worker:
125*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23_worker() #[[ATTR4:[0-9]+]]
126*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTEXIT:%.*]]
127*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .mastercheck:
128*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_TID1:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.tid.x()
129*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_NUM_THREADS2:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
130*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_WARP_SIZE3:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
131*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP1:%.*]] = sub nuw i32 [[NVPTX_WARP_SIZE3]], 1
132*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP2:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS2]], 1
133*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP3:%.*]] = xor i32 [[TMP1]], -1
134*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[MASTER_TID:%.*]] = and i32 [[TMP2]], [[TMP3]]
135*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[TMP4:%.*]] = icmp eq i32 [[NVPTX_TID1]], [[MASTER_TID]]
136*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br i1 [[TMP4]], label [[DOTMASTER:%.*]], label [[DOTEXIT]]
137*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .master:
138*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_NUM_THREADS4:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
139*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[NVPTX_WARP_SIZE5:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
140*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    [[THREAD_LIMIT6:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS4]], [[NVPTX_WARP_SIZE5]]
141*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_kernel_init(i32 [[THREAD_LIMIT6]], i16 1)
142*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_data_sharing_init_stack()
143*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @_Z3usev() #[[ATTR7]]
144*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTTERMINATION_NOTIFIER:%.*]]
145*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .termination.notifier:
146*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_kernel_deinit(i16 1)
147*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
148*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    br label [[DOTEXIT]]
149*a2dbfb6bSGiorgis Georgakoudis // CHECK1:       .exit:
150*a2dbfb6bSGiorgis Georgakoudis // CHECK1-NEXT:    ret void
151*a2dbfb6bSGiorgis Georgakoudis //
152*a2dbfb6bSGiorgis Georgakoudis //
153*a2dbfb6bSGiorgis Georgakoudis // CHECK2-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l21
154*a2dbfb6bSGiorgis Georgakoudis // CHECK2-SAME: () #[[ATTR0:[0-9]+]] {
155*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:  entry:
156*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[CAPTURED_VARS_ADDRS:%.*]] = alloca [0 x i8*], align 4
157*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_NUM_THREADS:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
158*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_spmd_kernel_init(i32 [[NVPTX_NUM_THREADS]], i16 1)
159*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_data_sharing_init_stack_spmd()
160*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTEXECUTE:%.*]]
161*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .execute:
162*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP0:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB1:[0-9]+]])
163*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP1:%.*]] = bitcast [0 x i8*]* [[CAPTURED_VARS_ADDRS]] to i8**
164*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_parallel_51(%struct.ident_t* @[[GLOB1]], i32 [[TMP0]], i32 1, i32 -1, i32 -1, i8* bitcast (void (i32*, i32*)* @__omp_outlined__ to i8*), i8* null, i8** [[TMP1]], i32 0)
165*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTOMP_DEINIT:%.*]]
166*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .omp.deinit:
167*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_spmd_kernel_deinit_v2(i16 1)
168*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTEXIT:%.*]]
169*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .exit:
170*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    ret void
171*a2dbfb6bSGiorgis Georgakoudis //
172*a2dbfb6bSGiorgis Georgakoudis //
173*a2dbfb6bSGiorgis Georgakoudis // CHECK2-LABEL: define {{[^@]+}}@__omp_outlined__
174*a2dbfb6bSGiorgis Georgakoudis // CHECK2-SAME: (i32* noalias [[DOTGLOBAL_TID_:%.*]], i32* noalias [[DOTBOUND_TID_:%.*]]) #[[ATTR0]] {
175*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:  entry:
176*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[DOTGLOBAL_TID__ADDR:%.*]] = alloca i32*, align 4
177*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[DOTBOUND_TID__ADDR:%.*]] = alloca i32*, align 4
178*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    store i32* [[DOTGLOBAL_TID_]], i32** [[DOTGLOBAL_TID__ADDR]], align 4
179*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    store i32* [[DOTBOUND_TID_]], i32** [[DOTBOUND_TID__ADDR]], align 4
180*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @_Z3usev() #[[ATTR7:[0-9]+]]
181*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    ret void
182*a2dbfb6bSGiorgis Georgakoudis //
183*a2dbfb6bSGiorgis Georgakoudis //
184*a2dbfb6bSGiorgis Georgakoudis // CHECK2-LABEL: define {{[^@]+}}@_Z3usev
185*a2dbfb6bSGiorgis Georgakoudis // CHECK2-SAME: () #[[ATTR2:[0-9]+]] {
186*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:  entry:
187*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[CAPTURED_VARS_ADDRS:%.*]] = alloca [0 x i8*], align 4
188*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP0:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB1]])
189*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP1:%.*]] = bitcast [0 x i8*]* [[CAPTURED_VARS_ADDRS]] to i8**
190*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_parallel_51(%struct.ident_t* @[[GLOB1]], i32 [[TMP0]], i32 1, i32 -1, i32 -1, i8* bitcast (void (i32*, i32*)* @__omp_outlined__1 to i8*), i8* null, i8** [[TMP1]], i32 0)
191*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    ret void
192*a2dbfb6bSGiorgis Georgakoudis //
193*a2dbfb6bSGiorgis Georgakoudis //
194*a2dbfb6bSGiorgis Georgakoudis // CHECK2-LABEL: define {{[^@]+}}@__omp_outlined__1
195*a2dbfb6bSGiorgis Georgakoudis // CHECK2-SAME: (i32* noalias [[DOTGLOBAL_TID_:%.*]], i32* noalias [[DOTBOUND_TID_:%.*]]) #[[ATTR0]] {
196*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:  entry:
197*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[DOTGLOBAL_TID__ADDR:%.*]] = alloca i32*, align 4
198*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[DOTBOUND_TID__ADDR:%.*]] = alloca i32*, align 4
199*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    store i32* [[DOTGLOBAL_TID_]], i32** [[DOTGLOBAL_TID__ADDR]], align 4
200*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    store i32* [[DOTBOUND_TID_]], i32** [[DOTBOUND_TID__ADDR]], align 4
201*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @_Z4workv() #[[ATTR7]]
202*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    ret void
203*a2dbfb6bSGiorgis Georgakoudis //
204*a2dbfb6bSGiorgis Georgakoudis //
205*a2dbfb6bSGiorgis Georgakoudis // CHECK2-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23_worker
206*a2dbfb6bSGiorgis Georgakoudis // CHECK2-SAME: () #[[ATTR5:[0-9]+]] {
207*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:  entry:
208*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[WORK_FN:%.*]] = alloca i8*, align 4
209*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[EXEC_STATUS:%.*]] = alloca i8, align 1
210*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    store i8* null, i8** [[WORK_FN]], align 4
211*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    store i8 0, i8* [[EXEC_STATUS]], align 1
212*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTAWAIT_WORK:%.*]]
213*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .await.work:
214*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
215*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP0:%.*]] = call i1 @__kmpc_kernel_parallel(i8** [[WORK_FN]])
216*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP1:%.*]] = zext i1 [[TMP0]] to i8
217*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    store i8 [[TMP1]], i8* [[EXEC_STATUS]], align 1
218*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP2:%.*]] = load i8*, i8** [[WORK_FN]], align 4
219*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[SHOULD_TERMINATE:%.*]] = icmp eq i8* [[TMP2]], null
220*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br i1 [[SHOULD_TERMINATE]], label [[DOTEXIT:%.*]], label [[DOTSELECT_WORKERS:%.*]]
221*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .select.workers:
222*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP3:%.*]] = load i8, i8* [[EXEC_STATUS]], align 1
223*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[IS_ACTIVE:%.*]] = icmp ne i8 [[TMP3]], 0
224*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br i1 [[IS_ACTIVE]], label [[DOTEXECUTE_PARALLEL:%.*]], label [[DOTBARRIER_PARALLEL:%.*]]
225*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .execute.parallel:
226*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP4:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB2:[0-9]+]])
227*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP5:%.*]] = bitcast i8* [[TMP2]] to void (i16, i32)*
228*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void [[TMP5]](i16 0, i32 [[TMP4]])
229*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTTERMINATE_PARALLEL:%.*]]
230*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .terminate.parallel:
231*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_kernel_end_parallel()
232*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTBARRIER_PARALLEL]]
233*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .barrier.parallel:
234*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
235*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTAWAIT_WORK]]
236*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .exit:
237*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    ret void
238*a2dbfb6bSGiorgis Georgakoudis //
239*a2dbfb6bSGiorgis Georgakoudis //
240*a2dbfb6bSGiorgis Georgakoudis // CHECK2-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23
241*a2dbfb6bSGiorgis Georgakoudis // CHECK2-SAME: () #[[ATTR0]] {
242*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:  entry:
243*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_TID:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.tid.x()
244*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_NUM_THREADS:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
245*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_WARP_SIZE:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
246*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[THREAD_LIMIT:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS]], [[NVPTX_WARP_SIZE]]
247*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP0:%.*]] = icmp ult i32 [[NVPTX_TID]], [[THREAD_LIMIT]]
248*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br i1 [[TMP0]], label [[DOTWORKER:%.*]], label [[DOTMASTERCHECK:%.*]]
249*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .worker:
250*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23_worker() #[[ATTR4:[0-9]+]]
251*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTEXIT:%.*]]
252*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .mastercheck:
253*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_TID1:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.tid.x()
254*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_NUM_THREADS2:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
255*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_WARP_SIZE3:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
256*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP1:%.*]] = sub nuw i32 [[NVPTX_WARP_SIZE3]], 1
257*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP2:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS2]], 1
258*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP3:%.*]] = xor i32 [[TMP1]], -1
259*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[MASTER_TID:%.*]] = and i32 [[TMP2]], [[TMP3]]
260*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[TMP4:%.*]] = icmp eq i32 [[NVPTX_TID1]], [[MASTER_TID]]
261*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br i1 [[TMP4]], label [[DOTMASTER:%.*]], label [[DOTEXIT]]
262*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .master:
263*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_NUM_THREADS4:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
264*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[NVPTX_WARP_SIZE5:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
265*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    [[THREAD_LIMIT6:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS4]], [[NVPTX_WARP_SIZE5]]
266*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_kernel_init(i32 [[THREAD_LIMIT6]], i16 1)
267*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_data_sharing_init_stack()
268*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @_Z3usev() #[[ATTR7]]
269*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTTERMINATION_NOTIFIER:%.*]]
270*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .termination.notifier:
271*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_kernel_deinit(i16 1)
272*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
273*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    br label [[DOTEXIT]]
274*a2dbfb6bSGiorgis Georgakoudis // CHECK2:       .exit:
275*a2dbfb6bSGiorgis Georgakoudis // CHECK2-NEXT:    ret void
276*a2dbfb6bSGiorgis Georgakoudis //
277*a2dbfb6bSGiorgis Georgakoudis //
278*a2dbfb6bSGiorgis Georgakoudis // CHECK3-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l21
279*a2dbfb6bSGiorgis Georgakoudis // CHECK3-SAME: () #[[ATTR0:[0-9]+]] {
280*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:  entry:
281*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[CAPTURED_VARS_ADDRS:%.*]] = alloca [0 x i8*], align 4
282*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_NUM_THREADS:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
283*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_spmd_kernel_init(i32 [[NVPTX_NUM_THREADS]], i16 1)
284*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_data_sharing_init_stack_spmd()
285*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTEXECUTE:%.*]]
286*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .execute:
287*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP0:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB1:[0-9]+]])
288*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP1:%.*]] = bitcast [0 x i8*]* [[CAPTURED_VARS_ADDRS]] to i8**
289*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_parallel_51(%struct.ident_t* @[[GLOB1]], i32 [[TMP0]], i32 1, i32 -1, i32 -1, i8* bitcast (void (i32*, i32*)* @__omp_outlined__ to i8*), i8* null, i8** [[TMP1]], i32 0)
290*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTOMP_DEINIT:%.*]]
291*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .omp.deinit:
292*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_spmd_kernel_deinit_v2(i16 1)
293*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTEXIT:%.*]]
294*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .exit:
295*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    ret void
296*a2dbfb6bSGiorgis Georgakoudis //
297*a2dbfb6bSGiorgis Georgakoudis //
298*a2dbfb6bSGiorgis Georgakoudis // CHECK3-LABEL: define {{[^@]+}}@__omp_outlined__
299*a2dbfb6bSGiorgis Georgakoudis // CHECK3-SAME: (i32* noalias [[DOTGLOBAL_TID_:%.*]], i32* noalias [[DOTBOUND_TID_:%.*]]) #[[ATTR0]] {
300*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:  entry:
301*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[DOTGLOBAL_TID__ADDR:%.*]] = alloca i32*, align 4
302*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[DOTBOUND_TID__ADDR:%.*]] = alloca i32*, align 4
303*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    store i32* [[DOTGLOBAL_TID_]], i32** [[DOTGLOBAL_TID__ADDR]], align 4
304*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    store i32* [[DOTBOUND_TID_]], i32** [[DOTBOUND_TID__ADDR]], align 4
305*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @_Z3usev() #[[ATTR7:[0-9]+]]
306*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    ret void
307*a2dbfb6bSGiorgis Georgakoudis //
308*a2dbfb6bSGiorgis Georgakoudis //
309*a2dbfb6bSGiorgis Georgakoudis // CHECK3-LABEL: define {{[^@]+}}@_Z3usev
310*a2dbfb6bSGiorgis Georgakoudis // CHECK3-SAME: () #[[ATTR2:[0-9]+]] {
311*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:  entry:
312*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[CAPTURED_VARS_ADDRS:%.*]] = alloca [0 x i8*], align 4
313*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP0:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB1]])
314*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP1:%.*]] = bitcast [0 x i8*]* [[CAPTURED_VARS_ADDRS]] to i8**
315*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_parallel_51(%struct.ident_t* @[[GLOB1]], i32 [[TMP0]], i32 1, i32 -1, i32 -1, i8* bitcast (void (i32*, i32*)* @__omp_outlined__1 to i8*), i8* null, i8** [[TMP1]], i32 0)
316*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    ret void
317*a2dbfb6bSGiorgis Georgakoudis //
318*a2dbfb6bSGiorgis Georgakoudis //
319*a2dbfb6bSGiorgis Georgakoudis // CHECK3-LABEL: define {{[^@]+}}@__omp_outlined__1
320*a2dbfb6bSGiorgis Georgakoudis // CHECK3-SAME: (i32* noalias [[DOTGLOBAL_TID_:%.*]], i32* noalias [[DOTBOUND_TID_:%.*]]) #[[ATTR0]] {
321*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:  entry:
322*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[DOTGLOBAL_TID__ADDR:%.*]] = alloca i32*, align 4
323*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[DOTBOUND_TID__ADDR:%.*]] = alloca i32*, align 4
324*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    store i32* [[DOTGLOBAL_TID_]], i32** [[DOTGLOBAL_TID__ADDR]], align 4
325*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    store i32* [[DOTBOUND_TID_]], i32** [[DOTBOUND_TID__ADDR]], align 4
326*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @_Z4workv() #[[ATTR7]]
327*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    ret void
328*a2dbfb6bSGiorgis Georgakoudis //
329*a2dbfb6bSGiorgis Georgakoudis //
330*a2dbfb6bSGiorgis Georgakoudis // CHECK3-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23_worker
331*a2dbfb6bSGiorgis Georgakoudis // CHECK3-SAME: () #[[ATTR5:[0-9]+]] {
332*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:  entry:
333*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[WORK_FN:%.*]] = alloca i8*, align 4
334*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[EXEC_STATUS:%.*]] = alloca i8, align 1
335*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    store i8* null, i8** [[WORK_FN]], align 4
336*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    store i8 0, i8* [[EXEC_STATUS]], align 1
337*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTAWAIT_WORK:%.*]]
338*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .await.work:
339*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
340*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP0:%.*]] = call i1 @__kmpc_kernel_parallel(i8** [[WORK_FN]])
341*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP1:%.*]] = zext i1 [[TMP0]] to i8
342*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    store i8 [[TMP1]], i8* [[EXEC_STATUS]], align 1
343*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP2:%.*]] = load i8*, i8** [[WORK_FN]], align 4
344*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[SHOULD_TERMINATE:%.*]] = icmp eq i8* [[TMP2]], null
345*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br i1 [[SHOULD_TERMINATE]], label [[DOTEXIT:%.*]], label [[DOTSELECT_WORKERS:%.*]]
346*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .select.workers:
347*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP3:%.*]] = load i8, i8* [[EXEC_STATUS]], align 1
348*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[IS_ACTIVE:%.*]] = icmp ne i8 [[TMP3]], 0
349*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br i1 [[IS_ACTIVE]], label [[DOTEXECUTE_PARALLEL:%.*]], label [[DOTBARRIER_PARALLEL:%.*]]
350*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .execute.parallel:
351*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP4:%.*]] = call i32 @__kmpc_global_thread_num(%struct.ident_t* @[[GLOB2:[0-9]+]])
352*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP5:%.*]] = bitcast i8* [[TMP2]] to void (i16, i32)*
353*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void [[TMP5]](i16 0, i32 [[TMP4]])
354*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTTERMINATE_PARALLEL:%.*]]
355*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .terminate.parallel:
356*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_kernel_end_parallel()
357*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTBARRIER_PARALLEL]]
358*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .barrier.parallel:
359*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
360*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTAWAIT_WORK]]
361*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .exit:
362*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    ret void
363*a2dbfb6bSGiorgis Georgakoudis //
364*a2dbfb6bSGiorgis Georgakoudis //
365*a2dbfb6bSGiorgis Georgakoudis // CHECK3-LABEL: define {{[^@]+}}@{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23
366*a2dbfb6bSGiorgis Georgakoudis // CHECK3-SAME: () #[[ATTR0]] {
367*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:  entry:
368*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_TID:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.tid.x()
369*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_NUM_THREADS:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
370*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_WARP_SIZE:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
371*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[THREAD_LIMIT:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS]], [[NVPTX_WARP_SIZE]]
372*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP0:%.*]] = icmp ult i32 [[NVPTX_TID]], [[THREAD_LIMIT]]
373*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br i1 [[TMP0]], label [[DOTWORKER:%.*]], label [[DOTMASTERCHECK:%.*]]
374*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .worker:
375*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @{{__omp_offloading_[0-9a-z]+_[0-9a-z]+}}_main_l23_worker() #[[ATTR4:[0-9]+]]
376*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTEXIT:%.*]]
377*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .mastercheck:
378*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_TID1:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.tid.x()
379*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_NUM_THREADS2:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
380*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_WARP_SIZE3:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
381*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP1:%.*]] = sub nuw i32 [[NVPTX_WARP_SIZE3]], 1
382*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP2:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS2]], 1
383*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP3:%.*]] = xor i32 [[TMP1]], -1
384*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[MASTER_TID:%.*]] = and i32 [[TMP2]], [[TMP3]]
385*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[TMP4:%.*]] = icmp eq i32 [[NVPTX_TID1]], [[MASTER_TID]]
386*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br i1 [[TMP4]], label [[DOTMASTER:%.*]], label [[DOTEXIT]]
387*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .master:
388*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_NUM_THREADS4:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.ntid.x()
389*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[NVPTX_WARP_SIZE5:%.*]] = call i32 @llvm.nvvm.read.ptx.sreg.warpsize()
390*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    [[THREAD_LIMIT6:%.*]] = sub nuw i32 [[NVPTX_NUM_THREADS4]], [[NVPTX_WARP_SIZE5]]
391*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_kernel_init(i32 [[THREAD_LIMIT6]], i16 1)
392*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_data_sharing_init_stack()
393*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @_Z3usev() #[[ATTR7]]
394*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTTERMINATION_NOTIFIER:%.*]]
395*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .termination.notifier:
396*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_kernel_deinit(i16 1)
397*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    call void @__kmpc_barrier_simple_spmd(%struct.ident_t* null, i32 0)
398*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    br label [[DOTEXIT]]
399*a2dbfb6bSGiorgis Georgakoudis // CHECK3:       .exit:
400*a2dbfb6bSGiorgis Georgakoudis // CHECK3-NEXT:    ret void
401*a2dbfb6bSGiorgis Georgakoudis //
402