2002-10-23 Roland McGrath <roland@redhat.com>
authorroland <roland>
Wed, 23 Oct 2002 23:50:14 +0000 (23:50 +0000)
committerroland <roland>
Wed, 23 Oct 2002 23:50:14 +0000 (23:50 +0000)
* libio/ftello.c (ftello): Use _IO_off64_t for type of POS.
Check for the result overflowing off_t and fail with EOVERFLOW.
* libio/ioftell.c (_IO_ftell): Likewise.
* libio/iofgetpos.c (_IO_new_fgetpos): Likewise.

libio/ftello.c
libio/iofgetpos.c
libio/ioftell.c

index dcecf5e..94a2541 100644 (file)
@@ -35,7 +35,7 @@ off_t
 ftello (fp)
      _IO_FILE *fp;
 {
-  _IO_off_t pos;
+  _IO_off64_t pos;
   CHECK_FILE (fp, -1L);
   _IO_cleanup_region_start ((void (*) (void *)) _IO_funlockfile, fp);
   _IO_flockfile (fp);
@@ -55,5 +55,12 @@ ftello (fp)
 #endif
       return -1L;
     }
+  if ((_IO_off64_t) (off_t) pos != pos)
+    {
+#ifdef EOVERFLOW
+      __set_errno (EOVERFLOW);
+#endif
+      return -1L;
+    }
   return pos;
 }
index c8eea79..4b50898 100644 (file)
@@ -35,7 +35,7 @@ _IO_new_fgetpos (fp, posp)
      _IO_FILE *fp;
      _IO_fpos_t *posp;
 {
-  _IO_off_t pos;
+  _IO_off64_t pos;
   int result = 0;
   CHECK_FILE (fp, EOF);
   _IO_cleanup_region_start ((void (*) __P ((void *))) _IO_funlockfile, fp);
@@ -56,6 +56,13 @@ _IO_new_fgetpos (fp, posp)
 #endif
       result = EOF;
     }
+  else if ((_IO_off64_t) (__typeof (posp->__pos)) pos != pos)
+    {
+#ifdef EOVERFLOW
+      __set_errno (EOVERFLOW);
+#endif
+      result = EOF;
+    }
   else
     {
       posp->__pos = pos;
index 8328c5b..2a389c3 100644 (file)
@@ -34,7 +34,7 @@ long int
 _IO_ftell (fp)
      _IO_FILE *fp;
 {
-  _IO_off_t pos;
+  _IO_off64_t pos;
   CHECK_FILE (fp, -1L);
   _IO_cleanup_region_start ((void (*) __P ((void *))) _IO_funlockfile, fp);
   _IO_flockfile (fp);
@@ -54,6 +54,13 @@ _IO_ftell (fp)
 #endif
       return -1L;
     }
+  if ((_IO_off64_t) (off_t) pos != pos)
+    {
+#ifdef EOVERFLOW
+      __set_errno (EOVERFLOW);
+#endif
+      return -1L;
+    }
   return pos;
 }
 INTDEF(_IO_ftell)