|  |  | @@ -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; | 
		
	
	
		
			
				|  |  | 
 |