aboutsummaryrefslogtreecommitdiff
path: root/libgfortran
diff options
context:
space:
mode:
authorThomas Koenig <Thomas.Koenig@online.de>2005-09-04 20:36:52 +0000
committerThomas Koenig <Thomas.Koenig@online.de>2005-09-04 20:36:52 +0000
commitfd0ab364d369489381ebd7df34958b4faa3dacc0 (patch)
tree980246c419799542558dca9b884df6c9e3881e82 /libgfortran
parent0ca80943eaa7f1000387ca7b862ee3191e518a96 (diff)
2005-09-04 Thomas Koenig <Thomas.Koenig@online.de>
PR libfortran/23321 * io/transfer.c(data_transfer_init): Check for a too-large record number. Return if sseek failed. 2005-09-04 Thomas Koenig <Thomas.Koenig@online.de> PR libfortran/23321 * gfortran.dg/direct_io_4.f90: New test case. git-svn-id: https://gcc.gnu.org/svn/gcc/trunk@103835 138bc75d-0d04-0410-961f-82ee72b054a4
Diffstat (limited to 'libgfortran')
-rw-r--r--libgfortran/ChangeLog6
-rw-r--r--libgfortran/io/transfer.c15
2 files changed, 20 insertions, 1 deletions
diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog
index 02df5fd0858..20239792ea4 100644
--- a/libgfortran/ChangeLog
+++ b/libgfortran/ChangeLog
@@ -1,3 +1,9 @@
+2005-09-04 Thomas Koenig <Thomas.Koenig@online.de>
+
+ PR libfortran/23321
+ * io/transfer.c(data_transfer_init): Check for a too-large
+ record number. Return if sseek failed.
+
2005-09-03 Jakub Jelinek <jakub@redhat.com>
* io/read.c (read_x): Take int argument instead of fnode * and
diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c
index 7449f02d3dd..59eb22d3dec 100644
--- a/libgfortran/io/transfer.c
+++ b/libgfortran/io/transfer.c
@@ -1160,10 +1160,23 @@ data_transfer_init (int read_flag)
if (g.mode == READING && current_unit->mode == WRITING)
flush(current_unit->s);
+ /* Check whether the record exists to be read. Only
+ a partial record needs to exist. */
+
+ if (g.mode == READING && (ioparm.rec -1)
+ * current_unit->recl >= file_length (current_unit->s))
+ {
+ generate_error (ERROR_BAD_OPTION, "Non-existing record number");
+ return;
+ }
+
/* Position the file. */
if (sseek (current_unit->s,
(ioparm.rec - 1) * current_unit->recl) == FAILURE)
- generate_error (ERROR_OS, NULL);
+ {
+ generate_error (ERROR_OS, NULL);
+ return;
+ }
}
/* Overwriting an existing sequential file ?