summaryrefslogtreecommitdiff
path: root/gcc/testsuite/gfortran.dg/loc_1.f90
blob: ef0b1c102800728dde9da580658d7ac196ecf97a (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
! { dg-do run }

! This test is here to prevent a regression in gfc_conv_intrinsic_loc.
! Taking the loc of something in a common block was a special case
! that caused in internal compiler error in gcc/expr.c, in
! expand_expr_addr_expr_1().
program test
  common /targ/targ
  integer targ(10)
  call fn
end program test

subroutine fn
  common /targ/targ
  integer targ(10)
  call foo (loc (targ)) ! Line that caused ICE
end subroutine fn

subroutine foo (ii)
  common /targ/targ
  integer targ(10)
  integer ii
  targ(2) = ii
end subroutine foo