Source-Changes-HG archive

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

[src/trunk]: src/lib/libc/stdio Obey EINTR and return immediately adjusting f...



details:   https://anonhg.NetBSD.org/src/rev/c6b30f1aaf96
branches:  trunk
changeset: 1022188:c6b30f1aaf96
user:      christos <christos%NetBSD.org@localhost>
date:      Thu Jul 08 09:06:51 2021 +0000

description:
Obey EINTR and return immediately adjusting for unwritten. From RVP

diffstat:

 lib/libc/stdio/fflush.c  |  14 +++++---------
 lib/libc/stdio/fvwrite.c |  27 +++++++++++++--------------
 2 files changed, 18 insertions(+), 23 deletions(-)

diffs (109 lines):

diff -r 86ac6984dfe5 -r c6b30f1aaf96 lib/libc/stdio/fflush.c
--- a/lib/libc/stdio/fflush.c   Thu Jul 08 05:18:49 2021 +0000
+++ b/lib/libc/stdio/fflush.c   Thu Jul 08 09:06:51 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: fflush.c,v 1.20 2021/07/06 14:22:16 christos Exp $     */
+/*     $NetBSD: fflush.c,v 1.21 2021/07/08 09:06:51 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.20 2021/07/06 14:22:16 christos Exp $");
+__RCSID("$NetBSD: fflush.c,v 1.21 2021/07/08 09:06:51 christos Exp $");
 #endif
 #endif /* LIBC_SCCS and not lint */
 
@@ -108,18 +108,14 @@
        for (; n > 0; n -= t, p += t) {
                t = (*fp->_write)(fp->_cookie, (char *)p, n);
                if (t < 0) {
-                       if (errno == EINTR) {
-                               t = 0;
-                               continue;
-                       }
                        /* 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;
                        }
+                       fp->_p += n;
+                       if ((fp->_flags & (__SLBF | __SNBF)) == 0)
+                               fp->_w -= n;
                        fp->_flags |= __SERR;
                        return EOF;
                }
diff -r 86ac6984dfe5 -r c6b30f1aaf96 lib/libc/stdio/fvwrite.c
--- a/lib/libc/stdio/fvwrite.c  Thu Jul 08 05:18:49 2021 +0000
+++ b/lib/libc/stdio/fvwrite.c  Thu Jul 08 09:06:51 2021 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: fvwrite.c,v 1.26 2021/07/06 14:22:16 christos Exp $    */
+/*     $NetBSD: fvwrite.c,v 1.27 2021/07/08 09:06:51 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.26 2021/07/06 14:22:16 christos Exp $");
+__RCSID("$NetBSD: fvwrite.c,v 1.27 2021/07/08 09:06:51 christos Exp $");
 #endif
 #endif /* LIBC_SCCS and not lint */
 
@@ -99,12 +99,14 @@
        }
 #define WRITE(nw) \
        w = (*fp->_write)(fp->_cookie, p, nw); \
-       if (w < 0) { \
-               if (errno != EINTR) \
-                       goto err; \
-               w = 0; \
-       } else \
-               w = w
+       if (w <= 0) \
+               goto err
+#define FLUSH(nw) \
+       if (fflush(fp)) { \
+               fp->_p -= nw;   /* rewind unwritten */ \
+               goto err; \
+       }
+
        if (fp->_flags & __SNBF) {
                /*
                 * Unbuffered: write up to BUFSIZ bytes at a time.
@@ -162,8 +164,7 @@
                                COPY(w);
                                /* fp->_w -= w; */ /* unneeded */
                                fp->_p += w;
-                               if (fflush(fp))
-                                       goto err;
+                               FLUSH(w);
                        } else if (len >= (size_t)(w = fp->_bf._size)) {
                                /* write directly */
                                WRITE((size_t)w);
@@ -200,8 +201,7 @@
                                COPY(w);
                                /* fp->_w -= w; */
                                fp->_p += w;
-                               if (fflush(fp))
-                                       goto err;
+                               FLUSH(w);
                        } else if (s >= (w = fp->_bf._size)) {
                                WRITE((size_t)w);
                        } else {
@@ -212,8 +212,7 @@
                        }
                        if ((nldist -= w) == 0) {
                                /* copied the newline: flush and forget */
-                               if (fflush(fp))
-                                       goto err;
+                               FLUSH(w);
                                nlknown = 0;
                        }
                        p += w;



Home | Main Index | Thread Index | Old Index