view gcc/testsuite/gfortran.dg/g77/980701-1.f @ 145:1830386684a0

gcc-9.2.0
author anatofuz
date Thu, 13 Feb 2020 11:34:05 +0900
parents 84e7813d76e9
children
line wrap: on
line source

c { dg-do run }
* g77 0.5.23 and previous had bugs involving too little space
* allocated for EQUIVALENCE and COMMON areas needing initial
* padding to meet alignment requirements of the system.

      call subr
      end

      subroutine subr
      implicit none

      real r1(5), r2(5), r3(5)
      real s1(2), s2(2), s3(2)
      double precision d1, d2, d3
      integer i1, i2, i3
      equivalence (d1, r1(2))
      equivalence (r1, s1(2))
      equivalence (d2, r2(2))
      equivalence (r2, s2(2))
      equivalence (d3, r3(2))
      equivalence (r3, s3(2))

      s1(1) = 1.
      r1(1) = 1.
      d1 = 10.
      r1(4) = 1.
      r1(5) = 1.
      i1 = 1
      s2(1) = 2.
      r2(1) = 2.
      d2 = 20.
      r2(4) = 2.
      r2(5) = 2.
      i2 = 2
      s3(1) = 3.
      r3(1) = 3.
      d3 = 30.
      r3(4) = 3.
      r3(5) = 3.
      i3 = 3

      call x (s1, r1, d1, i1, s2, r2, d2, i2, s3, r3, d3, i3)

      end

      subroutine x (s1, r1, d1, i1, s2, r2, d2, i2, s3, r3, d3, i3)
      implicit none

      real r1(5), r2(5), r3(5)
      real s1(2), s2(2), s3(2)
      double precision d1, d2, d3
      integer i1, i2, i3

      if (s1(1) .ne. 1.) STOP 1
      if (r1(1) .ne. 1.) STOP 2
      if (d1 .ne. 10.) STOP 3
      if (r1(4) .ne. 1.) STOP 4
      if (r1(5) .ne. 1.) STOP 5
      if (i1 .ne. 1) STOP 6
      if (s2(1) .ne. 2.) STOP 7
      if (r2(1) .ne. 2.) STOP 8
      if (d2 .ne. 20.) STOP 9
      if (r2(4) .ne. 2.) STOP 10
      if (r2(5) .ne. 2.) STOP 11
      if (i2 .ne. 2) STOP 12
      if (s3(1) .ne. 3.) STOP 13
      if (r3(1) .ne. 3.) STOP 14
      if (d3 .ne. 30.) STOP 15
      if (r3(4) .ne. 3.) STOP 16
      if (r3(5) .ne. 3.) STOP 17
      if (i3 .ne. 3) STOP 18

      end