29 lines
982 B
Fortran
29 lines
982 B
Fortran
! Test instantiation of module variables inside an internal subprogram
|
|
! where the use statement is inside the host program.
|
|
! RUN: bbc -emit-hlfir -o - %s | FileCheck %s
|
|
|
|
module module_used_by_host
|
|
implicit none
|
|
integer :: indexed_by_var(2)
|
|
integer :: ref_in_implied_do
|
|
integer :: ref_in_forall(2)
|
|
end module
|
|
|
|
subroutine host_procedure
|
|
use module_used_by_host
|
|
implicit none
|
|
contains
|
|
subroutine internal_procedure(i, mask)
|
|
integer :: i
|
|
logical :: mask(2)
|
|
indexed_by_var(i) = 0
|
|
print *, (/(ref_in_implied_do, integer::j=1,10)/)
|
|
forall (integer::k = 1:2)
|
|
ref_in_forall(k) = 0
|
|
end forall
|
|
end subroutine
|
|
end subroutine
|
|
! CHECK-LABEL: func.func @_QFhost_procedurePinternal_procedure(
|
|
! CHECK: fir.address_of(@_QMmodule_used_by_hostEindexed_by_var) : !fir.ref<!fir.array<2xi32>>
|
|
! CHECK: fir.address_of(@_QMmodule_used_by_hostEref_in_forall) : !fir.ref<!fir.array<2xi32>>
|
|
! CHECK: fir.address_of(@_QMmodule_used_by_hostEref_in_implied_do) : !fir.ref<i32>
|