The following bit of code generates an internal compiler error on a Sun T5240. Using the *exact* same binary on a Sun Blade 2000, no internal error is generated.
kir...@t2:~$ gfortran secondtst.f gfortran: Internal error: Segmentation Fault (program f951) Please submit a full bug report. See <http://gcc.gnu.org/bugs.html> for instructions. Here's the bit of code. I did not write it, and do not even known Fortran well, so I've no idea if the code is good/bad, but the compiler should not generate an internal error. kir...@t2:~$ cat secondtst.f PROGRAM TEST4 * * -- LAPACK test routine (version 3.1) -- * Univ. of Tennessee, Univ. of California Berkeley and NAG Ltd.. * November 2006 * * .. Parameters .. INTEGER NMAX, ITS PARAMETER ( NMAX = 100, ITS = 5000 ) * .. * .. Local Scalars .. INTEGER I, J REAL ALPHA, AVG, T1, T2, TNOSEC * .. * .. Local Arrays .. REAL X( NMAX ), Y( NMAX ) * .. * .. External Functions .. REAL SECOND EXTERNAL SECOND * .. * .. Intrinsic Functions .. INTRINSIC REAL * .. * .. Executable Statements .. * * * Initialize X and Y * DO 10 I = 1, NMAX X( I ) = REAL( 1 ) / REAL( I ) Y( I ) = REAL( NMAX-I ) / REAL( NMAX ) 10 CONTINUE ALPHA = 0.315 * * Time 1,000,000 SAXPY operations * T1 = SECOND( ) DO 30 J = 1, ITS DO 20 I = 1, NMAX Y( I ) = Y( I ) + ALPHA*X( I ) 20 CONTINUE ALPHA = -ALPHA 30 CONTINUE T2 = SECOND( ) WRITE( 6, 9999 )T2 - T1 IF( T2-T1.GT.0.0 ) THEN WRITE( 6, 9998 )1.0 / ( T2-T1 ) ELSE WRITE( 6, 9994 ) END IF TNOSEC = T2 - T1 * * Time 1,000,000 SAXPY operations with SECOND in the outer loop * T1 = SECOND( ) DO 50 J = 1, ITS DO 40 I = 1, NMAX Y( I ) = Y( I ) + ALPHA*X( I ) 40 CONTINUE ALPHA = -ALPHA T2 = SECOND( ) 50 CONTINUE * * Compute the time used in milliseconds used by an average call * to SECOND. * WRITE( 6, 9997 )T2 - T1 AVG = ( ( T2-T1 ) - TNOSEC ) * 1000./REAL( ITS ) WRITE( 6, 9996 )AVG * * Compute the equivalent number of floating point operations used * by an average call to SECOND. * IF( TNOSEC.GT.0.0 ) $ WRITE( 6, 9995 )1000.*AVG / TNOSEC * 9999 FORMAT( ' Time for 1,000,000 SAXPY ops = ', G10.3, ' seconds' ) 9998 FORMAT( ' SAXPY performance rate = ', G10.3, ' mflops ' ) 9997 FORMAT( ' Including SECOND, time = ', G10.3, ' seconds' ) 9996 FORMAT( ' Average time for SECOND = ', G10.3, $ ' milliseconds' ) 9995 FORMAT( ' Equivalent floating point ops = ', G10.3, ' ops' ) 9994 FORMAT( ' *** Error: Time for operations was zero' ) CALL MYSUB(NMAX,X,Y) END SUBROUTINE MYSUB(N,X,Y) INTEGER N REAL X(N), Y(N) RETURN END -- Summary: nternal error: Segmentation Fault (program f951) on Solaris. Product: gcc Version: 4.3.2 Status: UNCONFIRMED Severity: major Priority: P3 Component: fortran AssignedTo: unassigned at gcc dot gnu dot org ReportedBy: david dot kirkby at onetel dot net http://gcc.gnu.org/bugzilla/show_bug.cgi?id=40358