David Laight reports that sometimes reads on a serial port will
authorsimon <simon@cda61777-01e9-0310-a592-d414129be87e>
Sat, 6 Nov 2010 17:22:38 +0000 (17:22 +0000)
committersimon <simon@cda61777-01e9-0310-a592-d414129be87e>
Sat, 6 Nov 2010 17:22:38 +0000 (17:22 +0000)
attempt to block, and hence return EAGAIN/EWOULDBLOCK, in spite of
the port having been reported readable by select(2). Don't treat
those errors as fatal.

git-svn-id: svn://svn.tartarus.org/sgt/putty@9020 cda61777-01e9-0310-a592-d414129be87e

unix/uxser.c

index 92961a7..22f4a06 100644 (file)
@@ -342,6 +342,14 @@ static int serial_select_result(int fd, int event)
             */
            finished = TRUE;
        } else if (ret < 0) {
+#ifdef EAGAIN
+           if (errno == EAGAIN)
+               return 1;              /* spurious */
+#endif
+#ifdef EWOULDBLOCK
+           if (errno == EWOULDBLOCK)
+               return 1;              /* spurious */
+#endif
            perror("read serial port");
            exit(1);
        } else if (ret > 0) {