Module Name: src Committed By: christos Date: Fri Oct 22 21:29:46 UTC 2010
Modified Files: src/lib/libc/stdio: ftell.c local.h Log Message: implement EOVERFLOW To generate a diff of this commit: cvs rdiff -u -r1.15 -r1.16 src/lib/libc/stdio/ftell.c cvs rdiff -u -r1.25 -r1.26 src/lib/libc/stdio/local.h Please note that diffs are not public domain; they are subject to the copyright notices on the relevant files.
Modified files: Index: src/lib/libc/stdio/ftell.c diff -u src/lib/libc/stdio/ftell.c:1.15 src/lib/libc/stdio/ftell.c:1.16 --- src/lib/libc/stdio/ftell.c:1.15 Thu Aug 7 12:43:25 2003 +++ src/lib/libc/stdio/ftell.c Fri Oct 22 17:29:45 2010 @@ -1,4 +1,4 @@ -/* $NetBSD: ftell.c,v 1.15 2003/08/07 16:43:25 agc Exp $ */ +/* $NetBSD: ftell.c,v 1.16 2010/10/22 21:29:45 christos Exp $ */ /*- * Copyright (c) 1990, 1993 @@ -37,7 +37,7 @@ #if 0 static char sccsid[] = "@(#)ftell.c 8.2 (Berkeley) 5/4/95"; #else -__RCSID("$NetBSD: ftell.c,v 1.15 2003/08/07 16:43:25 agc Exp $"); +__RCSID("$NetBSD: ftell.c,v 1.16 2010/10/22 21:29:45 christos Exp $"); #endif #endif /* LIBC_SCCS and not lint */ @@ -62,7 +62,7 @@ if (fp->_seek == NULL) { FUNLOCKFILE(fp); errno = ESPIPE; /* historic practice */ - return (-1L); + return -1L; } /* @@ -97,5 +97,10 @@ pos += fp->_p - fp->_bf._base; } FUNLOCKFILE(fp); + if (_FPOS_OVERFLOW(pos)) { + errno = EOVERFLOW; + return -1L; + } + return (long)(pos); } Index: src/lib/libc/stdio/local.h diff -u src/lib/libc/stdio/local.h:1.25 src/lib/libc/stdio/local.h:1.26 --- src/lib/libc/stdio/local.h:1.25 Mon Sep 6 10:52:55 2010 +++ src/lib/libc/stdio/local.h Fri Oct 22 17:29:45 2010 @@ -1,4 +1,4 @@ -/* $NetBSD: local.h,v 1.25 2010/09/06 14:52:55 christos Exp $ */ +/* $NetBSD: local.h,v 1.26 2010/10/22 21:29:45 christos Exp $ */ /*- * Copyright (c) 1990, 1993 @@ -113,3 +113,9 @@ extern void __flockfile_internal __P((FILE *, int)); extern void __funlockfile_internal __P((FILE *, int)); + +/* + * Detect if the current file position fits in a long int. + */ +#define _FPOS_OVERFLOW(pos) (sizeof(fpos_t) != sizeof(long) && \ + ((pos) & (~0ULL << ((sizeof(fpos_t) - sizeof(long)) * NBBY))) != 0)