diff options
author | Nicolas George <nicolas.george@normalesup.org> | 2011-02-02 18:45:44 +0100 |
---|---|---|
committer | Ronald S. Bultje <rsbultje@gmail.com> | 2011-02-03 20:58:32 -0500 |
commit | 51b317d2e921f489de7fb72a7f5f05d3039fa1cb (patch) | |
tree | 249d31c0a3ee9110e8e3a10326cbd4e11129ce92 /libavformat/tcp.c | |
parent | f61dee2fe4bc6a614079f37c25af1f92e90bc35b (diff) | |
download | ffmpeg-51b317d2e921f489de7fb72a7f5f05d3039fa1cb.tar.gz |
TCP: factor the poll() call
Signed-off-by: Nicolas George <nicolas.george@normalesup.org>
Signed-off-by: Ronald S. Bultje <rsbultje@gmail.com>
Diffstat (limited to 'libavformat/tcp.c')
-rw-r--r-- | libavformat/tcp.c | 28 |
1 files changed, 18 insertions, 10 deletions
diff --git a/libavformat/tcp.c b/libavformat/tcp.c index ac4e4b09db..564d69f19d 100644 --- a/libavformat/tcp.c +++ b/libavformat/tcp.c @@ -129,17 +129,26 @@ static int tcp_open(URLContext *h, const char *uri, int flags) return ret; } +static int tcp_wait_fd(int fd, int write) +{ + int ev = write ? POLLOUT : POLLIN; + struct pollfd p = { .fd = fd, .events = ev, .revents = 0 }; + int ret; + + ret = poll(&p, 1, 100); + return ret < 0 ? ff_neterrno() : !!(p.revents & ev); +} + static int tcp_read(URLContext *h, uint8_t *buf, int size) { TCPContext *s = h->priv_data; - struct pollfd p = {s->fd, POLLIN, 0}; int len, ret; for (;;) { if (url_interrupt_cb()) return AVERROR(EINTR); - ret = poll(&p, 1, 100); - if (ret == 1 && p.revents & POLLIN) { + ret = tcp_wait_fd(s->fd, 0); + if (ret > 0) { len = recv(s->fd, buf, size, 0); if (len < 0) { if (ff_neterrno() != FF_NETERROR(EINTR) && @@ -147,9 +156,9 @@ static int tcp_read(URLContext *h, uint8_t *buf, int size) return ff_neterrno(); } else return len; } else if (ret < 0) { - if (ff_neterrno() == FF_NETERROR(EINTR)) + if (ret == FF_NETERROR(EINTR)) continue; - return -1; + return ret; } } } @@ -158,14 +167,13 @@ static int tcp_write(URLContext *h, const uint8_t *buf, int size) { TCPContext *s = h->priv_data; int ret, size1, len; - struct pollfd p = {s->fd, POLLOUT, 0}; size1 = size; while (size > 0) { if (url_interrupt_cb()) return AVERROR(EINTR); - ret = poll(&p, 1, 100); - if (ret == 1 && p.revents & POLLOUT) { + ret = tcp_wait_fd(s->fd, 1); + if (ret > 0) { len = send(s->fd, buf, size, 0); if (len < 0) { if (ff_neterrno() != FF_NETERROR(EINTR) && @@ -176,9 +184,9 @@ static int tcp_write(URLContext *h, const uint8_t *buf, int size) size -= len; buf += len; } else if (ret < 0) { - if (ff_neterrno() == FF_NETERROR(EINTR)) + if (ret == FF_NETERROR(EINTR)) continue; - return -1; + return ret; } } return size1 - size; |