diff options
author | Martin Storsjö <martin@martin.st> | 2010-03-26 16:04:38 +0000 |
---|---|---|
committer | Martin Storsjö <martin@martin.st> | 2010-03-26 16:04:38 +0000 |
commit | cae9a15c98eb9b1ba431d2d55a39171783407bc0 (patch) | |
tree | 01192de415e1cd1779690c5d7f7544e0347ead22 /libavformat | |
parent | 3fd427cd194ca9bd486fb222277b03ee90a64384 (diff) | |
download | ffmpeg-cae9a15c98eb9b1ba431d2d55a39171783407bc0.tar.gz |
Don't report EINTR from select as an error, retry select instead
Originally committed as revision 22694 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat')
-rw-r--r-- | libavformat/rtpproto.c | 2 | ||||
-rw-r--r-- | libavformat/tcp.c | 4 | ||||
-rw-r--r-- | libavformat/udp.c | 5 |
3 files changed, 10 insertions, 1 deletions
diff --git a/libavformat/rtpproto.c b/libavformat/rtpproto.c index 35bbc18636..4ef655d563 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 ae846a4c37..79cabdfe90 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 dc896a43f1..84bca7b0d3 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); |