Kannel: Open Source WAP and SMS gateway
svn-r5336
gwpoll.h
Go to the documentation of this file.
1
/* ====================================================================
2
* The Kannel Software License, Version 1.0
3
*
4
* Copyright (c) 2001-2018 Kannel Group
5
* Copyright (c) 1998-2001 WapIT Ltd.
6
* All rights reserved.
7
*
8
* Redistribution and use in source and binary forms, with or without
9
* modification, are permitted provided that the following conditions
10
* are met:
11
*
12
* 1. Redistributions of source code must retain the above copyright
13
* notice, this list of conditions and the following disclaimer.
14
*
15
* 2. Redistributions in binary form must reproduce the above copyright
16
* notice, this list of conditions and the following disclaimer in
17
* the documentation and/or other materials provided with the
18
* distribution.
19
*
20
* 3. The end-user documentation included with the redistribution,
21
* if any, must include the following acknowledgment:
22
* "This product includes software developed by the
23
* Kannel Group (http://www.kannel.org/)."
24
* Alternately, this acknowledgment may appear in the software itself,
25
* if and wherever such third-party acknowledgments normally appear.
26
*
27
* 4. The names "Kannel" and "Kannel Group" must not be used to
28
* endorse or promote products derived from this software without
29
* prior written permission. For written permission, please
30
* contact org@kannel.org.
31
*
32
* 5. Products derived from this software may not be called "Kannel",
33
* nor may "Kannel" appear in their name, without prior written
34
* permission of the Kannel Group.
35
*
36
* THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37
* WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38
* OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39
* DISCLAIMED. IN NO EVENT SHALL THE KANNEL GROUP OR ITS CONTRIBUTORS
40
* BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
41
* OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT
42
* OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR
43
* BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
44
* WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE
45
* OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
46
* EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
47
* ====================================================================
48
*
49
* This software consists of voluntary contributions made by many
50
* individuals on behalf of the Kannel Group. For more information on
51
* the Kannel Group, please see <http://www.kannel.org/>.
52
*
53
* Portions of this software are based upon software originally written at
54
* WapIT Ltd., Helsinki, Finland for the Kannel project.
55
*/
56
57
/* gwpoll.h - define poll() for systems that don't have it */
58
59
#ifndef GWPOLL_H
60
#define GWPOLL_H
61
62
/* If the system supplies it, we're done. Assume that if the header file
63
* exists, it will define poll() and struct pollfd for us. */
64
#ifdef HAVE_SYS_POLL_H
65
66
#include <sys/poll.h>
67
68
/* Most systems accept any negative timeout value as meaning infinite
69
* timeout. FreeBSD explicitly wants INFTIM, however. Other systems
70
* don't define INFTIM. So we use it if it's defined, and -1 otherwise.
71
*/
72
73
#ifdef INFTIM
74
#define POLL_NOTIMEOUT INFTIM
75
#else
76
#define POLL_NOTIMEOUT (-1)
77
#endif
78
79
#else
80
81
/* Define struct pollfd and the event bits, and declare a function poll()
82
* that uses them and is a wrapper around select(). */
83
84
struct
pollfd
{
85
int
fd
;
/* file descriptor */
86
short
events
;
/* requested events */
87
short
revents
;
/* returned events */
88
};
89
90
/* Bits for events and revents */
91
#define POLLIN 1
/* Reading will not block */
92
#define POLLPRI 2
/* Urgent data available for reading */
93
#define POLLOUT 4
/* Writing will not block */
94
95
/* Bits only used in revents */
96
#define POLLERR 8
/* Error condition */
97
#define POLLHUP 16
/* Hung up: fd was closed by other side */
98
#define POLLNVAL 32
/* Invalid: fd not open or not valid */
99
100
#define POLL_NOTIMEOUT (-1)
101
102
/* Implement the function as gw_poll, in case the system does have a poll()
103
* function in its libraries but just fails to define it in sys/poll.h. */
104
#define poll(fdarray, numfds, timeout) gw_poll(fdarray, numfds, timeout)
105
int
gw_poll
(
struct
pollfd
*fdarray,
unsigned
int
numfds,
int
timeout);
106
107
#endif
/* !HAVE_SYS_POLL_H */
108
109
#endif
gw_poll
int gw_poll(struct pollfd *fdarray, unsigned int numfds, int timeout)
Definition:
gwpoll.c:67
pollfd::events
short events
Definition:
gwpoll.h:86
pollfd
Definition:
gwpoll.h:84
pollfd::fd
int fd
Definition:
gwpoll.h:85
pollfd::revents
short revents
Definition:
gwpoll.h:87
See file LICENSE for details about the license agreement for using, modifying, copying or deriving work from this software.