// RUN: %clang_cc1 -verify -fopenmp -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple x86_64-unknown-unknown -emit-llvm %s -o - | FileCheck %s --check-prefix CHECK --check-prefix OMP45 // RUN: %clang_cc1 -fopenmp -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple x86_64-unknown-unknown -emit-pch -o %t %s // RUN: %clang_cc1 -fopenmp -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple x86_64-unknown-unknown -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s --check-prefix CHECK --check-prefix OMP45 // RUN: %clang_cc1 -verify -fopenmp -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple x86_64-unknown-unknown -emit-llvm %s -o - | FileCheck %s --check-prefix CHECK --check-prefix OMP50 // RUN: %clang_cc1 -fopenmp -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple x86_64-unknown-unknown -emit-pch -o %t %s // RUN: %clang_cc1 -fopenmp -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple x86_64-unknown-unknown -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s --check-prefix CHECK --check-prefix OMP50 // RUN: %clang_cc1 -verify -fopenmp-simd -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple x86_64-unknown-unknown -emit-llvm %s -o - | FileCheck %s --check-prefix SIMD-ONLY // RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple x86_64-unknown-unknown -emit-pch -o %t %s // RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple x86_64-unknown-unknown -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s --check-prefix SIMD-ONLY // RUN: %clang_cc1 -verify -fopenmp-simd -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple x86_64-unknown-unknown -emit-llvm %s -o - | FileCheck %s --check-prefix SIMD-ONLY // RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple x86_64-unknown-unknown -emit-pch -o %t %s // RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple x86_64-unknown-unknown -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s --check-prefix SIMD-ONLY // SIMD-ONLY-NOT: {{__kmpc|__tgt}} // RUN: %clang_cc1 -verify -fopenmp -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple aarch64-unknown-unknown -emit-llvm %s -o - | FileCheck %s --check-prefix CHECK --check-prefix OMP45 // RUN: %clang_cc1 -fopenmp -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple aarch64-unknown-unknown -emit-pch -o %t %s // RUN: %clang_cc1 -fopenmp -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple aarch64-unknown-unknown -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s --check-prefix CHECK --check-prefix OMP45 // RUN: %clang_cc1 -verify -fopenmp -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple aarch64-unknown-unknown -emit-llvm %s -o - | FileCheck %s --check-prefix CHECK --check-prefix OMP50 // RUN: %clang_cc1 -fopenmp -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple aarch64-unknown-unknown -emit-pch -o %t %s // RUN: %clang_cc1 -fopenmp -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple aarch64-unknown-unknown -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s --check-prefix CHECK --check-prefix OMP50 // RUN: %clang_cc1 -verify -fopenmp-simd -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple aarch64-unknown-unknown -emit-llvm %s -o - | FileCheck %s --check-prefix SIMD-ONLY // RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple aarch64-unknown-unknown -emit-pch -o %t %s // RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=45 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple aarch64-unknown-unknown -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s --check-prefix SIMD-ONLY // RUN: %clang_cc1 -verify -fopenmp-simd -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple aarch64-unknown-unknown -emit-llvm %s -o - | FileCheck %s --check-prefix SIMD-ONLY // RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -std=c++11 -triple aarch64-unknown-unknown -emit-pch -o %t %s // RUN: %clang_cc1 -fopenmp-simd -fopenmp-version=50 -DOMP5 -fopenmp-targets=powerpc64le-ibm-linux-gnu -x c++ -triple aarch64-unknown-unknown -std=c++11 -include-pch %t -verify %s -emit-llvm -o - | FileCheck %s --check-prefix SIMD-ONLY // SIMD-ONLY-NOT: {{__kmpc|__tgt}} // expected-no-diagnostics #ifndef HEADER #define HEADER void fn1(); void fn2(); void fn3(); void fn4(); void fn5(); void fn6(); int Arg; // CHECK-LABEL: define {{.*}}void @{{.+}}gtid_test void gtid_test() { // CHECK: call void @__kmpc_push_target_tripcount_mapper(%struct.ident_t* @{{.+}}, i64 -1, i64 100) // CHECK: call i{{[0-9]+}} @__tgt_target_teams_mapper(%struct.ident_t* @{{.+}}, // CHECK: call void [[OFFLOADING_FUN_0:@.+]]( // CHECK: call void @__kmpc_push_target_tripcount_mapper(%struct.ident_t* @{{.+}}, i64 -1, i64 100) // CHECK: call i{{[0-9]+}} @__tgt_target_teams_mapper(%struct.ident_t* @{{.+}}, // CHECK: call void [[OFFLOADING_FUN_1:@.+]]( #ifdef OMP5 #pragma omp target teams distribute parallel for simd if(simd: true) nontemporal(Arg) #else #pragma omp target teams distribute parallel for simd #endif // OMP5 for (int i = 0; i < 100; i++) { Arg = 0; } // CHECK: define internal void [[OFFLOADING_FUN_0]]( // CHECK: call {{.*}}void {{.+}} @__kmpc_fork_teams({{.+}}, i32 1, {{.+}}* [[OMP_TEAMS_OUTLINED_0:@.+]] to {{.+}}) // CHECK: define{{.+}} void [[OMP_TEAMS_OUTLINED_0]]( // CHECK: call void @__kmpc_for_static_init_4( // OMP50: load i32,{{.*}}!nontemporal // CHECK: call void {{.+}} @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{.+}} 3, {{.+}}* [[OMP_OUTLINED_0:@.+]] to void // CHECK: call void @__kmpc_for_static_fini( // CHECK: define{{.+}} void [[OMP_OUTLINED_0]]( // CHECK: call void @__kmpc_for_static_init_4( // OMP45-NOT: !nontemporal // OMP50: store i32 0,{{.*}}!nontemporal // CHECK: call void @__kmpc_for_static_fini( // CHECK: ret #pragma omp target teams distribute parallel for simd if (parallel: false) for(int i = 0 ; i < 100; i++) { // CHECK: define internal void [[OFFLOADING_FUN_1]]( // CHECK: call {{.*}}void {{.+}} @__kmpc_fork_teams({{.+}}, i32 0, {{.+}}* [[OMP_TEAMS_OUTLINED_1:@.+]] to {{.+}}) // CHECK: define{{.+}} void [[OMP_TEAMS_OUTLINED_1]]( // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call void @__kmpc_serialized_parallel( // CHECK: call void [[OMP_OUTLINED_1:@.+]]( // CHECK: call void @__kmpc_end_serialized_parallel( // CHECK: call void @__kmpc_for_static_fini( // CHECK: define{{.+}} void [[OMP_OUTLINED_1]]( // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call void @{{.+}}gtid_test // CHECK: call void @__kmpc_for_static_fini( // CHECK: ret gtid_test(); } } template int tmain(T Arg) { #pragma omp target teams distribute parallel for simd if (true) for(int i = 0 ; i < 100; i++) { fn1(); } #pragma omp target teams distribute parallel for simd if (false) for(int i = 0 ; i < 100; i++) { fn2(); } #pragma omp target teams distribute parallel for simd if (parallel: Arg) for(int i = 0 ; i < 100; i++) { fn3(); } return 0; } // CHECK-LABEL: define {{.*}}i{{[0-9]+}} @main() int main() { // CHECK: call void @__kmpc_push_target_tripcount_mapper(%struct.ident_t* @{{.+}}, i64 -1, i64 100) // CHECK: call i{{[0-9]+}} @__tgt_target_teams_mapper(%struct.ident_t* @{{.+}}, // CHECK: call void [[OFFLOADING_FUN_0:@.+]]( // CHECK-NOT: call void @__kmpc_push_target_tripcount_mapper(%struct.ident_t* @{{.+}}, i64 -1, i64 100) // CHECK: call void [[OFFLOADING_FUN_1:@.+]]( // CHECK: call void @__kmpc_push_target_tripcount_mapper(%struct.ident_t* @{{.+}}, i64 -1, i64 100) // CHECK: call i{{[0-9]+}} @__tgt_target_teams_mapper(%struct.ident_t* @{{.+}}, // CHECK: call void [[OFFLOADING_FUN_2:@.+]]( // CHECK: = call {{.*}}i{{.+}} @{{.+}}tmain #pragma omp target teams distribute parallel for simd if (true) for(int i = 0 ; i < 100; i++) { // CHECK: define internal void [[OFFLOADING_FUN_0]]( // CHECK: call {{.*}}void {{.+}} @__kmpc_fork_teams({{.+}}, i32 0, {{.+}}* [[OMP_TEAMS_OUTLINED_0:@.+]] to {{.+}}) // CHECK: define{{.+}} void [[OMP_TEAMS_OUTLINED_0]]( // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call void {{.+}} @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{.+}} 2, {{.+}}* [[OMP_OUTLINED_2:@.+]] to void // CHECK: call void @__kmpc_for_static_fini( // CHECK: define{{.+}} void [[OMP_OUTLINED_2]]( // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void @{{.+}}fn4 // CHECK: call void @__kmpc_for_static_fini( fn4(); } #pragma omp target teams distribute parallel for simd if (false) for(int i = 0 ; i < 100; i++) { // CHECK: define internal void [[OFFLOADING_FUN_1]]( // CHECK: call {{.*}}void {{.+}} @__kmpc_fork_teams({{.+}}, i32 0, {{.+}}* [[OMP_TEAMS_OUTLINED_1:@.+]] to {{.+}}) // CHECK: define{{.+}} void [[OMP_TEAMS_OUTLINED_1]]( // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call void @__kmpc_serialized_parallel( // CHECK: call void [[OMP_OUTLINED_3:@.+]]( // CHECK: call void @__kmpc_end_serialized_parallel( // CHECK: call void @__kmpc_for_static_fini( // CHECK: define{{.+}} void [[OMP_OUTLINED_3]]( // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void @{{.+}}fn5 // CHECK: call void @__kmpc_for_static_fini( fn5(); } #pragma omp target teams distribute parallel for simd if (Arg) for(int i = 0 ; i < 100; i++) { // CHECK: define internal void [[OFFLOADING_FUN_2]]( // CHECK: call {{.*}}void {{.+}} @__kmpc_fork_teams({{.+}}, i32 1, {{.+}}* [[OMP_TEAMS_OUTLINED_2:@.+]] to {{.+}}) // CHECK: define{{.+}} void [[OMP_TEAMS_OUTLINED_2]]( // CHECK: call void @__kmpc_for_static_init_4( // OMP45: call void {{.+}} @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{.+}} 2, {{.+}}* [[OMP_OUTLINED_4:@.+]] to void // OMP50: call void {{.+}} @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{.+}} 3, {{.+}}* [[OMP_OUTLINED_4:@.+]] to void // CHECK: call void @__kmpc_serialized_parallel( // CHECK: call void [[OMP_OUTLINED_4:@.+]]( // CHECK: call void @__kmpc_end_serialized_parallel( // CHECK: call void @__kmpc_for_static_fini( // CHECK: define{{.+}} void [[OMP_OUTLINED_4]]( // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void @{{.+}}fn6 // CHECK: call void @__kmpc_for_static_fini( fn6(); } return tmain(Arg); } // CHECK-LABEL: define {{.+}} @{{.+}}tmain // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void {{.+}} @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{.+}} 2, void {{.+}}* [[T_OUTLINE_FUN_1:@.+]] to void // CHECK: call void @__kmpc_for_static_fini( // CHECK: define internal {{.*}}void [[T_OUTLINE_FUN_1]] // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void @{{.+}}fn1 // CHECK: call void @__kmpc_for_static_fini( // CHECK: ret void // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void @__kmpc_serialized_parallel( // CHECK: call void [[T_OUTLINE_FUN_2:@.+]]( // CHECK: call {{.*}}void @__kmpc_end_serialized_parallel( // CHECK: call void @__kmpc_for_static_fini( // CHECK: define internal {{.*}}void [[T_OUTLINE_FUN_2]] // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void @{{.+}}fn2 // CHECK: call void @__kmpc_for_static_fini( // CHECK: ret void // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void {{.+}} @__kmpc_fork_call(%{{.+}}* @{{.+}}, i{{.+}} 2, void {{.+}}* [[T_OUTLINE_FUN_3:@.+]] to void // CHECK: call {{.*}}void @__kmpc_serialized_parallel( // call void [[T_OUTLINE_FUN_3:@.+]]( // CHECK: call {{.*}}void @__kmpc_end_serialized_parallel( // CHECK: define internal {{.*}}void [[T_OUTLINE_FUN_3]] // CHECK: call void @__kmpc_for_static_init_4( // CHECK: call {{.*}}void @{{.+}}fn3 // CHECK: call void @__kmpc_for_static_fini( // CHECK: ret void #endif // OMP45-NOT: !{!"llvm.loop.vectorize.enable", i1 false} // CHECK-DAG: !{!"llvm.loop.vectorize.enable", i1 true} // OMP45-NOT: !{!"llvm.loop.vectorize.enable", i1 false} // OMP50-DAG: !{!"llvm.loop.vectorize.enable", i1 false}