diff options
Diffstat (limited to 'src')
| -rw-r--r-- | src/modules/module-sine-source.c | 2 | ||||
| -rw-r--r-- | src/modules/raop/module-raop-sink.c | 2 | ||||
| -rw-r--r-- | src/modules/raop/raop_client.c | 5 | ||||
| -rw-r--r-- | src/modules/rtp/rtsp_client.c | 5 | ||||
| -rw-r--r-- | src/pulse/mainloop.c | 9 | ||||
| -rw-r--r-- | src/pulsecore/lock-autospawn.c | 3 | ||||
| -rw-r--r-- | src/pulsecore/poll.c | 11 | ||||
| -rw-r--r-- | src/pulsecore/poll.h | 18 | ||||
| -rw-r--r-- | src/pulsecore/rtpoll.c | 9 | ||||
| -rw-r--r-- | src/tests/lock-autospawn-test.c | 4 | ||||
| -rw-r--r-- | src/tests/rtpoll-test.c | 2 | ||||
| -rw-r--r-- | src/utils/pacmd.c | 4 | 
12 files changed, 34 insertions, 40 deletions
| diff --git a/src/modules/module-sine-source.c b/src/modules/module-sine-source.c index 9826e5f4..53f53353 100644 --- a/src/modules/module-sine-source.c +++ b/src/modules/module-sine-source.c @@ -32,7 +32,6 @@  #include <unistd.h>  #include <limits.h>  #include <sys/ioctl.h> -#include <sys/poll.h>  #include <pulse/rtclock.h>  #include <pulse/timeval.h> @@ -48,6 +47,7 @@  #include <pulsecore/thread.h>  #include <pulsecore/thread-mq.h>  #include <pulsecore/rtpoll.h> +#include <pulsecore/poll.h>  #include "module-sine-source-symdef.h" diff --git a/src/modules/raop/module-raop-sink.c b/src/modules/raop/module-raop-sink.c index ac48ab10..ce534ce3 100644 --- a/src/modules/raop/module-raop-sink.c +++ b/src/modules/raop/module-raop-sink.c @@ -32,7 +32,6 @@  #include <fcntl.h>  #include <unistd.h>  #include <limits.h> -#include <poll.h>  #include <sys/socket.h>  #include <netinet/in.h>  #include <netinet/tcp.h> @@ -60,6 +59,7 @@  #include <pulsecore/thread.h>  #include <pulsecore/time-smoother.h>  #include <pulsecore/socket-util.h> +#include <pulsecore/poll.h>  #include "module-raop-sink-symdef.h"  #include "rtp.h" diff --git a/src/modules/raop/raop_client.c b/src/modules/raop/raop_client.c index c4b02371..e3152dd3 100644 --- a/src/modules/raop/raop_client.c +++ b/src/modules/raop/raop_client.c @@ -51,12 +51,7 @@  #include <pulsecore/macro.h>  #include <pulsecore/strbuf.h>  #include <pulsecore/random.h> - -#ifdef HAVE_POLL_H -#include <poll.h> -#else  #include <pulsecore/poll.h> -#endif  #include "raop_client.h"  #include "rtsp_client.h" diff --git a/src/modules/rtp/rtsp_client.c b/src/modules/rtp/rtsp_client.c index 59618064..6094eb82 100644 --- a/src/modules/rtp/rtsp_client.c +++ b/src/modules/rtp/rtsp_client.c @@ -45,12 +45,7 @@  #include <pulsecore/macro.h>  #include <pulsecore/strbuf.h>  #include <pulsecore/ioline.h> - -#ifdef HAVE_POLL_H -#include <poll.h> -#else  #include <pulsecore/poll.h> -#endif  #include "rtsp_client.h" diff --git a/src/pulse/mainloop.c b/src/pulse/mainloop.c index 6cd089ef..8f743ec7 100644 --- a/src/pulse/mainloop.c +++ b/src/pulse/mainloop.c @@ -32,12 +32,6 @@  #include <fcntl.h>  #include <errno.h> -#ifdef HAVE_POLL_H -#include <poll.h> -#else -#include <pulsecore/poll.h> -#endif -  #ifndef HAVE_PIPE  #include <pulsecore/pipe.h>  #endif @@ -47,6 +41,7 @@  #include <pulse/timeval.h>  #include <pulse/xmalloc.h> +#include <pulsecore/poll.h>  #include <pulsecore/core-rtclock.h>  #include <pulsecore/core-util.h>  #include <pulsecore/llist.h> @@ -887,7 +882,7 @@ int pa_mainloop_poll(pa_mainloop *m) {                      m->prepared_timeout == PA_USEC_INVALID ? NULL : pa_timespec_store(&ts, m->prepared_timeout),                      NULL);  #else -            m->poll_func_ret = poll( +            m->poll_func_ret = pa_poll(                      m->pollfds, m->n_pollfds,                      usec_to_timeout(m->prepared_timeout));  #endif diff --git a/src/pulsecore/lock-autospawn.c b/src/pulsecore/lock-autospawn.c index 65e35634..95ca04a8 100644 --- a/src/pulsecore/lock-autospawn.c +++ b/src/pulsecore/lock-autospawn.c @@ -33,6 +33,7 @@  #include <pulse/i18n.h>  #include <pulse/xmalloc.h> +#include <pulsecore/poll.h>  #include <pulsecore/mutex.h>  #include <pulsecore/thread.h>  #include <pulsecore/core-util.h> @@ -182,7 +183,7 @@ static void wait_for_ping(void) {      pfd.fd = pipe_fd[0];      pfd.events = POLLIN; -    if ((k = poll(&pfd, 1, -1)) != 1) { +    if ((k = pa_poll(&pfd, 1, -1)) != 1) {          pa_assert(k < 0);          pa_assert(errno == EINTR);      } else if ((s = read(pipe_fd[0], &x, 1)) != 1) { diff --git a/src/pulsecore/poll.c b/src/pulsecore/poll.c index 46a69c5f..1dcace8b 100644 --- a/src/pulsecore/poll.c +++ b/src/pulsecore/poll.c @@ -43,13 +43,18 @@  #include "winsock.h" -#ifndef HAVE_POLL_H -  #include <pulsecore/core-util.h> +#include <pulse/util.h>  #include "poll.h" -int poll (struct pollfd *fds, unsigned long int nfds, int timeout) { +/* Mac OSX fails to implement poll() in a working way since 10.4. IOW, for + * several years. We need to enable a dirty workaround and emulate that call + * with select(), just like for Windows. sic! */ + +#if !defined(HAVE_POLL_H) || defined(OS_IS_DARWIN) + +int pa_poll (struct pollfd *fds, unsigned long int nfds, int timeout) {      struct timeval tv;      fd_set rset, wset, xset;      struct pollfd *f; diff --git a/src/pulsecore/poll.h b/src/pulsecore/poll.h index fe0c6af6..a137d974 100644 --- a/src/pulsecore/poll.h +++ b/src/pulsecore/poll.h @@ -24,6 +24,10 @@     Copyright (C) 1994,96,97,98,99,2000,2001,2004 Free Software Foundation, Inc.  ***/ +#if defined(HAVE_POLL_H) +#include <poll.h> +#else +  /* Event types that can be polled for.  These bits may be set in `events'     to indicate the interesting event types; they will appear in `revents'     to indicate the status of the file descriptor.  */ @@ -38,10 +42,6 @@  #define POLLHUP         0x010           /* Hung up.  */  #define POLLNVAL        0x020           /* Invalid polling request.  */ - -/* Type used for the number of file descriptors.  */ -typedef unsigned long int nfds_t; -  /* Data structure describing a polling request.  */  struct pollfd    { @@ -50,9 +50,17 @@ struct pollfd      short int revents;          /* Types of events that actually occurred.  */    }; +  /* Poll the file descriptors described by the NFDS structures starting at     FDS.  If TIMEOUT is nonzero and not -1, allow TIMEOUT milliseconds for     an event to occur; if TIMEOUT is -1, block until an event occurs.     Returns the number of file descriptors with events, zero if timed out,     or -1 for errors.  */ -extern int poll (struct pollfd *__fds, nfds_t __nfds, int __timeout); + +#endif /* HAVE_POLL_H */ + +#if defined(HAVE_POLL_H) && !defined(OS_IS_DARWIN) +#define pa_poll(fds,nfds,timeout) poll((fds),(nfds),(timeout)) +#else +int pa_poll (struct pollfd *fds, unsigned long nfds, int timeout); +#endif diff --git a/src/pulsecore/rtpoll.c b/src/pulsecore/rtpoll.c index 666cbc98..83993f02 100644 --- a/src/pulsecore/rtpoll.c +++ b/src/pulsecore/rtpoll.c @@ -30,15 +30,10 @@  #include <string.h>  #include <errno.h> -#ifdef HAVE_POLL_H -#include <poll.h> -#else -#include <pulsecore/poll.h> -#endif -  #include <pulse/xmalloc.h>  #include <pulse/timeval.h> +#include <pulsecore/poll.h>  #include <pulsecore/core-error.h>  #include <pulsecore/core-rtclock.h>  #include <pulsecore/macro.h> @@ -304,7 +299,7 @@ int pa_rtpoll_run(pa_rtpoll *p, pa_bool_t wait_op) {          r = ppoll(p->pollfd, p->n_pollfd_used, (!wait_op || p->quit || p->timer_enabled) ? &ts : NULL, NULL);      }  #else -    r = poll(p->pollfd, p->n_pollfd_used, (!wait_op || p->quit || p->timer_enabled) ? (int) ((timeout.tv_sec*1000) + (timeout.tv_usec / 1000)) : -1); +    r = pa_poll(p->pollfd, p->n_pollfd_used, (!wait_op || p->quit || p->timer_enabled) ? (int) ((timeout.tv_sec*1000) + (timeout.tv_usec / 1000)) : -1);  #endif      p->timer_elapsed = r == 0; diff --git a/src/tests/lock-autospawn-test.c b/src/tests/lock-autospawn-test.c index c754e230..6f7156d7 100644 --- a/src/tests/lock-autospawn-test.c +++ b/src/tests/lock-autospawn-test.c @@ -23,9 +23,9 @@  #include <config.h>  #endif -#include <sys/poll.h>  #include <string.h> +#include <pulsecore/poll.h>  #include <pulsecore/macro.h>  #include <pulsecore/thread.h>  #include <pulsecore/lock-autospawn.h> @@ -69,7 +69,7 @@ static void thread_func2(void *k) {          pollfd.fd = fd;          pollfd.events = POLLIN; -        pa_assert_se(poll(&pollfd, 1, -1) == 1); +        pa_assert_se(pa_poll(&pollfd, 1, -1) == 1);          pa_log("%i, woke up", PA_PTR_TO_INT(k));      } diff --git a/src/tests/rtpoll-test.c b/src/tests/rtpoll-test.c index 1706cdfa..6a6b73a8 100644 --- a/src/tests/rtpoll-test.c +++ b/src/tests/rtpoll-test.c @@ -22,8 +22,8 @@  #endif  #include <signal.h> -#include <poll.h> +#include <pulsecore/poll.h>  #include <pulsecore/log.h>  #include <pulsecore/rtpoll.h> diff --git a/src/utils/pacmd.c b/src/utils/pacmd.c index ef58e9ce..6ffe94fe 100644 --- a/src/utils/pacmd.c +++ b/src/utils/pacmd.c @@ -25,7 +25,6 @@  #include <assert.h>  #include <signal.h> -#include <sys/poll.h>  #include <sys/socket.h>  #include <unistd.h>  #include <errno.h> @@ -38,6 +37,7 @@  #include <pulse/xmalloc.h>  #include <pulse/i18n.h> +#include <pulsecore/poll.h>  #include <pulsecore/macro.h>  #include <pulsecore/core-util.h>  #include <pulsecore/log.h> @@ -153,7 +153,7 @@ int main(int argc, char*argv[]) {          else if (!ibuf_eof)              pollfd[WATCH_STDIN].events |= POLLIN; -        if (poll(pollfd, N_WATCH, -1) < 0) { +        if (pa_poll(pollfd, N_WATCH, -1) < 0) {              if (errno == EINTR)                  continue; | 
