! This test checks lowering of OpenMP DO SIMD composite constructs. ! RUN: bbc -fopenmp -emit-hlfir %s -o - | FileCheck %s ! RUN: %flang_fc1 -fopenmp -emit-hlfir %s -o - | FileCheck %s ! CHECK-LABEL: func.func @_QPdo_simd_aligned( subroutine do_simd_aligned(A) use iso_c_binding type(c_ptr) :: A ! CHECK: omp.wsloop ! CHECK-NOT: aligned({{.*}}) ! CHECK-SAME: { ! CHECK-NEXT: omp.simd ! CHECK-SAME: aligned({{.*}}) !$omp do simd aligned(A:256) do index_ = 1, 10 call c_test_call(A) end do !$omp end do simd end subroutine do_simd_aligned ! CHECK-LABEL: func.func @_QPdo_simd_safelen( subroutine do_simd_safelen() ! CHECK: omp.wsloop ! CHECK-NOT: safelen({{.*}}) ! CHECK-SAME: { ! CHECK-NEXT: omp.simd ! CHECK-SAME: safelen({{.*}}) !$omp do simd safelen(4) do index_ = 1, 10 end do !$omp end do simd end subroutine do_simd_safelen ! CHECK-LABEL: func.func @_QPdo_simd_simdlen( subroutine do_simd_simdlen() ! CHECK: omp.wsloop ! CHECK-NOT: simdlen({{.*}}) ! CHECK-SAME: { ! CHECK-NEXT: omp.simd ! CHECK-SAME: simdlen({{.*}}) !$omp do simd simdlen(4) do index_ = 1, 10 end do !$omp end do simd end subroutine do_simd_simdlen ! CHECK-LABEL: func.func @_QPdo_simd_reduction( subroutine do_simd_reduction() integer :: sum sum = 0 ! CHECK: omp.wsloop ! CHECK-SAME: reduction(@[[RED_SYM:.*]] %{{.*}} -> %[[RED_OUTER:.*]] : !fir.ref) ! CHECK-NEXT: omp.simd ! CHECK-SAME: reduction(@[[RED_SYM]] %[[RED_OUTER]] -> %[[RED_INNER:.*]] : !fir.ref) ! CHECK-NEXT: omp.loop_nest ! CHECK: %[[RED_DECL:.*]]:2 = hlfir.declare %[[RED_INNER]] ! CHECK: %[[RED:.*]] = fir.load %[[RED_DECL]]#0 : !fir.ref ! CHECK: %[[RESULT:.*]] = arith.addi %[[RED]], %{{.*}} : i32 ! CHECK: hlfir.assign %[[RESULT]] to %[[RED_DECL]]#0 : i32, !fir.ref ! CHECK-NEXT: omp.yield !$omp do simd reduction(+:sum) do index_ = 1, 10 sum = sum + 1 end do !$omp end do simd end subroutine do_simd_reduction