1
1
! Test delayed privatization for the `CHARACTER` type.
2
2
3
+ ! RUN: split-file %s %t
4
+
5
+ ! RUN: %flang_fc1 -emit-hlfir -fopenmp -mmlir --openmp-enable-delayed-privatization \
6
+ ! RUN: -o - %t/dyn_len.f90 2>&1 | FileCheck %s --check-prefix=DYN_LEN
7
+ ! RUN: bbc -emit-hlfir -fopenmp --openmp-enable-delayed-privatization -o - %t/dyn_len.f90 2>&1 \
8
+ ! RUN: | FileCheck %s --check-prefix=DYN_LEN
9
+
3
10
! RUN: %flang_fc1 -emit-hlfir -fopenmp -mmlir --openmp-enable-delayed-privatization \
4
- ! RUN: -o - %s 2>&1 | FileCheck %s
5
- ! RUN: bbc -emit-hlfir -fopenmp --openmp-enable-delayed-privatization -o - %s 2>&1 \
6
- ! RUN: | FileCheck %s
11
+ ! RUN: -o - %t/static_len.f90 2>&1 | FileCheck %s --check-prefix=STATIC_LEN
12
+ ! RUN: bbc -emit-hlfir -fopenmp --openmp-enable-delayed-privatization -o - %t/static_len.f90 2>&1 \
13
+ ! RUN: | FileCheck %s --check-prefix=STATIC_LEN
7
14
15
+ !- -- dyn_len.f90
8
16
subroutine delayed_privatization_character (var1 , l )
9
17
implicit none
10
18
integer (8 ):: l
@@ -15,19 +23,37 @@ subroutine delayed_privatization_character(var1, l)
15
23
! $omp end parallel
16
24
end subroutine
17
25
18
- ! CHECK-LABEL: omp.private {type = firstprivate}
19
- ! CHECK-SAME: @[[PRIVATIZER_SYM:.*]] : [[TYPE:!fir.boxchar<1>]] alloc {
26
+ ! DYN_LEN-LABEL: omp.private {type = firstprivate}
27
+ ! DYN_LEN-SAME: @[[PRIVATIZER_SYM:.*]] : [[TYPE:!fir.boxchar<1>]] alloc {
28
+
29
+ ! DYN_LEN-NEXT: ^bb0(%[[PRIV_ARG:.*]]: [[TYPE]]):
30
+ ! DYN_LEN-NEXT: %[[UNBOX:.*]]:2 = fir.unboxchar %[[PRIV_ARG]]
31
+ ! DYN_LEN: %[[PRIV_ALLOC:.*]] = fir.alloca !fir.char<1,?>(%[[UNBOX]]#1 : index)
32
+ ! DYN_LEN-NEXT: %[[PRIV_DECL:.*]]:2 = hlfir.declare %[[PRIV_ALLOC]] typeparams %[[UNBOX]]#1
33
+ ! DYN_LEN-NEXT: omp.yield(%[[PRIV_DECL]]#0 : !fir.boxchar<1>)
34
+
35
+ ! DYN_LEN-NEXT: } copy {
36
+ ! DYN_LEN-NEXT: ^bb0(%[[PRIV_ORIG_ARG:.*]]: [[TYPE]], %[[PRIV_PRIV_ARG:.*]]: [[TYPE]]):
37
+
38
+ ! DYN_LEN-NEXT: hlfir.assign %[[PRIV_ORIG_ARG]] to %[[PRIV_PRIV_ARG]]
20
39
21
- ! CHECK-NEXT: ^bb0(%[[PRIV_ARG:.*]]: [[TYPE]]):
22
- ! CHECK-NEXT: %[[UNBOX:.*]]:2 = fir.unboxchar %[[PRIV_ARG]]
23
- ! CHECK: %[[PRIV_ALLOC:.*]] = fir.alloca !fir.char<1,?>(%[[UNBOX]]#1 : index)
24
- ! CHECK-NEXT: %[[PRIV_DECL:.*]]:2 = hlfir.declare %[[PRIV_ALLOC]] typeparams %[[UNBOX]]#1
25
- ! CHECK-NEXT: omp.yield(%[[PRIV_DECL]]#0 : !fir.boxchar<1>)
40
+ ! DYN_LEN-NEXT: omp.yield(%[[PRIV_PRIV_ARG]] : !fir.boxchar<1>)
41
+ ! DYN_LEN-NEXT: }
26
42
27
- ! CHECK-NEXT: } copy {
28
- ! CHECK-NEXT: ^bb0(%[[PRIV_ORIG_ARG:.*]]: [[TYPE]], %[[PRIV_PRIV_ARG:.*]]: [[TYPE]]):
43
+ !- -- static_len.f90
44
+ subroutine delayed_privatization_character_static_len (var1 )
45
+ implicit none
46
+ character (len = 10 ) :: var1
47
+
48
+ ! $omp parallel private(var1)
49
+ var1 = " test"
50
+ ! $omp end parallel
51
+ end subroutine
29
52
30
- ! CHECK-NEXT: hlfir.assign %[[PRIV_ORIG_ARG]] to %[[PRIV_PRIV_ARG]]
53
+ ! STATIC_LEN-LABEL: omp.private {type = private}
54
+ ! STATIC_LEN-SAME: @[[PRIVATIZER_SYM:.*]] : [[TYPE:!fir.ref<!fir.char<1,10>>]] alloc {
31
55
32
- ! CHECK-NEXT: omp.yield(%[[PRIV_PRIV_ARG]] : !fir.boxchar<1>)
33
- ! CHECK-NEXT: }
56
+ ! STATIC_LEN-NEXT: ^bb0(%[[PRIV_ARG:.*]]: [[TYPE]]):
57
+ ! STATIC_LEN-NEXT: %[[C10:.*]] = arith.constant 10 : index
58
+ ! STATIC_LEN-NEXT: %[[PRIV_ALLOC:.*]] = fir.alloca !fir.char<1,10>
59
+ ! STATIC_LEN-NEXT: %[[PRIV_DECL:.*]]:2 = hlfir.declare %[[PRIV_ALLOC]] typeparams %[[C10]]
0 commit comments