diff --git a/libgfortran/ChangeLog b/libgfortran/ChangeLog
index 3ee00936037ede4839c332c5cd5388a846d88079..8a816fc9e5adeda2397f61162dcd84f1b7f241f7 100644
--- a/libgfortran/ChangeLog
+++ b/libgfortran/ChangeLog
@@ -1,3 +1,11 @@
+2009-11-18  Jerry DeLisle  <jvdelisle@gcc.gnu.org>
+
+	PR libgfortran/42090
+	* io/transfer.c (skip_record): Set bytes_left_subrecord to zero after
+	skipping the remaining bytes in the record.
+	(next_record_r): Call skip_record with the number of bytes_left to be
+	skipped.
+
 2009-11-02  Janne Blomqvist  <jb@gcc.gnu.org>
 
 	* Makefile.am (gfor_io_headers): Add fbuf.h, format.h, unix.h.
diff --git a/libgfortran/io/transfer.c b/libgfortran/io/transfer.c
index b5f52b1ccf38811f7025d4c79a0a24daff6461ab..a110c6529ffe0275c6b62e9435d899adb14d4d40 100644
--- a/libgfortran/io/transfer.c
+++ b/libgfortran/io/transfer.c
@@ -2661,6 +2661,8 @@ skip_record (st_parameter_dt *dtp, ssize_t bytes)
       if (sseek (dtp->u.p.current_unit->s, 
 		 dtp->u.p.current_unit->bytes_left_subrecord, SEEK_CUR) < 0)
 	generate_error (&dtp->common, LIBERROR_OS, NULL);
+
+      dtp->u.p.current_unit->bytes_left_subrecord = 0;
     }
   else
     {			/* Seek by reading data.  */
@@ -2741,7 +2743,7 @@ next_record_r (st_parameter_dt *dtp)
 
     case FORMATTED_DIRECT:
     case UNFORMATTED_DIRECT:
-      skip_record (dtp, 0);
+      skip_record (dtp, dtp->u.p.current_unit->bytes_left);
       break;
 
     case FORMATTED_STREAM: