Commit 51b317d2 authored by Nicolas George's avatar Nicolas George Committed by Ronald S. Bultje

TCP: factor the poll() call

Signed-off-by: 's avatarNicolas George <nicolas.george@normalesup.org>
Signed-off-by: 's avatarRonald S. Bultje <rsbultje@gmail.com>
parent f61dee2f
...@@ -129,17 +129,26 @@ static int tcp_open(URLContext *h, const char *uri, int flags) ...@@ -129,17 +129,26 @@ static int tcp_open(URLContext *h, const char *uri, int flags)
return ret; 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) static int tcp_read(URLContext *h, uint8_t *buf, int size)
{ {
TCPContext *s = h->priv_data; TCPContext *s = h->priv_data;
struct pollfd p = {s->fd, POLLIN, 0};
int len, ret; int len, ret;
for (;;) { for (;;) {
if (url_interrupt_cb()) if (url_interrupt_cb())
return AVERROR(EINTR); return AVERROR(EINTR);
ret = poll(&p, 1, 100); ret = tcp_wait_fd(s->fd, 0);
if (ret == 1 && p.revents & POLLIN) { if (ret > 0) {
len = recv(s->fd, buf, size, 0); len = recv(s->fd, buf, size, 0);
if (len < 0) { if (len < 0) {
if (ff_neterrno() != FF_NETERROR(EINTR) && if (ff_neterrno() != FF_NETERROR(EINTR) &&
...@@ -147,9 +156,9 @@ static int tcp_read(URLContext *h, uint8_t *buf, int size) ...@@ -147,9 +156,9 @@ static int tcp_read(URLContext *h, uint8_t *buf, int size)
return ff_neterrno(); return ff_neterrno();
} else return len; } else return len;
} else if (ret < 0) { } else if (ret < 0) {
if (ff_neterrno() == FF_NETERROR(EINTR)) if (ret == FF_NETERROR(EINTR))
continue; continue;
return -1; return ret;
} }
} }
} }
...@@ -158,14 +167,13 @@ static int tcp_write(URLContext *h, const uint8_t *buf, int size) ...@@ -158,14 +167,13 @@ static int tcp_write(URLContext *h, const uint8_t *buf, int size)
{ {
TCPContext *s = h->priv_data; TCPContext *s = h->priv_data;
int ret, size1, len; int ret, size1, len;
struct pollfd p = {s->fd, POLLOUT, 0};
size1 = size; size1 = size;
while (size > 0) { while (size > 0) {
if (url_interrupt_cb()) if (url_interrupt_cb())
return AVERROR(EINTR); return AVERROR(EINTR);
ret = poll(&p, 1, 100); ret = tcp_wait_fd(s->fd, 1);
if (ret == 1 && p.revents & POLLOUT) { if (ret > 0) {
len = send(s->fd, buf, size, 0); len = send(s->fd, buf, size, 0);
if (len < 0) { if (len < 0) {
if (ff_neterrno() != FF_NETERROR(EINTR) && if (ff_neterrno() != FF_NETERROR(EINTR) &&
...@@ -176,9 +184,9 @@ static int tcp_write(URLContext *h, const uint8_t *buf, int size) ...@@ -176,9 +184,9 @@ static int tcp_write(URLContext *h, const uint8_t *buf, int size)
size -= len; size -= len;
buf += len; buf += len;
} else if (ret < 0) { } else if (ret < 0) {
if (ff_neterrno() == FF_NETERROR(EINTR)) if (ret == FF_NETERROR(EINTR))
continue; continue;
return -1; return ret;
} }
} }
return size1 - size; return size1 - size;
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment