From: Tilghman Lesher Date: Tue, 7 Sep 2010 19:07:17 +0000 (+0000) Subject: Merged revisions 285266 via svnmerge from X-Git-Tag: 1.6.2.14-rc1~40 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=3ca871af91b70eae03457c5632a18d972aeb2fbd;p=thirdparty%2Fasterisk.git Merged revisions 285266 via svnmerge from https://origsvn.digium.com/svn/asterisk/branches/1.4 ........ r285266 | tilghman | 2010-09-07 14:04:50 -0500 (Tue, 07 Sep 2010) | 4 lines Use poll, if indicated to do so, in the ast_poll2 implementation. This fixes the unit tests on FreeBSD 8.0. ........ git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/1.6.2@285267 65c4cc65-6c06-0410-ace0-fbb531ad65f3 --- diff --git a/main/poll.c b/main/poll.c index 5895058c10..7989792678 100644 --- a/main/poll.c +++ b/main/poll.c @@ -89,7 +89,7 @@ unsigned int ast_FD_SETSIZE = FD_SETSIZE; Private Functions \*---------------------------------------------------------------------------*/ -#if defined(AST_POLL_COMPAT) || !defined(HAVE_PPOLL) +#if defined(AST_POLL_COMPAT) static int map_poll_spec(struct pollfd *pArray, unsigned long n_fds, ast_fdset *pReadSet, ast_fdset *pWriteSet, ast_fdset *pExceptSet) { @@ -263,10 +263,14 @@ int ast_internal_poll(struct pollfd *pArray, unsigned long n_fds, int timeout) int ast_poll2(struct pollfd *pArray, unsigned long n_fds, struct timeval *tv) { -#ifdef HAVE_PPOLL +#if !defined(AST_POLL_COMPAT) struct timeval start = ast_tvnow(); +#if defined(HAVE_PPOLL) struct timespec ts = { tv ? tv->tv_sec : 0, tv ? tv->tv_usec * 1000 : 0 }; int res = ppoll(pArray, n_fds, tv ? &ts : NULL, NULL); +#else + int res = poll(pArray, n_fds, tv ? tv->tv_sec * 1000 + tv->tv_usec / 1000 : -1); +#endif struct timeval after = ast_tvnow(); if (res > 0 && tv && ast_tvdiff_ms(ast_tvadd(*tv, start), after) > 0) { *tv = ast_tvsub(*tv, ast_tvsub(after, start));