From: Francois-Xavier Coudert Date: Wed, 16 Mar 2005 19:32:08 +0000 (+0100) Subject: open.c (new_unit): set record length to max_offset rather than using a hard-coded... X-Git-Tag: misc/cutover-cvs2svn~4930 X-Git-Url: https://gcc.gnu.org/git/?a=commitdiff_plain;h=2786eb77b2d11d62515e4ed1aa36137addf6a172;p=gcc.git open.c (new_unit): set record length to max_offset rather than using a hard-coded limit (which was... * open.c (new_unit): set record length to max_offset rather than using a hard-coded limit (which was too low). * write_big_array.f90: New test. From-SVN: r96573 --- diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog index e3e9cec70b99..f6e234ec2a51 100644 --- a/gcc/testsuite/ChangeLog +++ b/gcc/testsuite/ChangeLog @@ -1,3 +1,8 @@ +2005-03-16 Francois-Xavier Coudert + + PR libfortran/20257 + * pr20257.f90: New test. + 2005-03-16 Francois-Xavier Coudert PR libfortran/20480 diff --git a/gcc/testsuite/gfortran.dg/pr20257.f90 b/gcc/testsuite/gfortran.dg/pr20257.f90 new file mode 100644 index 000000000000..3808829b486d --- /dev/null +++ b/gcc/testsuite/gfortran.dg/pr20257.f90 @@ -0,0 +1,9 @@ +! { dg-do run } + integer,parameter :: n = 10000 + real(8) array(10000) + + array(:) = 0 + open (10, status='scratch') + write (10,*) array + close (10) +end diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog index 43a2d9d39fb4..b18aa05fcb14 100644 --- a/libgfortran/ChangeLog +++ b/libgfortran/ChangeLog @@ -1,3 +1,9 @@ +2005-03-16 Francois-Xavier Coudert + + PR libfortran/20257 + * open.c (new_unit): set record length to max_offset rather than + using a hard-coded limit (which was too low). + 2005-03-16 Francois-Xavier Coudert PR libfortran/20480 diff --git a/libgfortran/io/open.c b/libgfortran/io/open.c index eaeb5a298c0c..3d0e5bebe7af 100644 --- a/libgfortran/io/open.c +++ b/libgfortran/io/open.c @@ -358,7 +358,7 @@ new_unit (unit_flags * flags) /* Unspecified recl ends up with a processor dependent value. */ - u->recl = (ioparm.recl_in != 0) ? ioparm.recl_in : DEFAULT_RECL; + u->recl = (ioparm.recl_in != 0) ? ioparm.recl_in : g.max_offset; u->last_record = 0; u->current_record = 0;