xref: /libuv/include/uv/unix.h (revision 51a22f60)
1 /* Copyright Joyent, Inc. and other Node contributors. All rights reserved.
2  *
3  * Permission is hereby granted, free of charge, to any person obtaining a copy
4  * of this software and associated documentation files (the "Software"), to
5  * deal in the Software without restriction, including without limitation the
6  * rights to use, copy, modify, merge, publish, distribute, sublicense, and/or
7  * sell copies of the Software, and to permit persons to whom the Software is
8  * furnished to do so, subject to the following conditions:
9  *
10  * The above copyright notice and this permission notice shall be included in
11  * all copies or substantial portions of the Software.
12  *
13  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
18  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
19  * IN THE SOFTWARE.
20  */
21 
22 #ifndef UV_UNIX_H
23 #define UV_UNIX_H
24 
25 #include <sys/types.h>
26 #include <sys/stat.h>
27 #include <fcntl.h>
28 #include <dirent.h>
29 
30 #include <sys/socket.h>
31 #include <netinet/in.h>
32 #include <netinet/tcp.h>
33 #include <arpa/inet.h>
34 #include <netdb.h>  /* MAXHOSTNAMELEN on Solaris */
35 
36 #include <termios.h>
37 #include <pwd.h>
38 
39 #if !defined(__MVS__)
40 #include <semaphore.h>
41 #include <sys/param.h> /* MAXHOSTNAMELEN on Linux and the BSDs */
42 #endif
43 #include <pthread.h>
44 #include <signal.h>
45 
46 #include "uv/threadpool.h"
47 
48 #if defined(__linux__)
49 # include "uv/linux.h"
50 #elif defined (__MVS__)
51 # include "uv/os390.h"
52 #elif defined(__PASE__)  /* __PASE__ and _AIX are both defined on IBM i */
53 # include "uv/posix.h"  /* IBM i needs uv/posix.h, not uv/aix.h */
54 #elif defined(_AIX)
55 # include "uv/aix.h"
56 #elif defined(__sun)
57 # include "uv/sunos.h"
58 #elif defined(__APPLE__)
59 # include "uv/darwin.h"
60 #elif defined(__DragonFly__)       || \
61       defined(__FreeBSD__)         || \
62       defined(__OpenBSD__)         || \
63       defined(__NetBSD__)
64 # include "uv/bsd.h"
65 #elif defined(__CYGWIN__) || \
66       defined(__MSYS__)   || \
67       defined(__HAIKU__)  || \
68       defined(__QNX__)    || \
69       defined(__GNU__)
70 # include "uv/posix.h"
71 #endif
72 
73 #ifndef NI_MAXHOST
74 # define NI_MAXHOST 1025
75 #endif
76 
77 #ifndef NI_MAXSERV
78 # define NI_MAXSERV 32
79 #endif
80 
81 #ifndef UV_IO_PRIVATE_PLATFORM_FIELDS
82 # define UV_IO_PRIVATE_PLATFORM_FIELDS /* empty */
83 #endif
84 
85 struct uv__io_s;
86 struct uv_loop_s;
87 
88 typedef void (*uv__io_cb)(struct uv_loop_s* loop,
89                           struct uv__io_s* w,
90                           unsigned int events);
91 typedef struct uv__io_s uv__io_t;
92 
93 struct uv__io_s {
94   uv__io_cb cb;
95   struct uv__queue pending_queue;
96   struct uv__queue watcher_queue;
97   unsigned int pevents; /* Pending event mask i.e. mask at next tick. */
98   unsigned int events;  /* Current event mask. */
99   int fd;
100   UV_IO_PRIVATE_PLATFORM_FIELDS
101 };
102 
103 #ifndef UV_PLATFORM_SEM_T
104 # define UV_PLATFORM_SEM_T sem_t
105 #endif
106 
107 #ifndef UV_PLATFORM_LOOP_FIELDS
108 # define UV_PLATFORM_LOOP_FIELDS /* empty */
109 #endif
110 
111 #ifndef UV_PLATFORM_FS_EVENT_FIELDS
112 # define UV_PLATFORM_FS_EVENT_FIELDS /* empty */
113 #endif
114 
115 #ifndef UV_STREAM_PRIVATE_PLATFORM_FIELDS
116 # define UV_STREAM_PRIVATE_PLATFORM_FIELDS /* empty */
117 #endif
118 
119 /* Note: May be cast to struct iovec. See writev(2). */
120 typedef struct uv_buf_t {
121   char* base;
122   size_t len;
123 } uv_buf_t;
124 
125 typedef int uv_file;
126 typedef int uv_os_sock_t;
127 typedef int uv_os_fd_t;
128 typedef pid_t uv_pid_t;
129 
130 #define UV_ONCE_INIT PTHREAD_ONCE_INIT
131 
132 typedef pthread_once_t uv_once_t;
133 typedef pthread_t uv_thread_t;
134 typedef pthread_mutex_t uv_mutex_t;
135 typedef pthread_rwlock_t uv_rwlock_t;
136 typedef UV_PLATFORM_SEM_T uv_sem_t;
137 typedef pthread_cond_t uv_cond_t;
138 typedef pthread_key_t uv_key_t;
139 
140 /* Note: guard clauses should match uv_barrier_init's in src/unix/thread.c. */
141 #if defined(_AIX) || \
142     defined(__OpenBSD__) || \
143     !defined(PTHREAD_BARRIER_SERIAL_THREAD)
144 /* TODO(bnoordhuis) Merge into uv_barrier_t in v2. */
145 struct _uv_barrier {
146   uv_mutex_t mutex;
147   uv_cond_t cond;
148   unsigned threshold;
149   unsigned in;
150   unsigned out;
151 };
152 
153 typedef struct {
154   struct _uv_barrier* b;
155 # if defined(PTHREAD_BARRIER_SERIAL_THREAD)
156   /* TODO(bnoordhuis) Remove padding in v2. */
157   char pad[sizeof(pthread_barrier_t) - sizeof(struct _uv_barrier*)];
158 # endif
159 } uv_barrier_t;
160 #else
161 typedef pthread_barrier_t uv_barrier_t;
162 #endif
163 
164 /* Platform-specific definitions for uv_spawn support. */
165 typedef gid_t uv_gid_t;
166 typedef uid_t uv_uid_t;
167 
168 typedef struct dirent uv__dirent_t;
169 
170 #define UV_DIR_PRIVATE_FIELDS \
171   DIR* dir;
172 
173 #if defined(DT_UNKNOWN)
174 # define HAVE_DIRENT_TYPES
175 # if defined(DT_REG)
176 #  define UV__DT_FILE DT_REG
177 # else
178 #  define UV__DT_FILE -1
179 # endif
180 # if defined(DT_DIR)
181 #  define UV__DT_DIR DT_DIR
182 # else
183 #  define UV__DT_DIR -2
184 # endif
185 # if defined(DT_LNK)
186 #  define UV__DT_LINK DT_LNK
187 # else
188 #  define UV__DT_LINK -3
189 # endif
190 # if defined(DT_FIFO)
191 #  define UV__DT_FIFO DT_FIFO
192 # else
193 #  define UV__DT_FIFO -4
194 # endif
195 # if defined(DT_SOCK)
196 #  define UV__DT_SOCKET DT_SOCK
197 # else
198 #  define UV__DT_SOCKET -5
199 # endif
200 # if defined(DT_CHR)
201 #  define UV__DT_CHAR DT_CHR
202 # else
203 #  define UV__DT_CHAR -6
204 # endif
205 # if defined(DT_BLK)
206 #  define UV__DT_BLOCK DT_BLK
207 # else
208 #  define UV__DT_BLOCK -7
209 # endif
210 #endif
211 
212 /* Platform-specific definitions for uv_dlopen support. */
213 #define UV_DYNAMIC /* empty */
214 
215 typedef struct {
216   void* handle;
217   char* errmsg;
218 } uv_lib_t;
219 
220 #define UV_LOOP_PRIVATE_FIELDS                                                \
221   unsigned long flags;                                                        \
222   int backend_fd;                                                             \
223   struct uv__queue pending_queue;                                             \
224   struct uv__queue watcher_queue;                                             \
225   uv__io_t** watchers;                                                        \
226   unsigned int nwatchers;                                                     \
227   unsigned int nfds;                                                          \
228   struct uv__queue wq;                                                        \
229   uv_mutex_t wq_mutex;                                                        \
230   uv_async_t wq_async;                                                        \
231   uv_rwlock_t cloexec_lock;                                                   \
232   uv_handle_t* closing_handles;                                               \
233   struct uv__queue process_handles;                                           \
234   struct uv__queue prepare_handles;                                           \
235   struct uv__queue check_handles;                                             \
236   struct uv__queue idle_handles;                                              \
237   struct uv__queue async_handles;                                             \
238   void (*async_unused)(void);  /* TODO(bnoordhuis) Remove in libuv v2. */     \
239   uv__io_t async_io_watcher;                                                  \
240   int async_wfd;                                                              \
241   struct {                                                                    \
242     void* min;                                                                \
243     unsigned int nelts;                                                       \
244   } timer_heap;                                                               \
245   uint64_t timer_counter;                                                     \
246   uint64_t time;                                                              \
247   int signal_pipefd[2];                                                       \
248   uv__io_t signal_io_watcher;                                                 \
249   uv_signal_t child_watcher;                                                  \
250   int emfile_fd;                                                              \
251   UV_PLATFORM_LOOP_FIELDS                                                     \
252 
253 #define UV_REQ_TYPE_PRIVATE /* empty */
254 
255 #define UV_REQ_PRIVATE_FIELDS  /* empty */
256 
257 #define UV_PRIVATE_REQ_TYPES /* empty */
258 
259 #define UV_WRITE_PRIVATE_FIELDS                                               \
260   struct uv__queue queue;                                                     \
261   unsigned int write_index;                                                   \
262   uv_buf_t* bufs;                                                             \
263   unsigned int nbufs;                                                         \
264   int error;                                                                  \
265   uv_buf_t bufsml[4];                                                         \
266 
267 #define UV_CONNECT_PRIVATE_FIELDS                                             \
268   struct uv__queue queue;                                                     \
269 
270 #define UV_SHUTDOWN_PRIVATE_FIELDS /* empty */
271 
272 #define UV_UDP_SEND_PRIVATE_FIELDS                                            \
273   struct uv__queue queue;                                                     \
274   struct sockaddr_storage addr;                                               \
275   unsigned int nbufs;                                                         \
276   uv_buf_t* bufs;                                                             \
277   ssize_t status;                                                             \
278   uv_udp_send_cb send_cb;                                                     \
279   uv_buf_t bufsml[4];                                                         \
280 
281 #define UV_HANDLE_PRIVATE_FIELDS                                              \
282   uv_handle_t* next_closing;                                                  \
283   unsigned int flags;                                                         \
284 
285 #define UV_STREAM_PRIVATE_FIELDS                                              \
286   uv_connect_t *connect_req;                                                  \
287   uv_shutdown_t *shutdown_req;                                                \
288   uv__io_t io_watcher;                                                        \
289   struct uv__queue write_queue;                                               \
290   struct uv__queue write_completed_queue;                                     \
291   uv_connection_cb connection_cb;                                             \
292   int delayed_error;                                                          \
293   int accepted_fd;                                                            \
294   void* queued_fds;                                                           \
295   UV_STREAM_PRIVATE_PLATFORM_FIELDS                                           \
296 
297 #define UV_TCP_PRIVATE_FIELDS /* empty */
298 
299 #define UV_UDP_PRIVATE_FIELDS                                                 \
300   uv_alloc_cb alloc_cb;                                                       \
301   uv_udp_recv_cb recv_cb;                                                     \
302   uv__io_t io_watcher;                                                        \
303   struct uv__queue write_queue;                                               \
304   struct uv__queue write_completed_queue;                                     \
305 
306 #define UV_PIPE_PRIVATE_FIELDS                                                \
307   const char* pipe_fname; /* NULL or strdup'ed */
308 
309 #define UV_POLL_PRIVATE_FIELDS                                                \
310   uv__io_t io_watcher;
311 
312 #define UV_PREPARE_PRIVATE_FIELDS                                             \
313   uv_prepare_cb prepare_cb;                                                   \
314   struct uv__queue queue;                                                     \
315 
316 #define UV_CHECK_PRIVATE_FIELDS                                               \
317   uv_check_cb check_cb;                                                       \
318   struct uv__queue queue;                                                     \
319 
320 #define UV_IDLE_PRIVATE_FIELDS                                                \
321   uv_idle_cb idle_cb;                                                         \
322   struct uv__queue queue;                                                     \
323 
324 #define UV_ASYNC_PRIVATE_FIELDS                                               \
325   uv_async_cb async_cb;                                                       \
326   struct uv__queue queue;                                                     \
327   int pending;                                                                \
328 
329 #define UV_TIMER_PRIVATE_FIELDS                                               \
330   uv_timer_cb timer_cb;                                                       \
331   union {                                                                     \
332     void* heap[3];                                                            \
333     struct uv__queue queue;                                                   \
334   } node;                                                                     \
335   uint64_t timeout;                                                           \
336   uint64_t repeat;                                                            \
337   uint64_t start_id;
338 
339 #define UV_GETADDRINFO_PRIVATE_FIELDS                                         \
340   struct uv__work work_req;                                                   \
341   uv_getaddrinfo_cb cb;                                                       \
342   struct addrinfo* hints;                                                     \
343   char* hostname;                                                             \
344   char* service;                                                              \
345   struct addrinfo* addrinfo;                                                  \
346   int retcode;
347 
348 #define UV_GETNAMEINFO_PRIVATE_FIELDS                                         \
349   struct uv__work work_req;                                                   \
350   uv_getnameinfo_cb getnameinfo_cb;                                           \
351   struct sockaddr_storage storage;                                            \
352   int flags;                                                                  \
353   char host[NI_MAXHOST];                                                      \
354   char service[NI_MAXSERV];                                                   \
355   int retcode;
356 
357 #define UV_PROCESS_PRIVATE_FIELDS                                             \
358   struct uv__queue queue;                                                     \
359   int status;                                                                 \
360 
361 #define UV_FS_PRIVATE_FIELDS                                                  \
362   const char *new_path;                                                       \
363   uv_file file;                                                               \
364   int flags;                                                                  \
365   mode_t mode;                                                                \
366   unsigned int nbufs;                                                         \
367   uv_buf_t* bufs;                                                             \
368   off_t off;                                                                  \
369   uv_uid_t uid;                                                               \
370   uv_gid_t gid;                                                               \
371   double atime;                                                               \
372   double mtime;                                                               \
373   struct uv__work work_req;                                                   \
374   uv_buf_t bufsml[4];                                                         \
375 
376 #define UV_WORK_PRIVATE_FIELDS                                                \
377   struct uv__work work_req;
378 
379 #define UV_TTY_PRIVATE_FIELDS                                                 \
380   struct termios orig_termios;                                                \
381   int mode;
382 
383 #define UV_SIGNAL_PRIVATE_FIELDS                                              \
384   /* RB_ENTRY(uv_signal_s) tree_entry; */                                     \
385   struct {                                                                    \
386     struct uv_signal_s* rbe_left;                                             \
387     struct uv_signal_s* rbe_right;                                            \
388     struct uv_signal_s* rbe_parent;                                           \
389     int rbe_color;                                                            \
390   } tree_entry;                                                               \
391   /* Use two counters here so we don have to fiddle with atomics. */          \
392   unsigned int caught_signals;                                                \
393   unsigned int dispatched_signals;
394 
395 #define UV_FS_EVENT_PRIVATE_FIELDS                                            \
396   uv_fs_event_cb cb;                                                          \
397   UV_PLATFORM_FS_EVENT_FIELDS                                                 \
398 
399 /* fs open() flags supported on this platform: */
400 #if defined(O_APPEND)
401 # define UV_FS_O_APPEND       O_APPEND
402 #else
403 # define UV_FS_O_APPEND       0
404 #endif
405 #if defined(O_CREAT)
406 # define UV_FS_O_CREAT        O_CREAT
407 #else
408 # define UV_FS_O_CREAT        0
409 #endif
410 
411 #if defined(__linux__) && defined(__arm__)
412 # define UV_FS_O_DIRECT       0x10000
413 #elif defined(__linux__) && defined(__m68k__)
414 # define UV_FS_O_DIRECT       0x10000
415 #elif defined(__linux__) && defined(__mips__)
416 # define UV_FS_O_DIRECT       0x08000
417 #elif defined(__linux__) && defined(__powerpc__)
418 # define UV_FS_O_DIRECT       0x20000
419 #elif defined(__linux__) && defined(__s390x__)
420 # define UV_FS_O_DIRECT       0x04000
421 #elif defined(__linux__) && defined(__x86_64__)
422 # define UV_FS_O_DIRECT       0x04000
423 #elif defined(__linux__) && defined(__loongarch__)
424 # define UV_FS_O_DIRECT       0x04000
425 #elif defined(O_DIRECT)
426 # define UV_FS_O_DIRECT       O_DIRECT
427 #else
428 # define UV_FS_O_DIRECT       0
429 #endif
430 
431 #if defined(O_DIRECTORY)
432 # define UV_FS_O_DIRECTORY    O_DIRECTORY
433 #else
434 # define UV_FS_O_DIRECTORY    0
435 #endif
436 #if defined(O_DSYNC)
437 # define UV_FS_O_DSYNC        O_DSYNC
438 #else
439 # define UV_FS_O_DSYNC        0
440 #endif
441 #if defined(O_EXCL)
442 # define UV_FS_O_EXCL         O_EXCL
443 #else
444 # define UV_FS_O_EXCL         0
445 #endif
446 #if defined(O_EXLOCK)
447 # define UV_FS_O_EXLOCK       O_EXLOCK
448 #else
449 # define UV_FS_O_EXLOCK       0
450 #endif
451 #if defined(O_NOATIME)
452 # define UV_FS_O_NOATIME      O_NOATIME
453 #else
454 # define UV_FS_O_NOATIME      0
455 #endif
456 #if defined(O_NOCTTY)
457 # define UV_FS_O_NOCTTY       O_NOCTTY
458 #else
459 # define UV_FS_O_NOCTTY       0
460 #endif
461 #if defined(O_NOFOLLOW)
462 # define UV_FS_O_NOFOLLOW     O_NOFOLLOW
463 #else
464 # define UV_FS_O_NOFOLLOW     0
465 #endif
466 #if defined(O_NONBLOCK)
467 # define UV_FS_O_NONBLOCK     O_NONBLOCK
468 #else
469 # define UV_FS_O_NONBLOCK     0
470 #endif
471 #if defined(O_RDONLY)
472 # define UV_FS_O_RDONLY       O_RDONLY
473 #else
474 # define UV_FS_O_RDONLY       0
475 #endif
476 #if defined(O_RDWR)
477 # define UV_FS_O_RDWR         O_RDWR
478 #else
479 # define UV_FS_O_RDWR         0
480 #endif
481 #if defined(O_SYMLINK)
482 # define UV_FS_O_SYMLINK      O_SYMLINK
483 #else
484 # define UV_FS_O_SYMLINK      0
485 #endif
486 #if defined(O_SYNC)
487 # define UV_FS_O_SYNC         O_SYNC
488 #else
489 # define UV_FS_O_SYNC         0
490 #endif
491 #if defined(O_TRUNC)
492 # define UV_FS_O_TRUNC        O_TRUNC
493 #else
494 # define UV_FS_O_TRUNC        0
495 #endif
496 #if defined(O_WRONLY)
497 # define UV_FS_O_WRONLY       O_WRONLY
498 #else
499 # define UV_FS_O_WRONLY       0
500 #endif
501 
502 /* fs open() flags supported on other platforms: */
503 #define UV_FS_O_FILEMAP       0
504 #define UV_FS_O_RANDOM        0
505 #define UV_FS_O_SHORT_LIVED   0
506 #define UV_FS_O_SEQUENTIAL    0
507 #define UV_FS_O_TEMPORARY     0
508 
509 #endif /* UV_UNIX_H */
510