summaryrefslogtreecommitdiff
path: root/libavformat/network.h
diff options
context:
space:
mode:
authorMichael Niedermayer <michaelni@gmx.at>2011-04-08 02:50:13 +0200
committerMichael Niedermayer <michaelni@gmx.at>2011-04-08 02:50:13 +0200
commitc88caa522c41cd4108d39d8dd98805e867606ae3 (patch)
tree90eacfa0065bb907cd6543f5b2865d31d3d0a677 /libavformat/network.h
parentdb95e559f2b1c392295b09e8457d6f161eb5acdb (diff)
parenta2031251c7eedd0d82cb9e08717990fa2ae6299f (diff)
Merge remote branch 'qatar/master'
* qatar/master: proto: include os_support.h in network.h matroskaenc: don't write an empty Cues element. lavc: add a FF_API_REQUEST_CHANNELS deprecation macro avio: move extern url_interrupt_cb declaration from avio.h to url.h avio: make av_register_protocol2 internal. avio: avio_ prefix for url_set_interrupt_cb. avio: AVIO_ prefixes for URL_ open flags. proto: introduce listen option in tcp doc: clarify configure features proto: factor ff_network_wait_fd and use it on udp Conflicts: ffmpeg.c Merged-by: Michael Niedermayer <michaelni@gmx.at>
Diffstat (limited to 'libavformat/network.h')
-rw-r--r--libavformat/network.h14
1 files changed, 14 insertions, 0 deletions
diff --git a/libavformat/network.h b/libavformat/network.h
index 58a8e80e72..74e6f0bbcc 100644
--- a/libavformat/network.h
+++ b/libavformat/network.h
@@ -22,6 +22,7 @@
#define AVFORMAT_NETWORK_H
#include "config.h"
+#include "os_support.h"
#if HAVE_WINSOCK2_H
#include <winsock2.h>
@@ -55,6 +56,10 @@ static inline int ff_neterrno() {
#include <arpa/inet.h>
#endif
+#if HAVE_POLL_H
+#include <poll.h>
+#endif
+
int ff_socket_nonblock(int socket, int enable);
static inline int ff_network_init(void)
@@ -67,6 +72,15 @@ static inline int ff_network_init(void)
return 1;
}
+static inline int ff_network_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 ? 0 : AVERROR(EAGAIN);
+}
+
static inline void ff_network_close(void)
{
#if HAVE_WINSOCK2_H