ViewVC Help
View File | Revision Log | Show Annotations | Download File
/cvs/libev/ev_port.c
(Generate patch)

Comparing libev/ev_port.c (file contents):
Revision 1.26 by root, Wed Feb 16 08:02:50 2011 UTC vs.
Revision 1.29 by root, Thu Feb 18 04:48:05 2016 UTC

53#include <poll.h> 53#include <poll.h>
54#include <port.h> 54#include <port.h>
55#include <string.h> 55#include <string.h>
56#include <errno.h> 56#include <errno.h>
57 57
58void inline_speed 58inline_speed
59void
59port_associate_and_check (EV_P_ int fd, int ev) 60port_associate_and_check (EV_P_ int fd, int ev)
60{ 61{
61 if (0 > 62 if (0 >
62 port_associate ( 63 port_associate (
63 backend_fd, PORT_SOURCE_FD, fd, 64 backend_fd, PORT_SOURCE_FD, fd,
134 port_eventmax = array_nextsize (sizeof (port_event_t), port_eventmax, port_eventmax + 1); 135 port_eventmax = array_nextsize (sizeof (port_event_t), port_eventmax, port_eventmax + 1);
135 port_events = (port_event_t *)ev_malloc (sizeof (port_event_t) * port_eventmax); 136 port_events = (port_event_t *)ev_malloc (sizeof (port_event_t) * port_eventmax);
136 } 137 }
137} 138}
138 139
139int inline_size 140inline_size
141int
140port_init (EV_P_ int flags) 142port_init (EV_P_ int flags)
141{ 143{
142 /* Initialize the kernel queue */ 144 /* Initialize the kernel queue */
143 if ((backend_fd = port_create ()) < 0) 145 if ((backend_fd = port_create ()) < 0)
144 return 0; 146 return 0;
145 147
146 assert (("libev: PORT_SOURCE_FD must not be zero", PORT_SOURCE_FD)); 148 assert (("libev: PORT_SOURCE_FD must not be zero", PORT_SOURCE_FD));
147 149
148 fcntl (backend_fd, F_SETFD, FD_CLOEXEC); /* not sure if necessary, hopefully doesn't hurt */ 150 fcntl (backend_fd, F_SETFD, FD_CLOEXEC); /* not sure if necessary, hopefully doesn't hurt */
149 151
152 /* if my reading of the opensolaris kernel sources are correct, then
153 * opensolaris does something very stupid: it checks if the time has already
154 * elapsed and doesn't round up if that is the case,m otherwise it DOES round
155 * up. Since we can't know what the case is, we need to guess by using a
156 * "large enough" timeout. Normally, 1e-9 would be correct.
157 */
150 backend_fudge = 1e-3; /* needed to compensate for port_getn returning early */ 158 backend_mintime = 1e-3; /* needed to compensate for port_getn returning early */
151 backend_modify = port_modify; 159 backend_modify = port_modify;
152 backend_poll = port_poll; 160 backend_poll = port_poll;
153 161
154 port_eventmax = 64; /* initial number of events receivable per poll */ 162 port_eventmax = 64; /* initial number of events receivable per poll */
155 port_events = (port_event_t *)ev_malloc (sizeof (port_event_t) * port_eventmax); 163 port_events = (port_event_t *)ev_malloc (sizeof (port_event_t) * port_eventmax);
156 164
157 return EVBACKEND_PORT; 165 return EVBACKEND_PORT;
158} 166}
159 167
160void inline_size 168inline_size
169void
161port_destroy (EV_P) 170port_destroy (EV_P)
162{ 171{
163 ev_free (port_events); 172 ev_free (port_events);
164} 173}
165 174
166void inline_size 175inline_size
176void
167port_fork (EV_P) 177port_fork (EV_P)
168{ 178{
169 close (backend_fd); 179 close (backend_fd);
170 180
171 while ((backend_fd = port_create ()) < 0) 181 while ((backend_fd = port_create ()) < 0)

Diff Legend

Removed lines
+ Added lines
< Changed lines
> Changed lines