Main Page | Alphabetical List | Data Structures | Directories | File List | Data Fields | Globals

gwpoll.c

Go to the documentation of this file.
00001 /* ==================================================================== 
00002  * The Kannel Software License, Version 1.0 
00003  * 
00004  * Copyright (c) 2001-2008 Kannel Group  
00005  * Copyright (c) 1998-2001 WapIT Ltd.   
00006  * All rights reserved. 
00007  * 
00008  * Redistribution and use in source and binary forms, with or without 
00009  * modification, are permitted provided that the following conditions 
00010  * are met: 
00011  * 
00012  * 1. Redistributions of source code must retain the above copyright 
00013  *    notice, this list of conditions and the following disclaimer. 
00014  * 
00015  * 2. Redistributions in binary form must reproduce the above copyright 
00016  *    notice, this list of conditions and the following disclaimer in 
00017  *    the documentation and/or other materials provided with the 
00018  *    distribution. 
00019  * 
00020  * 3. The end-user documentation included with the redistribution, 
00021  *    if any, must include the following acknowledgment: 
00022  *       "This product includes software developed by the 
00023  *        Kannel Group (http://www.kannel.org/)." 
00024  *    Alternately, this acknowledgment may appear in the software itself, 
00025  *    if and wherever such third-party acknowledgments normally appear. 
00026  * 
00027  * 4. The names "Kannel" and "Kannel Group" must not be used to 
00028  *    endorse or promote products derived from this software without 
00029  *    prior written permission. For written permission, please  
00030  *    contact org@kannel.org. 
00031  * 
00032  * 5. Products derived from this software may not be called "Kannel", 
00033  *    nor may "Kannel" appear in their name, without prior written 
00034  *    permission of the Kannel Group. 
00035  * 
00036  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED 
00037  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES 
00038  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE 
00039  * DISCLAIMED.  IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS 
00040  * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,  
00041  * OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT  
00042  * OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR  
00043  * BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,  
00044  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE  
00045  * OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,  
00046  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. 
00047  * ==================================================================== 
00048  * 
00049  * This software consists of voluntary contributions made by many 
00050  * individuals on behalf of the Kannel Group.  For more information on  
00051  * the Kannel Group, please see <http://www.kannel.org/>. 
00052  * 
00053  * Portions of this software are based upon software originally written at  
00054  * WapIT Ltd., Helsinki, Finland for the Kannel project.  
00055  */ 
00056 
00057 /* gwpoll.c - implement poll() for systems that don't have it */
00058 
00059 #include "gwlib/gwlib.h"
00060 
00061 #ifndef HAVE_SYS_POLL_H
00062 
00063 #include <sys/time.h>
00064 #include <sys/types.h>
00065 #include <unistd.h>
00066 
00067 int gw_poll(struct pollfd *fdarray, unsigned int numfds, int timeout)
00068 {
00069     struct timeval tv, *tvp;
00070     unsigned int i;
00071     int maxfd;
00072     fd_set readfds, *rfdp;
00073     fd_set writefds, *wfdp;
00074     fd_set exceptfds, *xfdp;
00075     int ret;
00076     int result;
00077 
00078     FD_ZERO(&readfds);
00079     FD_ZERO(&writefds);
00080     FD_ZERO(&exceptfds);
00081     maxfd = -1;
00082     /* These are the pointers we will pass to select().  We use them because
00083      * we may want to pass NULL for some of them. */
00084     tvp = NULL;
00085     rfdp = NULL;
00086     wfdp = NULL;
00087     xfdp = NULL;
00088 
00089     /* Deal with timeout.  We get it in milliseconds.  If it's negative,
00090      * block indefinitely, which we do in select() by passing a NULL
00091      * timeval pointer. */
00092     if (timeout >= 0) {
00093         tv.tv_sec = timeout / 1000;
00094         tv.tv_usec = (timeout % 1000) * 1000;
00095         tvp = &tv;
00096     }
00097 
00098     /* Deal with fdarray, and convert it to the three fd_sets used by select. */
00099     for (i = 0; i < numfds; i++) {
00100         int fd = fdarray[i].fd;
00101         int events = fdarray[i].events;
00102         if (fd < 0)
00103             continue;
00104         if (events & POLLIN) {
00105             FD_SET(fd, &readfds);
00106             rfdp = &readfds;
00107     }
00108         if (events & POLLOUT) {
00109             FD_SET(fd, &writefds);
00110             wfdp = &writefds;
00111     }
00112         if (events & POLLPRI) {
00113             FD_SET(fd, &exceptfds);
00114             xfdp = &exceptfds;
00115     }
00116         if (fd > maxfd && events & (POLLIN | POLLOUT | POLLPRI))
00117         maxfd = fd;
00118     }
00119 
00120     ret = select(maxfd + 1, rfdp, wfdp, xfdp, tvp);
00121     if (ret < 0)
00122         return ret;
00123 
00124     /* Move the returned data from the fd sets to the revents fields
00125      * in fdarray.  We can't detect POLLNVAL except for obviously
00126      * invalid fd's, and detecting POLLHUP or POLLERR would require
00127      * an extra read() call per fd which is too expensive. */
00128     result = 0;
00129     for (i = 0; i < numfds; i++) {
00130         if (fdarray[i].fd < 0) {
00131         fdarray[i].revents = POLLNVAL;
00132             continue;
00133         }
00134         fdarray[i].revents = 0;
00135         if (rfdp && FD_ISSET(fdarray[i].fd, &readfds))
00136         fdarray[i].revents |= POLLIN;
00137         if (wfdp && FD_ISSET(fdarray[i].fd, &writefds))
00138         fdarray[i].revents |= POLLOUT;
00139         if (xfdp && FD_ISSET(fdarray[i].fd, &exceptfds))
00140         fdarray[i].revents |= POLLPRI;
00141     if (fdarray[i].revents != 0)
00142         result++;
00143     }
00144 
00145     return result;
00146 }
00147 
00148 #endif
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.