diff options
author | François Revol <revol@free.fr> | 2007-02-15 07:44:10 +0000 |
---|---|---|
committer | François Revol <revol@free.fr> | 2007-02-15 07:44:10 +0000 |
commit | b0c858d83481aa85a33c582651ac6ad7d3c4795a (patch) | |
tree | dfbba31c4a03d5fb826ff24695f8216070e7157f /libavformat/os_support.c | |
parent | befa3397c54a495460fe4f18dd7e83a6221b0677 (diff) | |
download | ffmpeg-b0c858d83481aa85a33c582651ac6ad7d3c4795a.tar.gz |
poll() emulation for BeOS, and maybe MinGW.
Originally committed as revision 7987 to svn://svn.ffmpeg.org/ffmpeg/trunk
Diffstat (limited to 'libavformat/os_support.c')
-rw-r--r-- | libavformat/os_support.c | 66 |
1 files changed, 66 insertions, 0 deletions
diff --git a/libavformat/os_support.c b/libavformat/os_support.c index 5d50e75b68..8372af2921 100644 --- a/libavformat/os_support.c +++ b/libavformat/os_support.c @@ -35,6 +35,9 @@ #include <sys/time.h> #endif #include <time.h> +#ifndef HAVE_SYS_POLL_H +#include <sys/select.h> +#endif /** * gets the current time in micro seconds. @@ -94,3 +97,66 @@ done: return 1; } #endif /* !defined(HAVE_INET_ATON) && defined(CONFIG_NETWORK) */ + +#ifndef HAVE_SYS_POLL_H +int poll(struct pollfd *fds, nfds_t numfds, int timeout) +{ + fd_set read_set; + fd_set write_set; + fd_set exception_set; + nfds_t i; + int n; + int rc; + + FD_ZERO(&read_set); + FD_ZERO(&write_set); + FD_ZERO(&exception_set); + + n = -1; + for(i = 0; i < numfds; i++) { + if (fds[i].fd < 0) + continue; + if (fds[i].fd >= FD_SETSIZE) { + errno = EINVAL; + return -1; + } + + if (fds[i].events & POLLIN) FD_SET(fds[i].fd, &read_set); + if (fds[i].events & POLLOUT) FD_SET(fds[i].fd, &write_set); + if (fds[i].events & POLLERR) FD_SET(fds[i].fd, &exception_set); + + if (fds[i].fd > n) + n = fds[i].fd; + }; + + if (n == -1) + /* Hey!? Nothing to poll, in fact!!! */ + return 0; + + if (timeout < 0) + rc = select(n+1, &read_set, &write_set, &exception_set, NULL); + else { + struct timeval tv; + + tv.tv_sec = timeout / 1000; + tv.tv_usec = 1000 * (timeout % 1000); + rc = select(n+1, &read_set, &write_set, &exception_set, &tv); + }; + + if (rc < 0) + return rc; + + for(i = 0; i < (nfds_t) n; i++) { + fds[i].revents = 0; + + if (FD_ISSET(fds[i].fd, &read_set)) fds[i].revents |= POLLIN; + if (FD_ISSET(fds[i].fd, &write_set)) fds[i].revents |= POLLOUT; + if (FD_ISSET(fds[i].fd, &exception_set)) fds[i].revents |= POLLERR; + }; + + return rc; +} + + +#endif /* HAVE_SYS_POLL_H */ + |