From cae9a15c98eb9b1ba431d2d55a39171783407bc0 Mon Sep 17 00:00:00 2001
From: =?UTF-8?q?Martin=20Storsj=C3=B6?= <martin@martin.st>
Date: Fri, 26 Mar 2010 16:04:38 +0000
Subject: [PATCH] Don't report EINTR from select as an error, retry select
 instead

Originally committed as revision 22694 to svn://svn.ffmpeg.org/ffmpeg/trunk
---
 libavformat/rtpproto.c | 2 ++
 libavformat/tcp.c      | 4 ++++
 libavformat/udp.c      | 5 ++++-
 3 files changed, 10 insertions(+), 1 deletion(-)

diff --git a/libavformat/rtpproto.c b/libavformat/rtpproto.c
index 35bbc186361..4ef655d5637 100644
--- a/libavformat/rtpproto.c
+++ b/libavformat/rtpproto.c
@@ -251,6 +251,8 @@ static int rtp_read(URLContext *h, uint8_t *buf, int size)
                 break;
             }
         } else if (n < 0) {
+            if (ff_neterrno() == FF_NETERROR(EINTR))
+                continue;
             return AVERROR(EIO);
         }
     }
diff --git a/libavformat/tcp.c b/libavformat/tcp.c
index ae846a4c370..79cabdfe903 100644
--- a/libavformat/tcp.c
+++ b/libavformat/tcp.c
@@ -147,6 +147,8 @@ static int tcp_read(URLContext *h, uint8_t *buf, int size)
                     return AVERROR(ff_neterrno());
             } else return len;
         } else if (ret < 0) {
+            if (ff_neterrno() == FF_NETERROR(EINTR))
+                continue;
             return -1;
         }
     }
@@ -180,6 +182,8 @@ static int tcp_write(URLContext *h, uint8_t *buf, int size)
             size -= len;
             buf += len;
         } else if (ret < 0) {
+            if (ff_neterrno() == FF_NETERROR(EINTR))
+                continue;
             return -1;
         }
     }
diff --git a/libavformat/udp.c b/libavformat/udp.c
index dc896a43f1c..84bca7b0d3f 100644
--- a/libavformat/udp.c
+++ b/libavformat/udp.c
@@ -437,8 +437,11 @@ static int udp_read(URLContext *h, uint8_t *buf, int size)
         tv.tv_sec = 0;
         tv.tv_usec = 100 * 1000;
         ret = select(s->udp_fd + 1, &rfds, NULL, NULL, &tv);
-        if (ret < 0)
+        if (ret < 0) {
+            if (ff_neterrno() == FF_NETERROR(EINTR))
+                continue;
             return AVERROR(EIO);
+        }
         if (!(ret > 0 && FD_ISSET(s->udp_fd, &rfds)))
             continue;
         len = recv(s->udp_fd, buf, size, 0);
-- 
GitLab