diff options
Diffstat (limited to 'test/OpenMP/for_codegen.cpp')
| -rw-r--r-- | test/OpenMP/for_codegen.cpp | 27 | 
1 files changed, 20 insertions, 7 deletions
diff --git a/test/OpenMP/for_codegen.cpp b/test/OpenMP/for_codegen.cpp index 466139cfb2fcb..1f5dd7ddd0dd7 100644 --- a/test/OpenMP/for_codegen.cpp +++ b/test/OpenMP/for_codegen.cpp @@ -11,15 +11,26 @@  // CHECK: [[IDENT_T_TY:%.+]] = type { i32, i32, i32, i32, i8* }  // CHECK-DAG: [[IMPLICIT_BARRIER_LOC:@.+]] = private unnamed_addr constant %{{.+}} { i32 0, i32 66, i32 0, i32 0, i8* +// CHECK-DAG: [[LOOP_LOC:@.+]] = private unnamed_addr constant %{{.+}} { i32 0, i32 514, i32 0, i32 0, i8*  // CHECK-DAG: [[I:@.+]] = global i8 1,  // CHECK-DAG: [[J:@.+]] = global i8 2,  // CHECK-DAG: [[K:@.+]] = global i8 3, +// CHECK-LABEL: loop_with_counter_collapse +void loop_with_counter_collapse() { +  // CHECK: call void @__kmpc_for_static_init_8(%ident_t* @ +  // CHECK: call void @__kmpc_for_static_fini(%ident_t* @ +  #pragma omp for collapse(2) +  for (int i = 0; i < 4; i++) { +    for (int j = i; j < 4; j++) { +    } +  } +}  // CHECK-LABEL: define {{.*void}} @{{.*}}without_schedule_clause{{.*}}(float* {{.+}}, float* {{.+}}, float* {{.+}}, float* {{.+}})  void without_schedule_clause(float *a, float *b, float *c, float *d) {  // CHECK: [[GTID:%.+]] = call i32 @__kmpc_global_thread_num([[IDENT_T_TY]]* [[DEFAULT_LOC:[@%].+]])    #pragma omp for nowait -// CHECK: call void @__kmpc_for_static_init_4([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]], i32 34, i32* [[IS_LAST:%[^,]+]], i32* [[OMP_LB:%[^,]+]], i32* [[OMP_UB:%[^,]+]], i32* [[OMP_ST:%[^,]+]], i32 1, i32 1) +// CHECK: call void @__kmpc_for_static_init_4([[IDENT_T_TY]]* [[LOOP_LOC]], i32 [[GTID]], i32 34, i32* [[IS_LAST:%[^,]+]], i32* [[OMP_LB:%[^,]+]], i32* [[OMP_UB:%[^,]+]], i32* [[OMP_ST:%[^,]+]], i32 1, i32 1)  // UB = min(UB, GlobalUB)  // CHECK-NEXT: [[UB:%.+]] = load i32, i32* [[OMP_UB]]  // CHECK-NEXT: [[UBCMP:%.+]] = icmp sgt i32 [[UB]], 4571423 @@ -51,7 +62,7 @@ void without_schedule_clause(float *a, float *b, float *c, float *d) {  // CHECK-NEXT: br label %{{.+}}    }  // CHECK: [[LOOP1_END]] -// CHECK: call void @__kmpc_for_static_fini([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]]) +// CHECK: call void @__kmpc_for_static_fini([[IDENT_T_TY]]* [[LOOP_LOC]], i32 [[GTID]])  // CHECK-NOT: __kmpc_barrier  // CHECK: ret void  } @@ -60,7 +71,7 @@ void without_schedule_clause(float *a, float *b, float *c, float *d) {  void static_not_chunked(float *a, float *b, float *c, float *d) {  // CHECK: [[GTID:%.+]] = call i32 @__kmpc_global_thread_num([[IDENT_T_TY]]* [[DEFAULT_LOC:[@%].+]])    #pragma omp for schedule(static) -// CHECK: call void @__kmpc_for_static_init_4([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]], i32 34, i32* [[IS_LAST:%[^,]+]], i32* [[OMP_LB:%[^,]+]], i32* [[OMP_UB:%[^,]+]], i32* [[OMP_ST:%[^,]+]], i32 1, i32 1) +// CHECK: call void @__kmpc_for_static_init_4([[IDENT_T_TY]]* [[LOOP_LOC]], i32 [[GTID]], i32 34, i32* [[IS_LAST:%[^,]+]], i32* [[OMP_LB:%[^,]+]], i32* [[OMP_UB:%[^,]+]], i32* [[OMP_ST:%[^,]+]], i32 1, i32 1)  // UB = min(UB, GlobalUB)  // CHECK-NEXT: [[UB:%.+]] = load i32, i32* [[OMP_UB]]  // CHECK-NEXT: [[UBCMP:%.+]] = icmp sgt i32 [[UB]], 4571423 @@ -92,7 +103,7 @@ void static_not_chunked(float *a, float *b, float *c, float *d) {  // CHECK-NEXT: br label %{{.+}}    }  // CHECK: [[LOOP1_END]] -// CHECK: call void @__kmpc_for_static_fini([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]]) +// CHECK: call void @__kmpc_for_static_fini([[IDENT_T_TY]]* [[LOOP_LOC]], i32 [[GTID]])  // CHECK: call {{.+}} @__kmpc_barrier([[IDENT_T_TY]]* [[IMPLICIT_BARRIER_LOC]], i32 [[GTID]])  // CHECK: ret void  } @@ -101,7 +112,7 @@ void static_not_chunked(float *a, float *b, float *c, float *d) {  void static_chunked(float *a, float *b, float *c, float *d) {  // CHECK: [[GTID:%.+]] = call i32 @__kmpc_global_thread_num([[IDENT_T_TY]]* [[DEFAULT_LOC:[@%].+]])    #pragma omp for schedule(monotonic: static, 5) -// CHECK: call void @__kmpc_for_static_init_4u([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]], i32 536870945, i32* [[IS_LAST:%[^,]+]], i32* [[OMP_LB:%[^,]+]], i32* [[OMP_UB:%[^,]+]], i32* [[OMP_ST:%[^,]+]], i32 1, i32 5) +// CHECK: call void @__kmpc_for_static_init_4u([[IDENT_T_TY]]* [[LOOP_LOC]], i32 [[GTID]], i32 536870945, i32* [[IS_LAST:%[^,]+]], i32* [[OMP_LB:%[^,]+]], i32* [[OMP_UB:%[^,]+]], i32* [[OMP_ST:%[^,]+]], i32 1, i32 5)  // UB = min(UB, GlobalUB)  // CHECK: [[UB:%.+]] = load i32, i32* [[OMP_UB]]  // CHECK-NEXT: [[UBCMP:%.+]] = icmp ugt i32 [[UB]], 16908288 @@ -152,7 +163,7 @@ void static_chunked(float *a, float *b, float *c, float *d) {  // CHECK-NEXT: store i32 [[ADD_UB]], i32* [[OMP_UB]]  // CHECK: [[O_LOOP1_END]] -// CHECK: call void @__kmpc_for_static_fini([[IDENT_T_TY]]* [[DEFAULT_LOC]], i32 [[GTID]]) +// CHECK: call void @__kmpc_for_static_fini([[IDENT_T_TY]]* [[LOOP_LOC]], i32 [[GTID]])  // CHECK: call {{.+}} @__kmpc_barrier([[IDENT_T_TY]]* [[IMPLICIT_BARRIER_LOC]], i32 [[GTID]])  // CHECK: ret void  } @@ -329,8 +340,8 @@ void runtime(float *a, float *b, float *c, float *d) {  // CHECK-LABEL: test_precond  void test_precond() {    // CHECK: [[A_ADDR:%.+]] = alloca i8, -  // CHECK: [[CAP:%.+]] = alloca i8,    // CHECK: [[I_ADDR:%.+]] = alloca i8, +  // CHECK: [[CAP:%.+]] = alloca i8,    char a = 0;    // CHECK: store i8 0,    // CHECK: store i32 @@ -375,7 +386,9 @@ void parallel_for(float *a) {  char i = 1, j = 2, k = 3;  // CHECK-LABEL: for_with_global_lcv  void for_with_global_lcv() { +// CHECK: alloca i8,  // CHECK: [[I_ADDR:%.+]] = alloca i8, +// CHECK: alloca i8,  // CHECK: [[J_ADDR:%.+]] = alloca i8,  // CHECK: call void @__kmpc_for_static_init_4(  | 
