! This test checks lowering of OpenACC device_type clause on directive where its
! position and the clauses that follow have special semantic
! RUN: bbc -fopenacc -emit-hlfir %s -o - | FileCheck %s
subroutine sub1()
!$acc parallel num_workers(16)
!$acc end parallel
! CHECK: acc.parallel num_workers(%c16{{.*}} : i32) {
!$acc parallel num_workers(1) device_type(nvidia) num_workers(16)
!$acc end parallel
! CHECK: acc.parallel num_workers(%c1{{.*}} : i32, %c16{{.*}} : i32 [#acc.device_type<nvidia>])
!$acc parallel device_type(*) num_workers(1) device_type(nvidia) num_workers(16)
!$acc end parallel
! CHECK: acc.parallel num_workers(%c1{{.*}} : i32 [#acc.device_type<star>], %c16{{.*}} : i32 [#acc.device_type<nvidia>])
!$acc parallel vector_length(1)
!$acc end parallel
! CHECK: acc.parallel vector_length(%c1{{.*}} : i32)
!$acc parallel device_type(multicore) vector_length(1)
!$acc end parallel
! CHECK: acc.parallel vector_length(%c1{{.*}} : i32 [#acc.device_type<multicore>])
!$acc parallel num_gangs(2) device_type(nvidia) num_gangs(4)
!$acc end parallel
! CHECK: acc.parallel num_gangs({%c2{{.*}} : i32}, {%c4{{.*}} : i32} [#acc.device_type<nvidia>])
!$acc parallel num_gangs(2) device_type(nvidia) num_gangs(1, 1, 1)
!$acc end parallel
! CHECK: acc.parallel num_gangs({%c2{{.*}} : i32}, {%c1{{.*}} : i32, %c1{{.*}} : i32, %c1{{.*}} : i32} [#acc.device_type<nvidia>])
!$acc parallel device_type(nvidia, default) num_gangs(1, 1, 1)
!$acc end parallel
! CHECK: acc.parallel num_gangs({%c1{{.*}} : i32, %c1{{.*}} : i32, %c1{{.*}} : i32} [#acc.device_type<nvidia>], {%c1{{.*}} : i32, %c1{{.*}} : i32, %c1{{.*}} : i32} [#acc.device_type<default>])
end subroutine