|
| 1 | +! Test delayed privatization for arrays. |
| 2 | + |
| 3 | +! RUN: split-file %s %t |
| 4 | + |
| 5 | +! RUN: %flang_fc1 -emit-hlfir -fopenmp -mmlir --openmp-enable-delayed-privatization \ |
| 6 | +! RUN: -o - %t/one_dim_array.f90 2>&1 | FileCheck %s --check-prefix=ONE_DIM |
| 7 | +! RUN: bbc -emit-hlfir -fopenmp --openmp-enable-delayed-privatization -o - \ |
| 8 | +! RUN: %t/one_dim_array.f90 2>&1 | FileCheck %s --check-prefix=ONE_DIM |
| 9 | + |
| 10 | +! RUN: %flang_fc1 -emit-hlfir -fopenmp -mmlir --openmp-enable-delayed-privatization \ |
| 11 | +! RUN: -o - %t/two_dim_array.f90 2>&1 | FileCheck %s --check-prefix=TWO_DIM |
| 12 | +! RUN: bbc -emit-hlfir -fopenmp --openmp-enable-delayed-privatization -o - %t/two_dim_array.f90 2>&1 |\ |
| 13 | +! RUN: FileCheck %s --check-prefix=TWO_DIM |
| 14 | + |
| 15 | +!--- one_dim_array.f90 |
| 16 | +subroutine delayed_privatization_private(var1, l1, u1) |
| 17 | + implicit none |
| 18 | + integer(8):: l1, u1 |
| 19 | + integer, dimension(l1:u1) :: var1 |
| 20 | + |
| 21 | +!$omp parallel firstprivate(var1) |
| 22 | + var1(l1 + 1) = 10 |
| 23 | +!$omp end parallel |
| 24 | +end subroutine |
| 25 | + |
| 26 | +! ONE_DIM-LABEL: omp.private {type = firstprivate} |
| 27 | +! ONE_DIM-SAME: @[[PRIVATIZER_SYM:.*]] : [[TYPE:!fir.box<!fir.array<\?xi32>>]] alloc { |
| 28 | + |
| 29 | +! ONE_DIM-NEXT: ^bb0(%[[PRIV_ARG:.*]]: [[TYPE]]): |
| 30 | + |
| 31 | +! ONE_DIM-NEXT: %[[C0:.*]] = arith.constant 0 : index |
| 32 | +! ONE_DIM-NEXT: %[[DIMS:.*]]:3 = fir.box_dims %[[PRIV_ARG]], %[[C0]] : ([[TYPE]], index) -> (index, index, index) |
| 33 | +! ONE_DIM-NEXT: %[[PRIV_ALLOCA:.*]] = fir.alloca !fir.array<{{\?}}xi32>, %[[DIMS]]#1 {bindc_name = "var1", pinned, uniq_name = "_QFdelayed_privatization_privateEvar1"} |
| 34 | +! ONE_DIM-NEXT: %[[SHAPE_SHIFT:.*]] = fir.shape_shift %[[DIMS]]#0, %[[DIMS]]#1 : (index, index) -> !fir.shapeshift<1> |
| 35 | +! ONE_DIM-NEXT: %[[PRIV_DECL:.*]]:2 = hlfir.declare %[[PRIV_ALLOCA]](%[[SHAPE_SHIFT]]) {uniq_name = "_QFdelayed_privatization_privateEvar1"} |
| 36 | +! ONE_DIM-NEXT: omp.yield(%[[PRIV_DECL]]#0 : [[TYPE]]) |
| 37 | + |
| 38 | +! ONE_DIM-NEXT: } copy { |
| 39 | +! ONE_DIM-NEXT: ^bb0(%[[PRIV_ORIG_ARG:.*]]: [[TYPE]], %[[PRIV_PRIV_ARG:.*]]: [[TYPE]]): |
| 40 | +! ONE_DIM-NEXT: hlfir.assign %[[PRIV_ORIG_ARG]] to %[[PRIV_PRIV_ARG]] temporary_lhs |
| 41 | +! ONE_DIM-NEXT: omp.yield(%[[PRIV_PRIV_ARG]] : [[TYPE]]) |
| 42 | +! ONE_DIM-NEXT: } |
| 43 | + |
| 44 | +!--- two_dim_array.f90 |
| 45 | +subroutine delayed_privatization_private(var1, l1, u1, l2, u2) |
| 46 | + implicit none |
| 47 | + integer(8):: l1, u1, l2, u2 |
| 48 | + integer, dimension(l1:u1, l2:u2) :: var1 |
| 49 | + |
| 50 | +!$omp parallel firstprivate(var1) |
| 51 | + var1(l1 + 1, u2) = 10 |
| 52 | +!$omp end parallel |
| 53 | +end subroutine |
| 54 | + |
| 55 | +! TWO_DIM-LABEL: omp.private {type = firstprivate} |
| 56 | +! TWO_DIM-SAME: @[[PRIVATIZER_SYM:.*]] : [[TYPE:!fir.box<!fir.array<\?x\?xi32>>]] alloc { |
| 57 | + |
| 58 | +! TWO_DIM-NEXT: ^bb0(%[[PRIV_ARG:.*]]: [[TYPE]]): |
| 59 | +! TWO_DIM-NEXT: %[[C0:.*]] = arith.constant 0 : index |
| 60 | +! TWO_DIM-NEXT: %[[DIMS0:.*]]:3 = fir.box_dims %[[PRIV_ARG]], %[[C0]] : ([[TYPE]], index) -> (index, index, index) |
| 61 | + |
| 62 | +! TWO_DIM-NEXT: %[[C1:.*]] = arith.constant 1 : index |
| 63 | +! TWO_DIM-NEXT: %[[DIMS1:.*]]:3 = fir.box_dims %[[PRIV_ARG]], %[[C1]] : ([[TYPE]], index) -> (index, index, index) |
| 64 | + |
| 65 | +! TWO_DIM-NEXT: %[[PRIV_ALLOCA:.*]] = fir.alloca !fir.array<{{\?}}x{{\?}}xi32>, %[[DIMS0]]#1, %[[DIMS1]]#1 {bindc_name = "var1", pinned, uniq_name = "_QFdelayed_privatization_privateEvar1"} |
| 66 | +! TWO_DIM-NEXT: %[[SHAPE_SHIFT:.*]] = fir.shape_shift %[[DIMS0]]#0, %[[DIMS0]]#1, %[[DIMS1]]#0, %[[DIMS1]]#1 : (index, index, index, index) -> !fir.shapeshift<2> |
| 67 | + |
| 68 | +! TWO_DIM-NEXT: %[[PRIV_DECL:.*]]:2 = hlfir.declare %[[PRIV_ALLOCA]](%[[SHAPE_SHIFT]]) {uniq_name = "_QFdelayed_privatization_privateEvar1"} |
| 69 | +! TWO_DIM-NEXT: omp.yield(%[[PRIV_DECL]]#0 : [[TYPE]]) |
| 70 | + |
| 71 | +! TWO_DIM-NEXT: } copy { |
| 72 | +! TWO_DIM-NEXT: ^bb0(%[[PRIV_ORIG_ARG:.*]]: [[TYPE]], %[[PRIV_PRIV_ARG:.*]]: [[TYPE]]): |
| 73 | +! TWO_DIM-NEXT: hlfir.assign %[[PRIV_ORIG_ARG]] to %[[PRIV_PRIV_ARG]] temporary_lhs |
| 74 | +! TWO_DIM-NEXT: omp.yield(%[[PRIV_PRIV_ARG]] : [[TYPE]]) |
| 75 | +! TWO_DIM-NEXT: } |
0 commit comments