summaryrefslogtreecommitdiff
path: root/libavformat/tcp.c
diff options
context:
space:
mode:
authorNicolas George <nicolas.george@normalesup.org>2011-02-02 18:45:44 +0100
committerRonald S. Bultje <rsbultje@gmail.com>2011-02-03 20:58:32 -0500
commit51b317d2e921f489de7fb72a7f5f05d3039fa1cb (patch)
tree249d31c0a3ee9110e8e3a10326cbd4e11129ce92 /libavformat/tcp.c
parentf61dee2fe4bc6a614079f37c25af1f92e90bc35b (diff)
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.c28
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;