! Verifies that proper `omp.map.bounds` ops are emitted when an allocatable is ! implicitly mapped by a `do concurrent` loop. ! RUN: %flang_fc1 -emit-hlfir -fopenmp -fdo-concurrent-to-openmp=device %s -o - \ ! RUN: | FileCheck %s program main implicit none integer,parameter :: n = 1000000 real, allocatable, dimension(:) :: y integer :: i allocate(y(1:n)) do concurrent(i=1:n) y(i) = 42 end do deallocate(y) end program main ! CHECK: %[[Y_DECL:.*]]:2 = hlfir.declare %{{.*}} {fortran_attrs = #fir.var_attrs, uniq_name = "_QFEy"} ! CHECK: %[[Y_VAL:.*]] = fir.load %[[Y_DECL]]#0 ! CHECK: %[[Y_DIM0:.*]]:3 = fir.box_dims %[[Y_VAL]], %{{c0_.*}} ! CHECK: %[[Y_LB:.*]] = arith.constant 0 : index ! CHECK: %[[Y_UB:.*]] = arith.subi %[[Y_DIM0]]#1, %{{c1_.*}} : index ! CHECK: %[[Y_BOUNDS:.*]] = omp.map.bounds lower_bound(%[[Y_LB]] : index) upper_bound(%[[Y_UB]] : index) extent(%[[Y_DIM0]]#1 : index) ! CHECK: %[[MEM_MAP:.*]] = omp.map.info {{.*}} bounds(%[[Y_BOUNDS]]) ! CHECK: omp.map.info var_ptr(%[[Y_DECL]]#1 : {{.*}}) {{.*}} members(%[[MEM_MAP]] : {{.*}})