Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/lib/libc/stdio revert changes to fflush.c (1.18) and fvwrite...



details:   https://anonhg.NetBSD.org/src/rev/e863227bddda
branches:  trunk
changeset: 984770:e863227bddda
user:      christos <christos%NetBSD.org@localhost>
date:      Thu Jul 22 17:08:15 2021 +0000

description:
revert changes to fflush.c (1.18) and fvwrite.c (1.25) until we investigate
collateral damage. Breaks h_intr.c test. Requested by RVP.

diffstat:

 lib/libc/stdio/fflush.c  |  19 ++-----------
 lib/libc/stdio/fvwrite.c |  66 ++++++++++++-----------------------------------
 2 files changed, 20 insertions(+), 65 deletions(-)

diffs (171 lines):

diff -r 7fedf14f6fb7 -r e863227bddda lib/libc/stdio/fflush.c
--- a/lib/libc/stdio/fflush.c   Thu Jul 22 15:48:40 2021 +0000
+++ b/lib/libc/stdio/fflush.c   Thu Jul 22 17:08:15 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: fflush.c,v 1.23 2021/07/09 09:24:16 christos Exp $     */
+/*     $NetBSD: fflush.c,v 1.24 2021/07/22 17:09:01 christos Exp $     */
 
 /*-
  * Copyright (c) 1990, 1993
@@ -37,7 +37,7 @@
 #if 0
 static char sccsid[] = "@(#)fflush.c   8.1 (Berkeley) 6/4/93";
 #else
-__RCSID("$NetBSD: fflush.c,v 1.23 2021/07/09 09:24:16 christos Exp $");
+__RCSID("$NetBSD: fflush.c,v 1.24 2021/07/22 17:09:01 christos Exp $");
 #endif
 #endif /* LIBC_SCCS and not lint */
 
@@ -45,8 +45,6 @@
 #include <assert.h>
 #include <errno.h>
 #include <stdio.h>
-#include <string.h>
-
 #include "reentrant.h"
 #include "local.h"
 
@@ -107,18 +105,7 @@
 
        for (; n > 0; n -= t, p += t) {
                t = (*fp->_write)(fp->_cookie, (char *)p, n);
-               if (t == 0)
-                       goto out;
-               if (t < 0) {
-                       /* Reset _p and _w. */
-                       if (p > fp->_p) {
-                               /* Some was written. */
-                               memmove(fp->_p, p, n);
-                       }
-                       fp->_p += n;
-                       if ((fp->_flags & (__SLBF | __SNBF)) == 0)
-                               fp->_w -= n;
-out:
+               if (t <= 0) {
                        fp->_flags |= __SERR;
                        return EOF;
                }
diff -r 7fedf14f6fb7 -r e863227bddda lib/libc/stdio/fvwrite.c
--- a/lib/libc/stdio/fvwrite.c  Thu Jul 22 15:48:40 2021 +0000
+++ b/lib/libc/stdio/fvwrite.c  Thu Jul 22 17:08:15 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: fvwrite.c,v 1.29 2021/07/19 10:00:32 christos Exp $    */
+/*     $NetBSD: fvwrite.c,v 1.30 2021/07/22 17:08:15 christos Exp $    */
 
 /*-
  * Copyright (c) 1990, 1993
@@ -37,7 +37,7 @@
 #if 0
 static char sccsid[] = "@(#)fvwrite.c  8.1 (Berkeley) 6/4/93";
 #else
-__RCSID("$NetBSD: fvwrite.c,v 1.29 2021/07/19 10:00:32 christos Exp $");
+__RCSID("$NetBSD: fvwrite.c,v 1.30 2021/07/22 17:08:15 christos Exp $");
 #endif
 #endif /* LIBC_SCCS and not lint */
 
@@ -51,39 +51,6 @@
 #include "local.h"
 #include "fvwrite.h"
 
-static int
-flush_adj(FILE *fp, struct __suio *uio, ssize_t w)
-{
-       int rc;
-
-       _DIAGASSERT(w >= 0);
-       _DIAGASSERT(fp->_w >= 0);
-
-       if ((rc = fflush(fp)) == 0)
-               return 0;
-
-       /*
-        * If we have to return without writing the whole buffer,
-        * adjust for how much fflush() has written for us.
-        * `w' is the amt. of new user data just copied into our
-        * internal buffer in _this_ fwrite() call.
-         */
-       if (fp->_w < w) {
-               /* some new data was also written */
-               ssize_t i = w - fp->_w;
-
-               /* adjust amt. written */
-               uio->uio_resid -= i;
-       } else {
-               /* only old stuff was written */
-
-               /* adjust _p and _w so user can retry */
-               fp->_p -= w;
-               fp->_w += w;
-       }
-       return rc;
-}
-
 /*
  * Write some memory regions.  Return zero on success, EOF on error.
  *
@@ -130,21 +97,15 @@
                len = iov->iov_len; \
                iov++; \
        }
-#define WRITE(nw) \
-       w = (*fp->_write)(fp->_cookie, p, nw); \
-       if (w <= 0) \
-               goto err
-#define FLUSH(nw) \
-       if (flush_adj(fp, uio, nw)) \
-               goto err
-
        if (fp->_flags & __SNBF) {
                /*
                 * Unbuffered: write up to BUFSIZ bytes at a time.
                 */
                do {
                        GETIOV(;);
-                       WRITE(MIN(len, BUFSIZ));
+                       w = (*fp->_write)(fp->_cookie, p, MIN(len, BUFSIZ));
+                       if (w <= 0)
+                               goto err;
                        p += w;
                        len -= w;
                } while ((uio->uio_resid -= w) != 0);
@@ -195,10 +156,13 @@
                                COPY(w);
                                /* fp->_w -= w; */ /* unneeded */
                                fp->_p += w;
-                               FLUSH(w);
+                               if (fflush(fp))
+                                       goto err;
                        } else if (len >= (size_t)(w = fp->_bf._size)) {
                                /* write directly */
-                               WRITE((size_t)w);
+                               w = (*fp->_write)(fp->_cookie, p, (size_t)w);
+                               if (w <= 0)
+                                       goto err;
                        } else {
                                /* fill and done */
                                w = len;
@@ -232,9 +196,12 @@
                                COPY(w);
                                /* fp->_w -= w; */
                                fp->_p += w;
-                               FLUSH(w);
+                               if (fflush(fp))
+                                       goto err;
                        } else if (s >= (w = fp->_bf._size)) {
-                               WRITE((size_t)w);
+                               w = (*fp->_write)(fp->_cookie, p, (size_t)w);
+                               if (w <= 0)
+                                       goto err;
                        } else {
                                w = s;
                                COPY(w);
@@ -243,7 +210,8 @@
                        }
                        if ((nldist -= w) == 0) {
                                /* copied the newline: flush and forget */
-                               FLUSH(w);
+                               if (fflush(fp))
+                                       goto err;
                                nlknown = 0;
                        }
                        p += w;



Home | Main Index | Thread Index | Old Index