Files
clang-p2996/flang/test/Semantics/offsets01.f90
Peter Klausler ca47447952 [flang] Don't reference non-invariant symbols in shape expressions
When an array's shape involves references to symbols that are not
invariant in a scope -- the classic example being a dummy array
with an explicit shape involving other dummy arguments -- the
compiler was creating shape expressions that referenced those
symbols.  This might be valid if those symbols are somehow
captured and copied at each entry point to a subprogram, and
the copies referenced in the shapes instead, but that's not
the case.

This patch introduces a new expression predicate IsScopeInvariantExpr(),
which defines a class of expressions that contains constant expressions
(in the sense that the standard uses that term) as well as references
to items that may be safely accessed in a context-free way throughout
their scopes.   This includes dummy arguments that are INTENT(IN)
and not VALUE, descriptor inquiries into descriptors that cannot
change, and bare LEN type parameters within the definitions of
derived types.  The new predicate is then used in shape analysis
to winnow out results that would have otherwise been contextual.

Differential Revision: https://reviews.llvm.org/D113309
2021-11-08 12:48:47 -08:00

55 lines
1.7 KiB
Fortran

!RUN: %flang_fc1 -fdebug-dump-symbols %s | FileCheck %s
! Size and alignment of intrinsic types
subroutine s1
integer(1) :: a_i1 !CHECK: a_i1 size=1 offset=0:
integer(8) :: b_i8 !CHECK: b_i8 size=8 offset=8:
real(2) :: c_r2 !CHECK: c_r2 size=2 offset=16:
real(2) :: d_r2 !CHECK: d_r2 size=2 offset=18:
real(8) :: e_r8 !CHECK: e_r8 size=8 offset=24:
real(4) :: f_r4 !CHECK: f_r4 size=4 offset=32:
complex(8) :: g_c8 !CHECK: g_c8 size=16 offset=40:
complex(4) :: h_c4 !CHECK: h_c4 size=8 offset=56:
logical :: i_l4 !CHECK: i_l4 size=4 offset=64:
end
! Character
subroutine s2
character(10) :: c1 !CHECK: c1 size=10 offset=0:
character(1) :: c2 !CHECK: c2 size=1 offset=10:
character(10,kind=2) :: c3 !CHECK: c3 size=20 offset=12:
end
! Descriptors
subroutine s3(n)
integer :: n
real, pointer :: x !CHECK: x, POINTER size=24 offset=8:
character(n) :: y !CHECK: y size=24 offset=32:
end
! Descriptors for arrays
subroutine s4
integer, allocatable :: z0 !CHECK: z0, ALLOCATABLE size=24 offset=
integer, allocatable :: z1(:) !CHECK: z1, ALLOCATABLE size=48 offset=
integer, allocatable :: z2(:,:) !CHECK: z2, ALLOCATABLE size=72 offset=
integer, allocatable :: z3(:,:,:) !CHECK: z3, ALLOCATABLE size=96 offset=
end
! Descriptors with length parameters
subroutine s5(n)
integer :: n
type :: t1(n)
integer, len :: n
real :: a(n)
end type
type :: t2(n1, n2)
integer, len :: n1
integer, len :: n2
real :: b(n1, n2)
end type
type(t1(n)) :: x1 !CHECK: x1 size=40 offset=
type(t2(n,n)) :: x2 !CHECK: x2 size=48 offset=
!CHECK: a size=48 offset=0:
!CHECK: b size=72 offset=0:
end