annotate src/event/modules/ngx_eventport_module.c @ 7446:9234e8d61aa0

Win32: detection of connect() errors in select(). On Windows, connect() errors are only reported via exceptfds descriptor set from select(). Previously exceptfds was set to NULL, and connect() errors were not detected at all, so connects to closed ports were waiting till a timeout occurred. Since ongoing connect() means that there will be a write event active, except descriptor set is copied from the write one. While it is possible to construct except descriptor set as a concatenation of both read and write descriptor sets, this looks unneeded. With this change, connect() errors are properly detected now when using select(). Note well that it is not possible to detect connect() errors with WSAPoll() (see https://daniel.haxx.se/blog/2012/10/10/wsapoll-is-broken/).
author Maxim Dounin <mdounin@mdounin.ru>
date Thu, 24 Jan 2019 22:00:44 +0300
parents cbf59d483c9c
children 3c51385e5da1
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
1
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
2 /*
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
3 * Copyright (C) Igor Sysoev
4412
d620f497c50f Copyright updated.
Maxim Konovalov <maxim@nginx.com>
parents: 3475
diff changeset
4 * Copyright (C) Nginx, Inc.
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
5 */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
6
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
7
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
8 #include <ngx_config.h>
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
9 #include <ngx_core.h>
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
10 #include <ngx_event.h>
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
11
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
12
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
13 #if (NGX_TEST_BUILD_EVENTPORT)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
14
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
15 #define ushort_t u_short
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
16 #define uint_t u_int
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
17
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
18 #ifndef CLOCK_REALTIME
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
19 #define CLOCK_REALTIME 0
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
20 typedef int clockid_t;
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
21 typedef void * timer_t;
7189
cbf59d483c9c Fixed --test-build-eventport on macOS 10.12 and later.
Ruslan Ermilov <ru@nginx.com>
parents: 6923
diff changeset
22 #elif (NGX_DARWIN)
cbf59d483c9c Fixed --test-build-eventport on macOS 10.12 and later.
Ruslan Ermilov <ru@nginx.com>
parents: 6923
diff changeset
23 typedef void * timer_t;
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
24 #endif
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
25
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
26 /* Solaris declarations */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
27
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
28 #define PORT_SOURCE_AIO 1
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
29 #define PORT_SOURCE_TIMER 2
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
30 #define PORT_SOURCE_USER 3
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
31 #define PORT_SOURCE_FD 4
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
32 #define PORT_SOURCE_ALERT 5
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
33 #define PORT_SOURCE_MQ 6
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
34
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
35 #ifndef ETIME
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
36 #define ETIME 64
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
37 #endif
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
38
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
39 #define SIGEV_PORT 4
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
40
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
41 typedef struct {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
42 int portev_events; /* event data is source specific */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
43 ushort_t portev_source; /* event source */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
44 ushort_t portev_pad; /* port internal use */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
45 uintptr_t portev_object; /* source specific object */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
46 void *portev_user; /* user cookie */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
47 } port_event_t;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
48
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
49 typedef struct port_notify {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
50 int portnfy_port; /* bind request(s) to port */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
51 void *portnfy_user; /* user defined */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
52 } port_notify_t;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
53
6475
7d6970ba5209 Events: fixed test building with eventport on OS X.
Ruslan Ermilov <ru@nginx.com>
parents: 6447
diff changeset
54 #if (__FreeBSD__ && __FreeBSD_version < 700005) || (NGX_DARWIN)
1939
6e7daf852eec restore building --test-build-rtsig and --test-build-eventport on FreeBSD 6
Igor Sysoev <igor@sysoev.ru>
parents: 1870
diff changeset
55
6e7daf852eec restore building --test-build-rtsig and --test-build-eventport on FreeBSD 6
Igor Sysoev <igor@sysoev.ru>
parents: 1870
diff changeset
56 typedef struct itimerspec { /* definition per POSIX.4 */
6e7daf852eec restore building --test-build-rtsig and --test-build-eventport on FreeBSD 6
Igor Sysoev <igor@sysoev.ru>
parents: 1870
diff changeset
57 struct timespec it_interval;/* timer period */
6e7daf852eec restore building --test-build-rtsig and --test-build-eventport on FreeBSD 6
Igor Sysoev <igor@sysoev.ru>
parents: 1870
diff changeset
58 struct timespec it_value; /* timer expiration */
6e7daf852eec restore building --test-build-rtsig and --test-build-eventport on FreeBSD 6
Igor Sysoev <igor@sysoev.ru>
parents: 1870
diff changeset
59 } itimerspec_t;
6e7daf852eec restore building --test-build-rtsig and --test-build-eventport on FreeBSD 6
Igor Sysoev <igor@sysoev.ru>
parents: 1870
diff changeset
60
6e7daf852eec restore building --test-build-rtsig and --test-build-eventport on FreeBSD 6
Igor Sysoev <igor@sysoev.ru>
parents: 1870
diff changeset
61 #endif
6e7daf852eec restore building --test-build-rtsig and --test-build-eventport on FreeBSD 6
Igor Sysoev <igor@sysoev.ru>
parents: 1870
diff changeset
62
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
63 int port_create(void);
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
64
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
65 int port_create(void)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
66 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
67 return -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
68 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
69
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
70
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
71 int port_associate(int port, int source, uintptr_t object, int events,
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
72 void *user);
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
73
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
74 int port_associate(int port, int source, uintptr_t object, int events,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
75 void *user)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
76 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
77 return -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
78 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
79
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
80
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
81 int port_dissociate(int port, int source, uintptr_t object);
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
82
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
83 int port_dissociate(int port, int source, uintptr_t object)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
84 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
85 return -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
86 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
87
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
88
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
89 int port_getn(int port, port_event_t list[], uint_t max, uint_t *nget,
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
90 struct timespec *timeout);
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
91
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
92 int port_getn(int port, port_event_t list[], uint_t max, uint_t *nget,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
93 struct timespec *timeout)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
94 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
95 return -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
96 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
97
6021
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
98 int port_send(int port, int events, void *user);
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
99
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
100 int port_send(int port, int events, void *user)
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
101 {
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
102 return -1;
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
103 }
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
104
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
105
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
106 int timer_create(clockid_t clock_id, struct sigevent *evp, timer_t *timerid);
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
107
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
108 int timer_create(clockid_t clock_id, struct sigevent *evp, timer_t *timerid)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
109 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
110 return -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
111 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
112
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
113
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
114 int timer_settime(timer_t timerid, int flags, const struct itimerspec *value,
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
115 struct itimerspec *ovalue);
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
116
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
117 int timer_settime(timer_t timerid, int flags, const struct itimerspec *value,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
118 struct itimerspec *ovalue)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
119 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
120 return -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
121 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
122
4759
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
123
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
124 int timer_delete(timer_t timerid);
4c36e15651f7 Fixed compilation with -Wmissing-prototypes.
Ruslan Ermilov <ru@nginx.com>
parents: 4572
diff changeset
125
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
126 int timer_delete(timer_t timerid)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
127 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
128 return -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
129 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
130
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
131 #endif
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
132
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
133
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
134 typedef struct {
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
135 ngx_uint_t events;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
136 } ngx_eventport_conf_t;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
137
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
138
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
139 static ngx_int_t ngx_eventport_init(ngx_cycle_t *cycle, ngx_msec_t timer);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
140 static void ngx_eventport_done(ngx_cycle_t *cycle);
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
141 static ngx_int_t ngx_eventport_add_event(ngx_event_t *ev, ngx_int_t event,
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
142 ngx_uint_t flags);
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
143 static ngx_int_t ngx_eventport_del_event(ngx_event_t *ev, ngx_int_t event,
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
144 ngx_uint_t flags);
6021
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
145 static ngx_int_t ngx_eventport_notify(ngx_event_handler_pt handler);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
146 static ngx_int_t ngx_eventport_process_events(ngx_cycle_t *cycle,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
147 ngx_msec_t timer, ngx_uint_t flags);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
148
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
149 static void *ngx_eventport_create_conf(ngx_cycle_t *cycle);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
150 static char *ngx_eventport_init_conf(ngx_cycle_t *cycle, void *conf);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
151
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
152 static int ep = -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
153 static port_event_t *event_list;
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
154 static ngx_uint_t nevents;
1870
a62fb6c156c5 fix building --test-build-rtsig and --test-build-eventport on FreeBSD 7
Igor Sysoev <igor@sysoev.ru>
parents: 1354
diff changeset
155 static timer_t event_timer = (timer_t) -1;
6021
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
156 static ngx_event_t notify_event;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
157
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
158 static ngx_str_t eventport_name = ngx_string("eventport");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
159
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
160
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
161 static ngx_command_t ngx_eventport_commands[] = {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
162
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
163 { ngx_string("eventport_events"),
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
164 NGX_EVENT_CONF|NGX_CONF_TAKE1,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
165 ngx_conf_set_num_slot,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
166 0,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
167 offsetof(ngx_eventport_conf_t, events),
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
168 NULL },
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
169
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
170 ngx_null_command
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
171 };
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
172
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
173
6922
a72886067bbb Added missing static specifiers.
Eran Kornblau <erankor@gmail.com>
parents: 6806
diff changeset
174 static ngx_event_module_t ngx_eventport_module_ctx = {
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
175 &eventport_name,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
176 ngx_eventport_create_conf, /* create configuration */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
177 ngx_eventport_init_conf, /* init configuration */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
178
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
179 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
180 ngx_eventport_add_event, /* add an event */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
181 ngx_eventport_del_event, /* delete an event */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
182 ngx_eventport_add_event, /* enable an event */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
183 ngx_eventport_del_event, /* disable an event */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
184 NULL, /* add an connection */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
185 NULL, /* delete an connection */
6021
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
186 ngx_eventport_notify, /* trigger a notify */
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
187 ngx_eventport_process_events, /* process the events */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
188 ngx_eventport_init, /* init the events */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
189 ngx_eventport_done, /* done the events */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
190 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
191
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
192 };
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
193
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
194 ngx_module_t ngx_eventport_module = {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
195 NGX_MODULE_V1,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
196 &ngx_eventport_module_ctx, /* module context */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
197 ngx_eventport_commands, /* module directives */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
198 NGX_EVENT_MODULE, /* module type */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
199 NULL, /* init master */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
200 NULL, /* init module */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
201 NULL, /* init process */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
202 NULL, /* init thread */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
203 NULL, /* exit thread */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
204 NULL, /* exit process */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
205 NULL, /* exit master */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
206 NGX_MODULE_V1_PADDING
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
207 };
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
208
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
209
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
210 static ngx_int_t
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
211 ngx_eventport_init(ngx_cycle_t *cycle, ngx_msec_t timer)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
212 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
213 port_notify_t pn;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
214 struct itimerspec its;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
215 struct sigevent sev;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
216 ngx_eventport_conf_t *epcf;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
217
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
218 epcf = ngx_event_get_conf(cycle->conf_ctx, ngx_eventport_module);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
219
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
220 if (ep == -1) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
221 ep = port_create();
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
222
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
223 if (ep == -1) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
224 ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
225 "port_create() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
226 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
227 }
6021
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
228
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
229 notify_event.active = 1;
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
230 notify_event.log = cycle->log;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
231 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
232
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
233 if (nevents < epcf->events) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
234 if (event_list) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
235 ngx_free(event_list);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
236 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
237
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
238 event_list = ngx_alloc(sizeof(port_event_t) * epcf->events,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
239 cycle->log);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
240 if (event_list == NULL) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
241 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
242 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
243 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
244
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
245 ngx_event_flags = NGX_USE_EVENTPORT_EVENT;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
246
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
247 if (timer) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
248 ngx_memzero(&pn, sizeof(port_notify_t));
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
249 pn.portnfy_port = ep;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
250
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
251 ngx_memzero(&sev, sizeof(struct sigevent));
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
252 sev.sigev_notify = SIGEV_PORT;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
253 #if !(NGX_TEST_BUILD_EVENTPORT)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
254 sev.sigev_value.sival_ptr = &pn;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
255 #endif
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
256
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
257 if (timer_create(CLOCK_REALTIME, &sev, &event_timer) == -1) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
258 ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
259 "timer_create() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
260 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
261 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
262
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
263 its.it_interval.tv_sec = timer / 1000;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
264 its.it_interval.tv_nsec = (timer % 1000) * 1000000;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
265 its.it_value.tv_sec = timer / 1000;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
266 its.it_value.tv_nsec = (timer % 1000) * 1000000;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
267
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
268 if (timer_settime(event_timer, 0, &its, NULL) == -1) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
269 ngx_log_error(NGX_LOG_EMERG, cycle->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
270 "timer_settime() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
271 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
272 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
273
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
274 ngx_event_flags |= NGX_USE_TIMER_EVENT;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
275 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
276
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
277 nevents = epcf->events;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
278
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
279 ngx_io = ngx_os_io;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
280
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
281 ngx_event_actions = ngx_eventport_module_ctx.actions;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
282
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
283 return NGX_OK;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
284 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
285
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
286
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
287 static void
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
288 ngx_eventport_done(ngx_cycle_t *cycle)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
289 {
1870
a62fb6c156c5 fix building --test-build-rtsig and --test-build-eventport on FreeBSD 7
Igor Sysoev <igor@sysoev.ru>
parents: 1354
diff changeset
290 if (event_timer != (timer_t) -1) {
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
291 if (timer_delete(event_timer) == -1) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
292 ngx_log_error(NGX_LOG_ALERT, cycle->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
293 "timer_delete() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
294 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
295
1870
a62fb6c156c5 fix building --test-build-rtsig and --test-build-eventport on FreeBSD 7
Igor Sysoev <igor@sysoev.ru>
parents: 1354
diff changeset
296 event_timer = (timer_t) -1;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
297 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
298
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
299 if (close(ep) == -1) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
300 ngx_log_error(NGX_LOG_ALERT, cycle->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
301 "close() event port failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
302 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
303
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
304 ep = -1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
305
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
306 ngx_free(event_list);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
307
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
308 event_list = NULL;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
309 nevents = 0;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
310 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
311
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
312
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
313 static ngx_int_t
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
314 ngx_eventport_add_event(ngx_event_t *ev, ngx_int_t event, ngx_uint_t flags)
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
315 {
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
316 ngx_int_t events, prev;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
317 ngx_event_t *e;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
318 ngx_connection_t *c;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
319
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
320 c = ev->data;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
321
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
322 events = event;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
323
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
324 if (event == NGX_READ_EVENT) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
325 e = c->write;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
326 prev = POLLOUT;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
327 #if (NGX_READ_EVENT != POLLIN)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
328 events = POLLIN;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
329 #endif
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
330
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
331 } else {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
332 e = c->read;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
333 prev = POLLIN;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
334 #if (NGX_WRITE_EVENT != POLLOUT)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
335 events = POLLOUT;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
336 #endif
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
337 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
338
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
339 if (e->oneshot) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
340 events |= prev;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
341 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
342
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
343 ngx_log_debug2(NGX_LOG_DEBUG_EVENT, ev->log, 0,
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
344 "eventport add event: fd:%d ev:%04Xi", c->fd, events);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
345
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
346 if (port_associate(ep, PORT_SOURCE_FD, c->fd, events,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
347 (void *) ((uintptr_t) ev | ev->instance))
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
348 == -1)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
349 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
350 ngx_log_error(NGX_LOG_ALERT, ev->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
351 "port_associate() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
352 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
353 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
354
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
355 ev->active = 1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
356 ev->oneshot = 1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
357
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
358 return NGX_OK;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
359 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
360
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
361
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
362 static ngx_int_t
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
363 ngx_eventport_del_event(ngx_event_t *ev, ngx_int_t event, ngx_uint_t flags)
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
364 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
365 ngx_event_t *e;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
366 ngx_connection_t *c;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
367
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
368 /*
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
369 * when the file descriptor is closed, the event port automatically
4572
67653855682e Fixed spelling in multiline C comments.
Ruslan Ermilov <ru@nginx.com>
parents: 4412
diff changeset
370 * dissociates it from the port, so we do not need to dissociate explicitly
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
371 * the event before the closing the file descriptor
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
372 */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
373
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
374 if (flags & NGX_CLOSE_EVENT) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
375 ev->active = 0;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
376 ev->oneshot = 0;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
377 return NGX_OK;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
378 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
379
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
380 c = ev->data;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
381
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
382 if (event == NGX_READ_EVENT) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
383 e = c->write;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
384 event = POLLOUT;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
385
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
386 } else {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
387 e = c->read;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
388 event = POLLIN;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
389 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
390
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
391 if (e->oneshot) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
392 ngx_log_debug2(NGX_LOG_DEBUG_EVENT, ev->log, 0,
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
393 "eventport change event: fd:%d ev:%04Xi", c->fd, event);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
394
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
395 if (port_associate(ep, PORT_SOURCE_FD, c->fd, event,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
396 (void *) ((uintptr_t) ev | ev->instance))
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
397 == -1)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
398 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
399 ngx_log_error(NGX_LOG_ALERT, ev->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
400 "port_associate() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
401 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
402 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
403
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
404 } else {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
405 ngx_log_debug1(NGX_LOG_DEBUG_EVENT, ev->log, 0,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
406 "eventport del event: fd:%d", c->fd);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
407
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
408 if (port_dissociate(ep, PORT_SOURCE_FD, c->fd) == -1) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
409 ngx_log_error(NGX_LOG_ALERT, ev->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
410 "port_dissociate() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
411 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
412 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
413 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
414
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
415 ev->active = 0;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
416 ev->oneshot = 0;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
417
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
418 return NGX_OK;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
419 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
420
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
421
6021
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
422 static ngx_int_t
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
423 ngx_eventport_notify(ngx_event_handler_pt handler)
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
424 {
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
425 notify_event.handler = handler;
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
426
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
427 if (port_send(ep, 0, &notify_event) != 0) {
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
428 ngx_log_error(NGX_LOG_ALERT, notify_event.log, ngx_errno,
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
429 "port_send() failed");
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
430 return NGX_ERROR;
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
431 }
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
432
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
433 return NGX_OK;
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
434 }
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
435
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
436
6923
fbdaad9b0e7b Added missing "static" specifiers found by gcc -Wtraditional.
Ruslan Ermilov <ru@nginx.com>
parents: 6922
diff changeset
437 static ngx_int_t
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
438 ngx_eventport_process_events(ngx_cycle_t *cycle, ngx_msec_t timer,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
439 ngx_uint_t flags)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
440 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
441 int n, revents;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
442 u_int events;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
443 ngx_err_t err;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
444 ngx_int_t instance;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
445 ngx_uint_t i, level;
5821
3f5f0ab59b35 Events: processing of posted events changed from LIFO to FIFO.
Valentin Bartenev <vbart@nginx.com>
parents: 5820
diff changeset
446 ngx_event_t *ev, *rev, *wev;
3f5f0ab59b35 Events: processing of posted events changed from LIFO to FIFO.
Valentin Bartenev <vbart@nginx.com>
parents: 5820
diff changeset
447 ngx_queue_t *queue;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
448 ngx_connection_t *c;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
449 struct timespec ts, *tp;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
450
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
451 if (timer == NGX_TIMER_INFINITE) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
452 tp = NULL;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
453
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
454 } else {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
455 ts.tv_sec = timer / 1000;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
456 ts.tv_nsec = (timer % 1000) * 1000000;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
457 tp = &ts;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
458 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
459
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
460 ngx_log_debug1(NGX_LOG_DEBUG_EVENT, cycle->log, 0,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
461 "eventport timer: %M", timer);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
462
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
463 events = 1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
464
1354
f69d1aab6a0f make 64-bit ngx_int_t on 64-bit platforms
Igor Sysoev <igor@sysoev.ru>
parents: 1287
diff changeset
465 n = port_getn(ep, event_list, (u_int) nevents, &events, tp);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
466
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
467 err = ngx_errno;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
468
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
469 if (flags & NGX_UPDATE_TIME) {
3475
ab353d7dc182 *) introduce ngx_time_sigsafe_update() to update the error log time only
Igor Sysoev <igor@sysoev.ru>
parents: 3474
diff changeset
470 ngx_time_update();
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
471 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
472
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
473 if (n == -1) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
474 if (err == ETIME) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
475 if (timer != NGX_TIMER_INFINITE) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
476 return NGX_OK;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
477 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
478
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
479 ngx_log_error(NGX_LOG_ALERT, cycle->log, 0,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
480 "port_getn() returned no events without timeout");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
481 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
482 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
483
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
484 level = (err == NGX_EINTR) ? NGX_LOG_INFO : NGX_LOG_ALERT;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
485 ngx_log_error(level, cycle->log, err, "port_getn() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
486 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
487 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
488
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
489 if (events == 0) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
490 if (timer != NGX_TIMER_INFINITE) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
491 return NGX_OK;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
492 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
493
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
494 ngx_log_error(NGX_LOG_ALERT, cycle->log, 0,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
495 "port_getn() returned no events without timeout");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
496 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
497 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
498
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
499 for (i = 0; i < events; i++) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
500
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
501 if (event_list[i].portev_source == PORT_SOURCE_TIMER) {
3475
ab353d7dc182 *) introduce ngx_time_sigsafe_update() to update the error log time only
Igor Sysoev <igor@sysoev.ru>
parents: 3474
diff changeset
502 ngx_time_update();
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
503 continue;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
504 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
505
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
506 ev = event_list[i].portev_user;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
507
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
508 switch (event_list[i].portev_source) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
509
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
510 case PORT_SOURCE_FD:
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
511
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
512 instance = (uintptr_t) ev & 1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
513 ev = (ngx_event_t *) ((uintptr_t) ev & (uintptr_t) ~1);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
514
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
515 if (ev->closed || ev->instance != instance) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
516
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
517 /*
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
518 * the stale event from a file descriptor
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
519 * that was just closed in this iteration
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
520 */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
521
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
522 ngx_log_debug1(NGX_LOG_DEBUG_EVENT, cycle->log, 0,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
523 "eventport: stale event %p", ev);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
524 continue;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
525 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
526
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
527 revents = event_list[i].portev_events;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
528
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
529 ngx_log_debug2(NGX_LOG_DEBUG_EVENT, cycle->log, 0,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
530 "eventport: fd:%d, ev:%04Xd",
6479
dc92298b1852 Events: fixed logging.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6475
diff changeset
531 (int) event_list[i].portev_object, revents);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
532
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
533 if (revents & (POLLERR|POLLHUP|POLLNVAL)) {
1128
06479b01caff decrease log level from alert to debug for POLLERR|POLLHUP|POLLNVAL
Igor Sysoev <igor@sysoev.ru>
parents: 929
diff changeset
534 ngx_log_debug2(NGX_LOG_DEBUG_EVENT, cycle->log, 0,
06479b01caff decrease log level from alert to debug for POLLERR|POLLHUP|POLLNVAL
Igor Sysoev <igor@sysoev.ru>
parents: 929
diff changeset
535 "port_getn() error fd:%d ev:%04Xd",
6479
dc92298b1852 Events: fixed logging.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6475
diff changeset
536 (int) event_list[i].portev_object, revents);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
537 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
538
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
539 if (revents & ~(POLLIN|POLLOUT|POLLERR|POLLHUP|POLLNVAL)) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
540 ngx_log_error(NGX_LOG_ALERT, cycle->log, 0,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
541 "strange port_getn() events fd:%d ev:%04Xd",
6479
dc92298b1852 Events: fixed logging.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6475
diff changeset
542 (int) event_list[i].portev_object, revents);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
543 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
544
6806
75dbab4ea930 Events: improved error event handling for UDP sockets.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 6479
diff changeset
545 if (revents & (POLLERR|POLLHUP|POLLNVAL)) {
75dbab4ea930 Events: improved error event handling for UDP sockets.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 6479
diff changeset
546
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
547 /*
6806
75dbab4ea930 Events: improved error event handling for UDP sockets.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 6479
diff changeset
548 * if the error events were returned, add POLLIN and POLLOUT
75dbab4ea930 Events: improved error event handling for UDP sockets.
Dmitry Volyntsev <xeioex@nginx.com>
parents: 6479
diff changeset
549 * to handle the events at least in one active handler
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
550 */
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
551
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
552 revents |= POLLIN|POLLOUT;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
553 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
554
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
555 c = ev->data;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
556 rev = c->read;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
557 wev = c->write;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
558
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
559 rev->active = 0;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
560 wev->active = 0;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
561
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
562 if (revents & POLLIN) {
5820
3377f9459e99 Events: removed broken thread support from posted events.
Valentin Bartenev <vbart@nginx.com>
parents: 5175
diff changeset
563 rev->ready = 1;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
564
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
565 if (flags & NGX_POST_EVENTS) {
5820
3377f9459e99 Events: removed broken thread support from posted events.
Valentin Bartenev <vbart@nginx.com>
parents: 5175
diff changeset
566 queue = rev->accept ? &ngx_posted_accept_events
3377f9459e99 Events: removed broken thread support from posted events.
Valentin Bartenev <vbart@nginx.com>
parents: 5175
diff changeset
567 : &ngx_posted_events;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
568
5820
3377f9459e99 Events: removed broken thread support from posted events.
Valentin Bartenev <vbart@nginx.com>
parents: 5175
diff changeset
569 ngx_post_event(rev, queue);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
570
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
571 } else {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
572 rev->handler(rev);
1287
3dd9883fa121 fix segfault when event port returns POLLERR without POLLIN or POLLOUT
Igor Sysoev <igor@sysoev.ru>
parents: 1128
diff changeset
573
5170
6362bd26e4b0 Events: protection from stale events in eventport and devpoll.
Valentin Bartenev <vbart@nginx.com>
parents: 4759
diff changeset
574 if (ev->closed || ev->instance != instance) {
1287
3dd9883fa121 fix segfault when event port returns POLLERR without POLLIN or POLLOUT
Igor Sysoev <igor@sysoev.ru>
parents: 1128
diff changeset
575 continue;
3dd9883fa121 fix segfault when event port returns POLLERR without POLLIN or POLLOUT
Igor Sysoev <igor@sysoev.ru>
parents: 1128
diff changeset
576 }
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
577 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
578
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
579 if (rev->accept) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
580 if (ngx_use_accept_mutex) {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
581 ngx_accept_events = 1;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
582 continue;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
583 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
584
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
585 if (port_associate(ep, PORT_SOURCE_FD, c->fd, POLLIN,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
586 (void *) ((uintptr_t) ev | ev->instance))
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
587 == -1)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
588 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
589 ngx_log_error(NGX_LOG_ALERT, ev->log, ngx_errno,
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
590 "port_associate() failed");
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
591 return NGX_ERROR;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
592 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
593 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
594 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
595
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
596 if (revents & POLLOUT) {
5820
3377f9459e99 Events: removed broken thread support from posted events.
Valentin Bartenev <vbart@nginx.com>
parents: 5175
diff changeset
597 wev->ready = 1;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
598
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
599 if (flags & NGX_POST_EVENTS) {
5820
3377f9459e99 Events: removed broken thread support from posted events.
Valentin Bartenev <vbart@nginx.com>
parents: 5175
diff changeset
600 ngx_post_event(wev, &ngx_posted_events);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
601
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
602 } else {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
603 wev->handler(wev);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
604 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
605 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
606
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
607 continue;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
608
6021
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
609 case PORT_SOURCE_USER:
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
610
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
611 ev->handler(ev);
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
612
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
613 continue;
117c77b22db1 Events: implemented eventport notification mechanism.
Ruslan Ermilov <ru@nginx.com>
parents: 6018
diff changeset
614
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
615 default:
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
616 ngx_log_error(NGX_LOG_ALERT, cycle->log, 0,
6005
d84f0abd4a53 Events: fixed typo in the error message.
Ruslan Ermilov <ru@nginx.com>
parents: 5821
diff changeset
617 "unexpected eventport object %d",
6479
dc92298b1852 Events: fixed logging.
Sergey Kandaurov <pluknet@nginx.com>
parents: 6475
diff changeset
618 (int) event_list[i].portev_object);
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
619 continue;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
620 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
621 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
622
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
623 return NGX_OK;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
624 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
625
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
626
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
627 static void *
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
628 ngx_eventport_create_conf(ngx_cycle_t *cycle)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
629 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
630 ngx_eventport_conf_t *epcf;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
631
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
632 epcf = ngx_palloc(cycle->pool, sizeof(ngx_eventport_conf_t));
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
633 if (epcf == NULL) {
2912
c7d57b539248 return NULL instead of NGX_CONF_ERROR on a create conf failure
Igor Sysoev <igor@sysoev.ru>
parents: 1939
diff changeset
634 return NULL;
719
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
635 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
636
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
637 epcf->events = NGX_CONF_UNSET;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
638
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
639 return epcf;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
640 }
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
641
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
642
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
643 static char *
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
644 ngx_eventport_init_conf(ngx_cycle_t *cycle, void *conf)
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
645 {
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
646 ngx_eventport_conf_t *epcf = conf;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
647
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
648 ngx_conf_init_uint_value(epcf->events, 32);
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
649
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
650 return NGX_CONF_OK;
f30b1a75fd3b Solaris 10 event ports support
Igor Sysoev <igor@sysoev.ru>
parents:
diff changeset
651 }