Don't report EINTR from select as an error, retry select instead
Originally committed as revision 22694 to svn://svn.ffmpeg.org/ffmpeg/trunk
This commit is contained in:
parent
3fd427cd19
commit
cae9a15c98
@ -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);
|
||||
}
|
||||
}
|
||||
|
@ -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;
|
||||
}
|
||||
}
|
||||
|
@ -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);
|
||||
|
Loading…
x
Reference in New Issue
Block a user