blob: 1659c7bdf6d3e208d6b4e377c0b6c126ccaaf29d [file] [log] [blame]
// Tests mapping `local` locality specifier to `private` clauses for non-empty
// `init` and `dealloc` regions.
// RUN: fir-opt --omp-do-concurrent-conversion="map-to=host" %s | FileCheck %s
func.func @my_allocator(%arg0: !fir.ref<!fir.box<!fir.array<10xf32>>>, %arg1: !fir.ref<!fir.box<!fir.array<10xf32>>>) {
return
}
func.func @my_deallocator(%arg0: !fir.ref<!fir.box<!fir.array<10xf32>>>) {
return
}
fir.local {type = local} @_QFlocal_assocEaa_private_box_10xf32 : !fir.box<!fir.array<10xf32>> init {
^bb0(%arg0: !fir.ref<!fir.box<!fir.array<10xf32>>>, %arg1: !fir.ref<!fir.box<!fir.array<10xf32>>>):
fir.call @my_allocator(%arg0, %arg1) : (!fir.ref<!fir.box<!fir.array<10xf32>>>, !fir.ref<!fir.box<!fir.array<10xf32>>>) -> ()
fir.yield(%arg1 : !fir.ref<!fir.box<!fir.array<10xf32>>>)
} dealloc {
^bb0(%arg0: !fir.ref<!fir.box<!fir.array<10xf32>>>):
fir.call @my_deallocator(%arg0) : (!fir.ref<!fir.box<!fir.array<10xf32>>>) -> ()
fir.yield
}
func.func @_QPlocal_assoc() {
%0 = fir.alloca !fir.box<!fir.array<10xf32>>
%c1 = arith.constant 1 : index
fir.do_concurrent {
%9 = fir.alloca i32 {bindc_name = "i"}
%10:2 = hlfir.declare %9 {uniq_name = "_QFlocal_assocEi"} : (!fir.ref<i32>) -> (!fir.ref<i32>, !fir.ref<i32>)
fir.do_concurrent.loop (%arg0) = (%c1) to (%c1) step (%c1) local(@_QFlocal_assocEaa_private_box_10xf32 %0 -> %arg1 : !fir.ref<!fir.box<!fir.array<10xf32>>>) {
%11 = fir.convert %arg0 : (index) -> i32
fir.store %11 to %10#0 : !fir.ref<i32>
}
}
return
}
// CHECK: omp.private {type = private} @[[PRIVATIZER:.*]] : !fir.box<!fir.array<10xf32>> init {
// CHECK-NEXT: ^bb0(%[[ORIG_ARG:.*]]: !{{.*}}, %[[PRIV_ARG:.*]]: !{{.*}}):
// CHECK-NEXT: fir.call @my_allocator(%[[ORIG_ARG]], %[[PRIV_ARG]]) : ({{.*}}) -> ()
// CHECK-NEXT: omp.yield(%[[PRIV_ARG]] : {{.*}})
// CHECK-NEXT: } dealloc {
// CHECK-NEXT: ^bb0(%[[PRIV_ARG:.*]]: !{{.*}}):
// CHECK-NEXT: fir.call @my_deallocator(%[[PRIV_ARG]]) : ({{.*}}) -> ()
// CHECK-NEXT: omp.yield
// CHECK-NEXT: }
// CHECK: %[[LOCAL_ALLOC:.*]] = fir.alloca !fir.box<!fir.array<10xf32>>
// CHECK: omp.wsloop private(@[[PRIVATIZER]] %[[LOCAL_ALLOC]] -> %{{.*}} : !{{.*}})