1 | //===-- sanitizer_platform_limits_posix.h ---------------------------------===// |
2 | // |
3 | // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. |
4 | // See https://llvm.org/LICENSE.txt for license information. |
5 | // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception |
6 | // |
7 | //===----------------------------------------------------------------------===// |
8 | // |
9 | // This file is a part of Sanitizer common code. |
10 | // |
11 | // Sizes and layouts of platform-specific POSIX data structures. |
12 | //===----------------------------------------------------------------------===// |
13 | |
14 | #ifndef SANITIZER_PLATFORM_LIMITS_POSIX_H |
15 | #define SANITIZER_PLATFORM_LIMITS_POSIX_H |
16 | |
17 | #if SANITIZER_LINUX || SANITIZER_APPLE || SANITIZER_HAIKU |
18 | |
19 | #include "sanitizer_internal_defs.h" |
20 | #include "sanitizer_platform.h" |
21 | #include "sanitizer_mallinfo.h" |
22 | |
23 | #if SANITIZER_APPLE |
24 | #include <sys/cdefs.h> |
25 | #if !__DARWIN_ONLY_64_BIT_INO_T |
26 | #define SANITIZER_HAS_STAT64 1 |
27 | #define SANITIZER_HAS_STATFS64 1 |
28 | #else |
29 | #define SANITIZER_HAS_STAT64 0 |
30 | #define SANITIZER_HAS_STATFS64 0 |
31 | #endif |
32 | #elif SANITIZER_GLIBC || SANITIZER_ANDROID |
33 | #define SANITIZER_HAS_STAT64 1 |
34 | #define SANITIZER_HAS_STATFS64 1 |
35 | #endif |
36 | |
37 | #if defined(__sparc__) |
38 | // FIXME: This can't be included from tsan which does not support sparc yet. |
39 | #include "sanitizer_glibc_version.h" |
40 | #endif |
41 | |
42 | # define GET_LINK_MAP_BY_DLOPEN_HANDLE(handle) ((link_map*)(handle)) |
43 | |
44 | namespace __sanitizer { |
45 | extern unsigned struct_utsname_sz; |
46 | extern unsigned struct_stat_sz; |
47 | #if SANITIZER_HAS_STAT64 |
48 | extern unsigned struct_stat64_sz; |
49 | #endif |
50 | extern unsigned struct_rusage_sz; |
51 | extern unsigned siginfo_t_sz; |
52 | extern unsigned struct_itimerval_sz; |
53 | extern unsigned pthread_t_sz; |
54 | extern unsigned pthread_mutex_t_sz; |
55 | extern unsigned pthread_cond_t_sz; |
56 | extern unsigned pid_t_sz; |
57 | extern unsigned timeval_sz; |
58 | extern unsigned uid_t_sz; |
59 | extern unsigned gid_t_sz; |
60 | extern unsigned mbstate_t_sz; |
61 | extern unsigned struct_timezone_sz; |
62 | extern unsigned struct_tms_sz; |
63 | extern unsigned struct_itimerspec_sz; |
64 | extern unsigned struct_sigevent_sz; |
65 | extern unsigned struct_stack_t_sz; |
66 | extern unsigned struct_sched_param_sz; |
67 | #if SANITIZER_HAS_STATFS64 |
68 | extern unsigned struct_statfs64_sz; |
69 | #endif |
70 | extern unsigned struct_regex_sz; |
71 | extern unsigned struct_regmatch_sz; |
72 | |
73 | #if !SANITIZER_ANDROID |
74 | extern unsigned struct_fstab_sz; |
75 | extern unsigned struct_statfs_sz; |
76 | extern unsigned struct_sockaddr_sz; |
77 | unsigned ucontext_t_sz(void *uctx); |
78 | # endif // !SANITIZER_ANDROID |
79 | |
80 | # if SANITIZER_LINUX |
81 | |
82 | # if defined(__x86_64__) |
83 | const unsigned struct_kernel_stat_sz = 144; |
84 | const unsigned struct_kernel_stat64_sz = 0; |
85 | #elif defined(__i386__) |
86 | const unsigned struct_kernel_stat_sz = 64; |
87 | const unsigned struct_kernel_stat64_sz = 96; |
88 | #elif defined(__arm__) |
89 | const unsigned struct_kernel_stat_sz = 64; |
90 | const unsigned struct_kernel_stat64_sz = 104; |
91 | #elif defined(__aarch64__) |
92 | const unsigned struct_kernel_stat_sz = 128; |
93 | const unsigned struct_kernel_stat64_sz = 104; |
94 | #elif defined(__powerpc__) && !defined(__powerpc64__) |
95 | const unsigned struct_kernel_stat_sz = 72; |
96 | const unsigned struct_kernel_stat64_sz = 104; |
97 | #elif defined(__powerpc64__) |
98 | const unsigned struct_kernel_stat_sz = 144; |
99 | const unsigned struct_kernel_stat64_sz = 104; |
100 | #elif defined(__mips__) |
101 | const unsigned struct_kernel_stat_sz = SANITIZER_ANDROID |
102 | ? FIRST_32_SECOND_64(104, 128) |
103 | # if defined(_ABIN32) && _MIPS_SIM == _ABIN32 |
104 | : FIRST_32_SECOND_64(176, 216); |
105 | # else |
106 | : FIRST_32_SECOND_64(160, 216); |
107 | # endif |
108 | const unsigned struct_kernel_stat64_sz = 104; |
109 | #elif defined(__s390__) && !defined(__s390x__) |
110 | const unsigned struct_kernel_stat_sz = 64; |
111 | const unsigned struct_kernel_stat64_sz = 104; |
112 | #elif defined(__s390x__) |
113 | const unsigned struct_kernel_stat_sz = 144; |
114 | const unsigned struct_kernel_stat64_sz = 0; |
115 | #elif defined(__sparc__) && defined(__arch64__) |
116 | const unsigned struct___old_kernel_stat_sz = 0; |
117 | const unsigned struct_kernel_stat_sz = 104; |
118 | const unsigned struct_kernel_stat64_sz = 144; |
119 | #elif defined(__sparc__) && !defined(__arch64__) |
120 | const unsigned struct___old_kernel_stat_sz = 0; |
121 | const unsigned struct_kernel_stat_sz = 64; |
122 | const unsigned struct_kernel_stat64_sz = 104; |
123 | #elif SANITIZER_RISCV64 |
124 | const unsigned struct_kernel_stat_sz = 128; |
125 | const unsigned struct_kernel_stat64_sz = 0; // RISCV64 does not use stat64 |
126 | # elif defined(__hexagon__) |
127 | const unsigned struct_kernel_stat_sz = 128; |
128 | const unsigned struct_kernel_stat64_sz = 0; |
129 | # elif defined(__loongarch__) |
130 | const unsigned struct_kernel_stat_sz = 128; |
131 | const unsigned struct_kernel_stat64_sz = 0; |
132 | # endif |
133 | struct __sanitizer_perf_event_attr { |
134 | unsigned type; |
135 | unsigned size; |
136 | // More fields that vary with the kernel version. |
137 | }; |
138 | |
139 | extern unsigned struct_epoll_event_sz; |
140 | extern unsigned struct_sysinfo_sz; |
141 | extern unsigned ; |
142 | extern unsigned __user_cap_data_struct_sz(void *hdrp); |
143 | extern unsigned struct_new_utsname_sz; |
144 | extern unsigned struct_old_utsname_sz; |
145 | extern unsigned struct_oldold_utsname_sz; |
146 | |
147 | const unsigned struct_kexec_segment_sz = 4 * sizeof(unsigned long); |
148 | #endif // SANITIZER_LINUX |
149 | |
150 | #if SANITIZER_LINUX |
151 | |
152 | #if defined(__powerpc64__) || defined(__s390__) || defined(__loongarch__) |
153 | const unsigned struct___old_kernel_stat_sz = 0; |
154 | #elif !defined(__sparc__) |
155 | const unsigned struct___old_kernel_stat_sz = 32; |
156 | #endif |
157 | |
158 | extern unsigned struct_rlimit_sz; |
159 | extern unsigned struct_utimbuf_sz; |
160 | extern unsigned struct_timespec_sz; |
161 | |
162 | struct __sanitizer_iocb { |
163 | u64 aio_data; |
164 | u32 aio_key_or_aio_reserved1; // Simply crazy. |
165 | u32 aio_reserved1_or_aio_key; // Luckily, we don't need these. |
166 | u16 aio_lio_opcode; |
167 | s16 aio_reqprio; |
168 | u32 aio_fildes; |
169 | u64 aio_buf; |
170 | u64 aio_nbytes; |
171 | s64 aio_offset; |
172 | u64 aio_reserved2; |
173 | u64 aio_reserved3; |
174 | }; |
175 | |
176 | struct __sanitizer_io_event { |
177 | u64 data; |
178 | u64 obj; |
179 | u64 res; |
180 | u64 res2; |
181 | }; |
182 | |
183 | const unsigned iocb_cmd_pread = 0; |
184 | const unsigned iocb_cmd_pwrite = 1; |
185 | const unsigned iocb_cmd_preadv = 7; |
186 | const unsigned iocb_cmd_pwritev = 8; |
187 | |
188 | struct __sanitizer___sysctl_args { |
189 | int *name; |
190 | int nlen; |
191 | void *oldval; |
192 | uptr *oldlenp; |
193 | void *newval; |
194 | uptr newlen; |
195 | unsigned long ___unused[4]; |
196 | }; |
197 | |
198 | const unsigned old_sigset_t_sz = sizeof(unsigned long); |
199 | |
200 | struct __sanitizer_sem_t { |
201 | #if SANITIZER_ANDROID && defined(_LP64) |
202 | int data[4]; |
203 | #elif SANITIZER_ANDROID && !defined(_LP64) |
204 | int data; |
205 | #elif SANITIZER_LINUX |
206 | uptr data[4]; |
207 | #endif |
208 | }; |
209 | #endif // SANITIZER_LINUX |
210 | |
211 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
212 | extern unsigned struct_ustat_sz; |
213 | extern unsigned struct_rlimit64_sz; |
214 | extern unsigned struct_statvfs64_sz; |
215 | |
216 | struct __sanitizer_ipc_perm { |
217 | int __key; |
218 | int uid; |
219 | int gid; |
220 | int cuid; |
221 | int cgid; |
222 | #ifdef __powerpc__ |
223 | unsigned mode; |
224 | unsigned __seq; |
225 | u64 __unused1; |
226 | u64 __unused2; |
227 | #elif defined(__sparc__) |
228 | unsigned mode; |
229 | unsigned short __pad2; |
230 | unsigned short __seq; |
231 | unsigned long long __unused1; |
232 | unsigned long long __unused2; |
233 | #else |
234 | unsigned int mode; |
235 | unsigned short __seq; |
236 | unsigned short __pad2; |
237 | #if defined(__x86_64__) && !defined(_LP64) |
238 | u64 __unused1; |
239 | u64 __unused2; |
240 | #else |
241 | unsigned long __unused1; |
242 | unsigned long __unused2; |
243 | #endif |
244 | #endif |
245 | }; |
246 | |
247 | struct __sanitizer_shmid_ds { |
248 | __sanitizer_ipc_perm shm_perm; |
249 | #if defined(__sparc__) |
250 | #if !defined(__arch64__) |
251 | u32 __pad1; |
252 | #endif |
253 | long shm_atime; |
254 | #if !defined(__arch64__) |
255 | u32 __pad2; |
256 | #endif |
257 | long shm_dtime; |
258 | #if !defined(__arch64__) |
259 | u32 __pad3; |
260 | #endif |
261 | long shm_ctime; |
262 | uptr shm_segsz; |
263 | int shm_cpid; |
264 | int shm_lpid; |
265 | unsigned long shm_nattch; |
266 | unsigned long __glibc_reserved1; |
267 | unsigned long __glibc_reserved2; |
268 | #else |
269 | #ifndef __powerpc__ |
270 | uptr shm_segsz; |
271 | #elif !defined(__powerpc64__) |
272 | uptr __unused0; |
273 | #endif |
274 | #if defined(__x86_64__) && !defined(_LP64) |
275 | u64 shm_atime; |
276 | u64 shm_dtime; |
277 | u64 shm_ctime; |
278 | #else |
279 | uptr shm_atime; |
280 | #if !defined(_LP64) && !defined(__mips__) |
281 | uptr __unused1; |
282 | #endif |
283 | uptr shm_dtime; |
284 | #if !defined(_LP64) && !defined(__mips__) |
285 | uptr __unused2; |
286 | #endif |
287 | uptr shm_ctime; |
288 | #if !defined(_LP64) && !defined(__mips__) |
289 | uptr __unused3; |
290 | #endif |
291 | #endif |
292 | #ifdef __powerpc__ |
293 | uptr shm_segsz; |
294 | #endif |
295 | int shm_cpid; |
296 | int shm_lpid; |
297 | #if defined(__x86_64__) && !defined(_LP64) |
298 | u64 shm_nattch; |
299 | u64 __unused4; |
300 | u64 __unused5; |
301 | #else |
302 | uptr shm_nattch; |
303 | uptr __unused4; |
304 | uptr __unused5; |
305 | #endif |
306 | #endif |
307 | }; |
308 | #endif |
309 | |
310 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
311 | extern unsigned struct_msqid_ds_sz; |
312 | extern unsigned struct_mq_attr_sz; |
313 | extern unsigned struct_timex_sz; |
314 | extern unsigned struct_statvfs_sz; |
315 | #endif // SANITIZER_LINUX && !SANITIZER_ANDROID |
316 | |
317 | struct __sanitizer_iovec { |
318 | void *iov_base; |
319 | usize iov_len; |
320 | }; |
321 | |
322 | #if !SANITIZER_ANDROID |
323 | struct __sanitizer_ifaddrs { |
324 | struct __sanitizer_ifaddrs *ifa_next; |
325 | char *ifa_name; |
326 | unsigned int ifa_flags; |
327 | void *ifa_addr; // (struct sockaddr *) |
328 | void *ifa_netmask; // (struct sockaddr *) |
329 | // This is a union on Linux. |
330 | # ifdef ifa_dstaddr |
331 | # undef ifa_dstaddr |
332 | # endif |
333 | void *ifa_dstaddr; // (struct sockaddr *) |
334 | void *ifa_data; |
335 | }; |
336 | #endif // !SANITIZER_ANDROID |
337 | |
338 | #if SANITIZER_APPLE |
339 | typedef unsigned long __sanitizer_pthread_key_t; |
340 | #else |
341 | typedef unsigned __sanitizer_pthread_key_t; |
342 | #endif |
343 | |
344 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
345 | |
346 | struct __sanitizer_XDR { |
347 | int x_op; |
348 | void *x_ops; |
349 | uptr x_public; |
350 | uptr x_private; |
351 | uptr x_base; |
352 | unsigned x_handy; |
353 | }; |
354 | |
355 | const int __sanitizer_XDR_ENCODE = 0; |
356 | const int __sanitizer_XDR_DECODE = 1; |
357 | const int __sanitizer_XDR_FREE = 2; |
358 | #endif |
359 | |
360 | struct __sanitizer_passwd { |
361 | char *pw_name; |
362 | char *pw_passwd; |
363 | int pw_uid; |
364 | int pw_gid; |
365 | #if SANITIZER_APPLE |
366 | long pw_change; |
367 | char *pw_class; |
368 | #endif |
369 | #if !(SANITIZER_ANDROID && (SANITIZER_WORDSIZE == 32)) && !SANITIZER_HAIKU |
370 | char *pw_gecos; |
371 | #endif |
372 | char *pw_dir; |
373 | char *pw_shell; |
374 | #if SANITIZER_APPLE |
375 | long pw_expire; |
376 | #endif |
377 | #if SANITIZER_HAIKU |
378 | char *pw_gecos; |
379 | #endif |
380 | }; |
381 | |
382 | struct __sanitizer_group { |
383 | char *gr_name; |
384 | char *gr_passwd; |
385 | int gr_gid; |
386 | char **gr_mem; |
387 | }; |
388 | |
389 | # if (SANITIZER_LINUX && !SANITIZER_GLIBC && !SANITIZER_ANDROID) || \ |
390 | (defined(__x86_64__) && !defined(_LP64)) || defined(__hexagon__) |
391 | typedef long long __sanitizer_time_t; |
392 | #else |
393 | typedef long __sanitizer_time_t; |
394 | #endif |
395 | |
396 | typedef long __sanitizer_suseconds_t; |
397 | |
398 | struct __sanitizer_timespec { |
399 | __sanitizer_time_t tv_sec; /* seconds */ |
400 | u64 tv_nsec; /* nanoseconds */ |
401 | }; |
402 | |
403 | struct __sanitizer_itimerspec { |
404 | struct __sanitizer_timespec it_interval; /* timer period */ |
405 | struct __sanitizer_timespec it_value; /* timer expiration */ |
406 | }; |
407 | |
408 | struct __sanitizer_timeval { |
409 | __sanitizer_time_t tv_sec; |
410 | __sanitizer_suseconds_t tv_usec; |
411 | }; |
412 | |
413 | struct __sanitizer_itimerval { |
414 | struct __sanitizer_timeval it_interval; |
415 | struct __sanitizer_timeval it_value; |
416 | }; |
417 | |
418 | struct __sanitizer_timeb { |
419 | __sanitizer_time_t time; |
420 | unsigned short millitm; |
421 | short timezone; |
422 | short dstflag; |
423 | }; |
424 | |
425 | struct __sanitizer_ether_addr { |
426 | u8 octet[6]; |
427 | }; |
428 | |
429 | struct __sanitizer_tm { |
430 | int tm_sec; |
431 | int tm_min; |
432 | int tm_hour; |
433 | int tm_mday; |
434 | int tm_mon; |
435 | int tm_year; |
436 | int tm_wday; |
437 | int tm_yday; |
438 | int tm_isdst; |
439 | #if SANITIZER_HAIKU |
440 | int tm_gmtoff; |
441 | #else |
442 | long int tm_gmtoff; |
443 | #endif |
444 | const char *tm_zone; |
445 | }; |
446 | |
447 | #if SANITIZER_LINUX |
448 | struct __sanitizer_mntent { |
449 | char *mnt_fsname; |
450 | char *mnt_dir; |
451 | char *mnt_type; |
452 | char *mnt_opts; |
453 | int mnt_freq; |
454 | int mnt_passno; |
455 | }; |
456 | |
457 | struct __sanitizer_file_handle { |
458 | unsigned int handle_bytes; |
459 | int handle_type; |
460 | unsigned char f_handle[1]; // variable sized |
461 | }; |
462 | #endif |
463 | |
464 | #if SANITIZER_APPLE || SANITIZER_HAIKU |
465 | struct __sanitizer_msghdr { |
466 | void *msg_name; |
467 | unsigned msg_namelen; |
468 | struct __sanitizer_iovec *msg_iov; |
469 | unsigned msg_iovlen; |
470 | void *msg_control; |
471 | unsigned msg_controllen; |
472 | int msg_flags; |
473 | }; |
474 | struct __sanitizer_cmsghdr { |
475 | unsigned cmsg_len; |
476 | int cmsg_level; |
477 | int cmsg_type; |
478 | }; |
479 | #else |
480 | // In POSIX, int msg_iovlen; socklen_t msg_controllen; socklen_t cmsg_len; but |
481 | // many implementations don't conform to the standard. |
482 | struct __sanitizer_msghdr { |
483 | void *msg_name; |
484 | unsigned msg_namelen; |
485 | struct __sanitizer_iovec *msg_iov; |
486 | uptr msg_iovlen; |
487 | void *msg_control; |
488 | uptr msg_controllen; |
489 | int msg_flags; |
490 | }; |
491 | struct __sanitizer_cmsghdr { |
492 | uptr cmsg_len; |
493 | int cmsg_level; |
494 | int cmsg_type; |
495 | }; |
496 | #endif |
497 | |
498 | #if SANITIZER_LINUX |
499 | struct __sanitizer_mmsghdr { |
500 | __sanitizer_msghdr msg_hdr; |
501 | unsigned int msg_len; |
502 | }; |
503 | #endif |
504 | |
505 | #if SANITIZER_APPLE |
506 | struct __sanitizer_dirent { |
507 | unsigned long long d_ino; |
508 | unsigned long long d_seekoff; |
509 | unsigned short d_reclen; |
510 | // more fields that we don't care about |
511 | }; |
512 | #elif SANITIZER_HAIKU |
513 | struct __sanitizer_dirent { |
514 | int d_dev; |
515 | int d_pdev; |
516 | unsigned long long d_ino; |
517 | unsigned long long d_pino; |
518 | unsigned short d_reclen; |
519 | // more fields that we don't care about |
520 | }; |
521 | # elif (SANITIZER_LINUX && !SANITIZER_GLIBC) || defined(__x86_64__) || \ |
522 | defined(__hexagon__) |
523 | struct __sanitizer_dirent { |
524 | unsigned long long d_ino; |
525 | unsigned long long d_off; |
526 | unsigned short d_reclen; |
527 | // more fields that we don't care about |
528 | }; |
529 | # else |
530 | struct __sanitizer_dirent { |
531 | uptr d_ino; |
532 | uptr d_off; |
533 | unsigned short d_reclen; |
534 | // more fields that we don't care about |
535 | }; |
536 | # endif |
537 | |
538 | # if SANITIZER_GLIBC |
539 | struct __sanitizer_dirent64 { |
540 | unsigned long long d_ino; |
541 | unsigned long long d_off; |
542 | unsigned short d_reclen; |
543 | // more fields that we don't care about |
544 | }; |
545 | extern unsigned struct_sock_fprog_sz; |
546 | #endif |
547 | |
548 | #if SANITIZER_HAIKU |
549 | typedef int __sanitizer_clock_t; |
550 | #elif defined(__x86_64__) && !defined(_LP64) |
551 | typedef long long __sanitizer_clock_t; |
552 | #else |
553 | typedef long __sanitizer_clock_t; |
554 | #endif |
555 | |
556 | #if SANITIZER_LINUX || SANITIZER_HAIKU |
557 | typedef int __sanitizer_clockid_t; |
558 | typedef unsigned long long __sanitizer_eventfd_t; |
559 | #endif |
560 | |
561 | #if SANITIZER_LINUX |
562 | # if defined(_LP64) || defined(__x86_64__) || defined(__powerpc__) || \ |
563 | defined(__mips__) || defined(__hexagon__) |
564 | typedef unsigned __sanitizer___kernel_uid_t; |
565 | typedef unsigned __sanitizer___kernel_gid_t; |
566 | #else |
567 | typedef unsigned short __sanitizer___kernel_uid_t; |
568 | typedef unsigned short __sanitizer___kernel_gid_t; |
569 | #endif |
570 | #if defined(__x86_64__) && !defined(_LP64) |
571 | typedef long long __sanitizer___kernel_off_t; |
572 | #else |
573 | typedef long __sanitizer___kernel_off_t; |
574 | #endif |
575 | |
576 | #if defined(__powerpc__) || defined(__mips__) |
577 | typedef unsigned int __sanitizer___kernel_old_uid_t; |
578 | typedef unsigned int __sanitizer___kernel_old_gid_t; |
579 | #else |
580 | typedef unsigned short __sanitizer___kernel_old_uid_t; |
581 | typedef unsigned short __sanitizer___kernel_old_gid_t; |
582 | #endif |
583 | |
584 | typedef long long __sanitizer___kernel_loff_t; |
585 | typedef struct { |
586 | unsigned long fds_bits[1024 / (8 * sizeof(long))]; |
587 | } __sanitizer___kernel_fd_set; |
588 | #endif |
589 | |
590 | // This thing depends on the platform. We are only interested in the upper |
591 | // limit. Verified with a compiler assert in .cpp. |
592 | union __sanitizer_pthread_attr_t { |
593 | char size[128]; |
594 | void *align; |
595 | }; |
596 | |
597 | #if SANITIZER_ANDROID |
598 | # if SANITIZER_MIPS |
599 | typedef unsigned long __sanitizer_sigset_t[16 / sizeof(unsigned long)]; |
600 | # else |
601 | typedef unsigned long __sanitizer_sigset_t; |
602 | # endif |
603 | #elif SANITIZER_APPLE |
604 | typedef unsigned __sanitizer_sigset_t; |
605 | #elif SANITIZER_HAIKU |
606 | typedef unsigned long __sanitizer_sigset_t; |
607 | #elif SANITIZER_LINUX |
608 | struct __sanitizer_sigset_t { |
609 | // The size is determined by looking at sizeof of real sigset_t on linux. |
610 | uptr val[128 / sizeof(uptr)]; |
611 | }; |
612 | #endif |
613 | |
614 | struct __sanitizer_siginfo_pad { |
615 | #if SANITIZER_X32 |
616 | // x32 siginfo_t is aligned to 8 bytes. |
617 | u64 pad[128 / sizeof(u64)]; |
618 | #else |
619 | // Require uptr, because siginfo_t is always pointer-size aligned on Linux. |
620 | uptr pad[128 / sizeof(uptr)]; |
621 | #endif |
622 | }; |
623 | |
624 | #if SANITIZER_LINUX |
625 | # define SANITIZER_HAS_SIGINFO 1 |
626 | union __sanitizer_siginfo { |
627 | __extension__ struct { |
628 | int si_signo; |
629 | # if SANITIZER_MIPS |
630 | int si_code; |
631 | int si_errno; |
632 | # else |
633 | int si_errno; |
634 | int si_code; |
635 | # endif |
636 | }; |
637 | __sanitizer_siginfo_pad pad; |
638 | }; |
639 | #else |
640 | # define SANITIZER_HAS_SIGINFO 0 |
641 | typedef __sanitizer_siginfo_pad __sanitizer_siginfo; |
642 | #endif |
643 | |
644 | using __sanitizer_sighandler_ptr = void (*)(int sig); |
645 | using __sanitizer_sigactionhandler_ptr = void (*)(int sig, |
646 | __sanitizer_siginfo *siginfo, |
647 | void *uctx); |
648 | |
649 | // Linux system headers define the 'sa_handler' and 'sa_sigaction' macros. |
650 | #if SANITIZER_ANDROID && (SANITIZER_WORDSIZE == 64) |
651 | struct __sanitizer_sigaction { |
652 | unsigned sa_flags; |
653 | union { |
654 | __sanitizer_sigactionhandler_ptr sigaction; |
655 | __sanitizer_sighandler_ptr handler; |
656 | }; |
657 | __sanitizer_sigset_t sa_mask; |
658 | void (*sa_restorer)(); |
659 | }; |
660 | #elif SANITIZER_ANDROID && SANITIZER_MIPS32 // check this before WORDSIZE == 32 |
661 | struct __sanitizer_sigaction { |
662 | unsigned sa_flags; |
663 | union { |
664 | __sanitizer_sigactionhandler_ptr sigaction; |
665 | __sanitizer_sighandler_ptr handler; |
666 | }; |
667 | __sanitizer_sigset_t sa_mask; |
668 | }; |
669 | #elif SANITIZER_ANDROID && (SANITIZER_WORDSIZE == 32) |
670 | struct __sanitizer_sigaction { |
671 | union { |
672 | __sanitizer_sigactionhandler_ptr sigaction; |
673 | __sanitizer_sighandler_ptr handler; |
674 | }; |
675 | __sanitizer_sigset_t sa_mask; |
676 | uptr sa_flags; |
677 | void (*sa_restorer)(); |
678 | }; |
679 | #else // !SANITIZER_ANDROID |
680 | struct __sanitizer_sigaction { |
681 | # if defined(__mips__) && !SANITIZER_FREEBSD && !SANITIZER_MUSL |
682 | unsigned int sa_flags; |
683 | # endif |
684 | union { |
685 | __sanitizer_sigactionhandler_ptr sigaction; |
686 | __sanitizer_sighandler_ptr handler; |
687 | }; |
688 | # if SANITIZER_FREEBSD |
689 | int sa_flags; |
690 | __sanitizer_sigset_t sa_mask; |
691 | # else |
692 | # if defined(__s390x__) |
693 | int sa_resv; |
694 | # else |
695 | __sanitizer_sigset_t sa_mask; |
696 | # endif |
697 | # if !defined(__mips__) || SANITIZER_MUSL |
698 | # if defined(__sparc__) |
699 | # if __GLIBC_PREREQ(2, 20) |
700 | // On sparc glibc 2.19 and earlier sa_flags was unsigned long. |
701 | # if defined(__arch64__) |
702 | // To maintain ABI compatibility on sparc64 when switching to an int, |
703 | // __glibc_reserved0 was added. |
704 | int __glibc_reserved0; |
705 | # endif |
706 | int sa_flags; |
707 | # else |
708 | unsigned long sa_flags; |
709 | # endif |
710 | # else |
711 | int sa_flags; |
712 | # endif |
713 | # endif |
714 | # endif |
715 | # if SANITIZER_LINUX || SANITIZER_HAIKU |
716 | void (*sa_restorer)(); |
717 | # endif |
718 | # if defined(__mips__) && (SANITIZER_WORDSIZE == 32) && !SANITIZER_MUSL |
719 | int sa_resv[1]; |
720 | # endif |
721 | # if defined(__s390x__) |
722 | __sanitizer_sigset_t sa_mask; |
723 | # endif |
724 | }; |
725 | #endif // !SANITIZER_ANDROID |
726 | |
727 | #if defined(__mips__) |
728 | #define __SANITIZER_KERNEL_NSIG 128 |
729 | #else |
730 | #define __SANITIZER_KERNEL_NSIG 64 |
731 | #endif |
732 | |
733 | struct __sanitizer_kernel_sigset_t { |
734 | uptr sig[__SANITIZER_KERNEL_NSIG / (sizeof(uptr) * 8)]; |
735 | }; |
736 | |
737 | // Linux system headers define the 'sa_handler' and 'sa_sigaction' macros. |
738 | #if SANITIZER_MIPS |
739 | struct __sanitizer_kernel_sigaction_t { |
740 | unsigned int sa_flags; |
741 | union { |
742 | void (*handler)(int signo); |
743 | void (*sigaction)(int signo, __sanitizer_siginfo *info, void *ctx); |
744 | }; |
745 | __sanitizer_kernel_sigset_t sa_mask; |
746 | void (*sa_restorer)(void); |
747 | }; |
748 | #else |
749 | struct __sanitizer_kernel_sigaction_t { |
750 | union { |
751 | void (*handler)(int signo); |
752 | void (*sigaction)(int signo, __sanitizer_siginfo *info, void *ctx); |
753 | }; |
754 | unsigned long sa_flags; |
755 | void (*sa_restorer)(void); |
756 | __sanitizer_kernel_sigset_t sa_mask; |
757 | }; |
758 | #endif |
759 | |
760 | extern const uptr sig_ign; |
761 | extern const uptr sig_dfl; |
762 | extern const uptr sig_err; |
763 | extern const uptr sa_siginfo; |
764 | |
765 | #if SANITIZER_LINUX |
766 | extern int e_tabsz; |
767 | #endif |
768 | |
769 | extern int af_inet; |
770 | extern int af_inet6; |
771 | uptr __sanitizer_in_addr_sz(int af); |
772 | |
773 | #if SANITIZER_LINUX |
774 | struct __sanitizer_dl_phdr_info { |
775 | uptr dlpi_addr; |
776 | const char *dlpi_name; |
777 | const void *dlpi_phdr; |
778 | short dlpi_phnum; |
779 | }; |
780 | |
781 | extern unsigned struct_ElfW_Phdr_sz; |
782 | #endif |
783 | |
784 | struct __sanitizer_protoent { |
785 | char *p_name; |
786 | char **p_aliases; |
787 | int p_proto; |
788 | }; |
789 | |
790 | struct __sanitizer_netent { |
791 | char *n_name; |
792 | char **n_aliases; |
793 | int n_addrtype; |
794 | u32 n_net; |
795 | }; |
796 | |
797 | struct __sanitizer_addrinfo { |
798 | int ai_flags; |
799 | int ai_family; |
800 | int ai_socktype; |
801 | int ai_protocol; |
802 | #if SANITIZER_ANDROID || SANITIZER_APPLE || SANITIZER_HAIKU |
803 | unsigned ai_addrlen; |
804 | char *ai_canonname; |
805 | void *ai_addr; |
806 | #else // LINUX |
807 | unsigned ai_addrlen; |
808 | void *ai_addr; |
809 | char *ai_canonname; |
810 | #endif |
811 | struct __sanitizer_addrinfo *ai_next; |
812 | }; |
813 | |
814 | struct __sanitizer_hostent { |
815 | char *h_name; |
816 | char **h_aliases; |
817 | int h_addrtype; |
818 | int h_length; |
819 | char **h_addr_list; |
820 | }; |
821 | |
822 | struct __sanitizer_pollfd { |
823 | int fd; |
824 | short events; |
825 | short revents; |
826 | }; |
827 | |
828 | #if SANITIZER_ANDROID || SANITIZER_APPLE |
829 | typedef unsigned __sanitizer_nfds_t; |
830 | #else |
831 | typedef unsigned long __sanitizer_nfds_t; |
832 | #endif |
833 | |
834 | #if !SANITIZER_ANDROID |
835 | # if SANITIZER_LINUX |
836 | struct __sanitizer_glob_t { |
837 | uptr gl_pathc; |
838 | char **gl_pathv; |
839 | uptr gl_offs; |
840 | int gl_flags; |
841 | |
842 | void (*gl_closedir)(void *dirp); |
843 | void *(*gl_readdir)(void *dirp); |
844 | void *(*gl_opendir)(const char *); |
845 | int (*gl_lstat)(const char *, void *); |
846 | int (*gl_stat)(const char *, void *); |
847 | }; |
848 | # endif // SANITIZER_LINUX |
849 | |
850 | # if SANITIZER_LINUX |
851 | extern int glob_nomatch; |
852 | extern int glob_altdirfunc; |
853 | # endif |
854 | #endif // !SANITIZER_ANDROID |
855 | |
856 | extern unsigned path_max; |
857 | |
858 | # if !SANITIZER_ANDROID |
859 | extern const int wordexp_wrde_dooffs; |
860 | # endif // !SANITIZER_ANDROID |
861 | |
862 | struct __sanitizer_wordexp_t { |
863 | uptr we_wordc; |
864 | char **we_wordv; |
865 | uptr we_offs; |
866 | }; |
867 | |
868 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
869 | struct __sanitizer_FILE { |
870 | int _flags; |
871 | char *_IO_read_ptr; |
872 | char *_IO_read_end; |
873 | char *_IO_read_base; |
874 | char *_IO_write_base; |
875 | char *_IO_write_ptr; |
876 | char *_IO_write_end; |
877 | char *_IO_buf_base; |
878 | char *_IO_buf_end; |
879 | char *_IO_save_base; |
880 | char *_IO_backup_base; |
881 | char *_IO_save_end; |
882 | void *_markers; |
883 | __sanitizer_FILE *_chain; |
884 | int _fileno; |
885 | }; |
886 | # define SANITIZER_HAS_STRUCT_FILE 1 |
887 | #else |
888 | typedef void __sanitizer_FILE; |
889 | # define SANITIZER_HAS_STRUCT_FILE 0 |
890 | #endif |
891 | |
892 | # if SANITIZER_LINUX && !SANITIZER_ANDROID && \ |
893 | (defined(__i386) || defined(__x86_64) || defined(__mips64) || \ |
894 | defined(__powerpc64__) || defined(__aarch64__) || defined(__arm__) || \ |
895 | defined(__s390__) || defined(__loongarch__) || SANITIZER_RISCV64 || \ |
896 | defined(__sparc__)) |
897 | extern unsigned struct_user_regs_struct_sz; |
898 | extern unsigned struct_user_fpregs_struct_sz; |
899 | extern unsigned struct_user_fpxregs_struct_sz; |
900 | extern unsigned struct_user_vfpregs_struct_sz; |
901 | |
902 | extern int ptrace_peektext; |
903 | extern int ptrace_peekdata; |
904 | extern int ptrace_peekuser; |
905 | extern int ptrace_getregs; |
906 | extern int ptrace_setregs; |
907 | extern int ptrace_getfpregs; |
908 | extern int ptrace_setfpregs; |
909 | extern int ptrace_getfpxregs; |
910 | extern int ptrace_setfpxregs; |
911 | extern int ptrace_getvfpregs; |
912 | extern int ptrace_setvfpregs; |
913 | extern int ptrace_getsiginfo; |
914 | extern int ptrace_setsiginfo; |
915 | extern int ptrace_getregset; |
916 | extern int ptrace_setregset; |
917 | extern int ptrace_geteventmsg; |
918 | |
919 | // Helper for the ptrace interceptor. |
920 | template <class T> |
921 | inline T ptrace_data_arg(int request, T addr, T data) { |
922 | # if SANITIZER_LINUX && SANITIZER_SPARC |
923 | // As described in ptrace(2), the meanings of addr and data are reversed |
924 | // for the PTRACE_GETREGS, PTRACE_GETFPREGS, PTRACE_GETREGS, and |
925 | // PTRACE_GETFPREGS requests on Linux/sparc64. |
926 | if (request == ptrace_getregs || request == ptrace_getfpregs || |
927 | request == ptrace_setregs || request == ptrace_setfpregs) |
928 | return addr; |
929 | else |
930 | # endif |
931 | return data; |
932 | } |
933 | # endif |
934 | |
935 | # if SANITIZER_LINUX && !SANITIZER_ANDROID |
936 | extern unsigned struct_shminfo_sz; |
937 | extern unsigned struct_shm_info_sz; |
938 | extern int shmctl_ipc_stat; |
939 | extern int shmctl_ipc_info; |
940 | extern int shmctl_shm_info; |
941 | extern int shmctl_shm_stat; |
942 | #endif |
943 | |
944 | #if !SANITIZER_APPLE && !SANITIZER_FREEBSD |
945 | extern unsigned struct_utmp_sz; |
946 | #endif |
947 | #if !SANITIZER_ANDROID |
948 | extern unsigned struct_utmpx_sz; |
949 | #endif |
950 | |
951 | extern int map_fixed; |
952 | |
953 | // ioctl arguments |
954 | struct __sanitizer_ifconf { |
955 | int ifc_len; |
956 | union { |
957 | void *ifcu_req; |
958 | } ifc_ifcu; |
959 | #if SANITIZER_APPLE |
960 | } __attribute__((packed)); |
961 | #else |
962 | }; |
963 | #endif |
964 | |
965 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
966 | struct __sanitizer__obstack_chunk { |
967 | char *limit; |
968 | struct __sanitizer__obstack_chunk *prev; |
969 | }; |
970 | |
971 | struct __sanitizer_obstack { |
972 | long chunk_size; |
973 | struct __sanitizer__obstack_chunk *chunk; |
974 | char *object_base; |
975 | char *next_free; |
976 | uptr more_fields[7]; |
977 | }; |
978 | |
979 | typedef uptr (*__sanitizer_cookie_io_read)(void *cookie, char *buf, uptr size); |
980 | typedef uptr (*__sanitizer_cookie_io_write)(void *cookie, const char *buf, |
981 | uptr size); |
982 | typedef int (*__sanitizer_cookie_io_seek)(void *cookie, u64 *offset, |
983 | int whence); |
984 | typedef int (*__sanitizer_cookie_io_close)(void *cookie); |
985 | |
986 | struct __sanitizer_cookie_io_functions_t { |
987 | __sanitizer_cookie_io_read read; |
988 | __sanitizer_cookie_io_write write; |
989 | __sanitizer_cookie_io_seek seek; |
990 | __sanitizer_cookie_io_close close; |
991 | }; |
992 | #endif |
993 | |
994 | #define IOC_NRBITS 8 |
995 | #define IOC_TYPEBITS 8 |
996 | #if defined(__powerpc__) || defined(__powerpc64__) || defined(__mips__) || \ |
997 | defined(__sparc__) |
998 | #define IOC_SIZEBITS 13 |
999 | #define IOC_DIRBITS 3 |
1000 | #define IOC_NONE 1U |
1001 | #define IOC_WRITE 4U |
1002 | #define IOC_READ 2U |
1003 | #else |
1004 | #define IOC_SIZEBITS 14 |
1005 | #define IOC_DIRBITS 2 |
1006 | #define IOC_NONE 0U |
1007 | #define IOC_WRITE 1U |
1008 | #define IOC_READ 2U |
1009 | #endif |
1010 | #define IOC_NRMASK ((1 << IOC_NRBITS) - 1) |
1011 | #define IOC_TYPEMASK ((1 << IOC_TYPEBITS) - 1) |
1012 | #define IOC_SIZEMASK ((1 << IOC_SIZEBITS) - 1) |
1013 | #if defined(IOC_DIRMASK) |
1014 | #undef IOC_DIRMASK |
1015 | #endif |
1016 | #define IOC_DIRMASK ((1 << IOC_DIRBITS) - 1) |
1017 | #define IOC_NRSHIFT 0 |
1018 | #define IOC_TYPESHIFT (IOC_NRSHIFT + IOC_NRBITS) |
1019 | #define IOC_SIZESHIFT (IOC_TYPESHIFT + IOC_TYPEBITS) |
1020 | #define IOC_DIRSHIFT (IOC_SIZESHIFT + IOC_SIZEBITS) |
1021 | #define EVIOC_EV_MAX 0x1f |
1022 | #define EVIOC_ABS_MAX 0x3f |
1023 | |
1024 | #define IOC_DIR(nr) (((nr) >> IOC_DIRSHIFT) & IOC_DIRMASK) |
1025 | #define IOC_TYPE(nr) (((nr) >> IOC_TYPESHIFT) & IOC_TYPEMASK) |
1026 | #define IOC_NR(nr) (((nr) >> IOC_NRSHIFT) & IOC_NRMASK) |
1027 | |
1028 | #if defined(__sparc__) |
1029 | // In sparc the 14 bits SIZE field overlaps with the |
1030 | // least significant bit of DIR, so either IOC_READ or |
1031 | // IOC_WRITE shall be 1 in order to get a non-zero SIZE. |
1032 | #define IOC_SIZE(nr) \ |
1033 | ((((((nr) >> 29) & 0x7) & (4U | 2U)) == 0) ? 0 : (((nr) >> 16) & 0x3fff)) |
1034 | #else |
1035 | #define IOC_SIZE(nr) (((nr) >> IOC_SIZESHIFT) & IOC_SIZEMASK) |
1036 | #endif |
1037 | |
1038 | extern unsigned struct_ifreq_sz; |
1039 | extern unsigned struct_termios_sz; |
1040 | extern unsigned struct_winsize_sz; |
1041 | |
1042 | #if SANITIZER_LINUX |
1043 | extern unsigned struct_arpreq_sz; |
1044 | extern unsigned struct_cdrom_msf_sz; |
1045 | extern unsigned struct_cdrom_multisession_sz; |
1046 | extern unsigned struct_cdrom_read_audio_sz; |
1047 | extern unsigned struct_cdrom_subchnl_sz; |
1048 | extern unsigned struct_cdrom_ti_sz; |
1049 | extern unsigned struct_cdrom_tocentry_sz; |
1050 | extern unsigned struct_cdrom_tochdr_sz; |
1051 | extern unsigned struct_cdrom_volctrl_sz; |
1052 | extern unsigned struct_ff_effect_sz; |
1053 | extern unsigned struct_floppy_drive_params_sz; |
1054 | extern unsigned struct_floppy_drive_struct_sz; |
1055 | extern unsigned struct_floppy_fdc_state_sz; |
1056 | extern unsigned struct_floppy_max_errors_sz; |
1057 | extern unsigned struct_floppy_raw_cmd_sz; |
1058 | extern unsigned struct_floppy_struct_sz; |
1059 | extern unsigned struct_floppy_write_errors_sz; |
1060 | extern unsigned struct_format_descr_sz; |
1061 | extern unsigned struct_hd_driveid_sz; |
1062 | extern unsigned struct_hd_geometry_sz; |
1063 | extern unsigned struct_input_absinfo_sz; |
1064 | extern unsigned struct_input_id_sz; |
1065 | extern unsigned struct_mtpos_sz; |
1066 | extern unsigned struct_vt_consize_sz; |
1067 | extern unsigned struct_vt_sizes_sz; |
1068 | extern unsigned struct_vt_stat_sz; |
1069 | #endif // SANITIZER_LINUX |
1070 | |
1071 | #if SANITIZER_LINUX |
1072 | extern unsigned struct_copr_buffer_sz; |
1073 | extern unsigned struct_copr_debug_buf_sz; |
1074 | extern unsigned struct_copr_msg_sz; |
1075 | extern unsigned struct_midi_info_sz; |
1076 | extern unsigned struct_mtget_sz; |
1077 | extern unsigned struct_mtop_sz; |
1078 | extern unsigned struct_rtentry_sz; |
1079 | extern unsigned struct_sbi_instrument_sz; |
1080 | extern unsigned struct_seq_event_rec_sz; |
1081 | extern unsigned struct_synth_info_sz; |
1082 | extern unsigned struct_vt_mode_sz; |
1083 | #endif // SANITIZER_LINUX |
1084 | |
1085 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
1086 | extern unsigned struct_ax25_parms_struct_sz; |
1087 | extern unsigned struct_input_keymap_entry_sz; |
1088 | extern unsigned struct_ipx_config_data_sz; |
1089 | extern unsigned struct_kbdiacrs_sz; |
1090 | extern unsigned struct_kbentry_sz; |
1091 | extern unsigned struct_kbkeycode_sz; |
1092 | extern unsigned struct_kbsentry_sz; |
1093 | extern unsigned struct_mtconfiginfo_sz; |
1094 | extern unsigned struct_nr_parms_struct_sz; |
1095 | extern unsigned struct_scc_modem_sz; |
1096 | extern unsigned struct_scc_stat_sz; |
1097 | extern unsigned struct_serial_multiport_struct_sz; |
1098 | extern unsigned struct_serial_struct_sz; |
1099 | extern unsigned struct_sockaddr_ax25_sz; |
1100 | extern unsigned struct_unimapdesc_sz; |
1101 | extern unsigned struct_unimapinit_sz; |
1102 | # endif // SANITIZER_LINUX && !SANITIZER_ANDROID |
1103 | |
1104 | extern const unsigned long __sanitizer_bufsiz; |
1105 | |
1106 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
1107 | extern unsigned struct_audio_buf_info_sz; |
1108 | extern unsigned struct_ppp_stats_sz; |
1109 | #endif // (SANITIZER_LINUX || SANITIZER_FREEBSD) && !SANITIZER_ANDROID |
1110 | |
1111 | #if !SANITIZER_ANDROID && !SANITIZER_APPLE |
1112 | extern unsigned struct_sioc_sg_req_sz; |
1113 | extern unsigned struct_sioc_vif_req_sz; |
1114 | #endif |
1115 | |
1116 | extern unsigned fpos_t_sz; |
1117 | |
1118 | // ioctl request identifiers |
1119 | |
1120 | // A special value to mark ioctls that are not present on the target platform, |
1121 | // when it can not be determined without including any system headers. |
1122 | extern const unsigned IOCTL_NOT_PRESENT; |
1123 | |
1124 | extern unsigned IOCTL_FIOASYNC; |
1125 | extern unsigned IOCTL_FIOCLEX; |
1126 | extern unsigned IOCTL_FIOGETOWN; |
1127 | extern unsigned IOCTL_FIONBIO; |
1128 | extern unsigned IOCTL_FIONCLEX; |
1129 | extern unsigned IOCTL_FIOSETOWN; |
1130 | extern unsigned IOCTL_SIOCADDMULTI; |
1131 | extern unsigned IOCTL_SIOCATMARK; |
1132 | extern unsigned IOCTL_SIOCDELMULTI; |
1133 | extern unsigned IOCTL_SIOCGIFADDR; |
1134 | extern unsigned IOCTL_SIOCGIFBRDADDR; |
1135 | extern unsigned IOCTL_SIOCGIFCONF; |
1136 | extern unsigned IOCTL_SIOCGIFDSTADDR; |
1137 | extern unsigned IOCTL_SIOCGIFFLAGS; |
1138 | extern unsigned IOCTL_SIOCGIFMETRIC; |
1139 | extern unsigned IOCTL_SIOCGIFMTU; |
1140 | extern unsigned IOCTL_SIOCGIFNETMASK; |
1141 | extern unsigned IOCTL_SIOCGPGRP; |
1142 | extern unsigned IOCTL_SIOCSIFADDR; |
1143 | extern unsigned IOCTL_SIOCSIFBRDADDR; |
1144 | extern unsigned IOCTL_SIOCSIFDSTADDR; |
1145 | extern unsigned IOCTL_SIOCSIFFLAGS; |
1146 | extern unsigned IOCTL_SIOCSIFMETRIC; |
1147 | extern unsigned IOCTL_SIOCSIFMTU; |
1148 | extern unsigned IOCTL_SIOCSIFNETMASK; |
1149 | extern unsigned IOCTL_SIOCSPGRP; |
1150 | #if !SANITIZER_HAIKU |
1151 | extern unsigned IOCTL_TIOCCONS; |
1152 | extern unsigned IOCTL_TIOCGETD; |
1153 | extern unsigned IOCTL_TIOCNOTTY; |
1154 | extern unsigned IOCTL_TIOCPKT; |
1155 | extern unsigned IOCTL_TIOCSETD; |
1156 | extern unsigned IOCTL_TIOCSTI; |
1157 | #endif |
1158 | extern unsigned IOCTL_TIOCEXCL; |
1159 | extern unsigned IOCTL_TIOCGPGRP; |
1160 | extern unsigned IOCTL_TIOCGWINSZ; |
1161 | extern unsigned IOCTL_TIOCMBIC; |
1162 | extern unsigned IOCTL_TIOCMBIS; |
1163 | extern unsigned IOCTL_TIOCMGET; |
1164 | extern unsigned IOCTL_TIOCMSET; |
1165 | extern unsigned IOCTL_TIOCNXCL; |
1166 | extern unsigned IOCTL_TIOCOUTQ; |
1167 | extern unsigned IOCTL_TIOCSCTTY; |
1168 | extern unsigned IOCTL_TIOCSPGRP; |
1169 | extern unsigned IOCTL_TIOCSWINSZ; |
1170 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
1171 | extern unsigned IOCTL_SIOCGETSGCNT; |
1172 | extern unsigned IOCTL_SIOCGETVIFCNT; |
1173 | #endif |
1174 | #if SANITIZER_LINUX |
1175 | extern unsigned IOCTL_EVIOCGABS; |
1176 | extern unsigned IOCTL_EVIOCGBIT; |
1177 | extern unsigned IOCTL_EVIOCGEFFECTS; |
1178 | extern unsigned IOCTL_EVIOCGID; |
1179 | extern unsigned IOCTL_EVIOCGKEY; |
1180 | extern unsigned IOCTL_EVIOCGKEYCODE; |
1181 | extern unsigned IOCTL_EVIOCGLED; |
1182 | extern unsigned IOCTL_EVIOCGNAME; |
1183 | extern unsigned IOCTL_EVIOCGPHYS; |
1184 | extern unsigned IOCTL_EVIOCGRAB; |
1185 | extern unsigned IOCTL_EVIOCGREP; |
1186 | extern unsigned IOCTL_EVIOCGSND; |
1187 | extern unsigned IOCTL_EVIOCGSW; |
1188 | extern unsigned IOCTL_EVIOCGUNIQ; |
1189 | extern unsigned IOCTL_EVIOCGVERSION; |
1190 | extern unsigned IOCTL_EVIOCRMFF; |
1191 | extern unsigned IOCTL_EVIOCSABS; |
1192 | extern unsigned IOCTL_EVIOCSFF; |
1193 | extern unsigned IOCTL_EVIOCSKEYCODE; |
1194 | extern unsigned IOCTL_EVIOCSREP; |
1195 | extern unsigned IOCTL_BLKFLSBUF; |
1196 | extern unsigned IOCTL_BLKGETSIZE; |
1197 | extern unsigned IOCTL_BLKRAGET; |
1198 | extern unsigned IOCTL_BLKRASET; |
1199 | extern unsigned IOCTL_BLKROGET; |
1200 | extern unsigned IOCTL_BLKROSET; |
1201 | extern unsigned IOCTL_BLKRRPART; |
1202 | extern unsigned IOCTL_BLKFRASET; |
1203 | extern unsigned IOCTL_BLKFRAGET; |
1204 | extern unsigned IOCTL_BLKSECTSET; |
1205 | extern unsigned IOCTL_BLKSECTGET; |
1206 | extern unsigned IOCTL_BLKSSZGET; |
1207 | extern unsigned IOCTL_BLKBSZGET; |
1208 | extern unsigned IOCTL_BLKBSZSET; |
1209 | extern unsigned IOCTL_BLKGETSIZE64; |
1210 | extern unsigned IOCTL_CDROMAUDIOBUFSIZ; |
1211 | extern unsigned IOCTL_CDROMEJECT; |
1212 | extern unsigned IOCTL_CDROMEJECT_SW; |
1213 | extern unsigned IOCTL_CDROMMULTISESSION; |
1214 | extern unsigned IOCTL_CDROMPAUSE; |
1215 | extern unsigned IOCTL_CDROMPLAYMSF; |
1216 | extern unsigned IOCTL_CDROMPLAYTRKIND; |
1217 | extern unsigned IOCTL_CDROMREADAUDIO; |
1218 | extern unsigned IOCTL_CDROMREADCOOKED; |
1219 | extern unsigned IOCTL_CDROMREADMODE1; |
1220 | extern unsigned IOCTL_CDROMREADMODE2; |
1221 | extern unsigned IOCTL_CDROMREADRAW; |
1222 | extern unsigned IOCTL_CDROMREADTOCENTRY; |
1223 | extern unsigned IOCTL_CDROMREADTOCHDR; |
1224 | extern unsigned IOCTL_CDROMRESET; |
1225 | extern unsigned IOCTL_CDROMRESUME; |
1226 | extern unsigned IOCTL_CDROMSEEK; |
1227 | extern unsigned IOCTL_CDROMSTART; |
1228 | extern unsigned IOCTL_CDROMSTOP; |
1229 | extern unsigned IOCTL_CDROMSUBCHNL; |
1230 | extern unsigned IOCTL_CDROMVOLCTRL; |
1231 | extern unsigned IOCTL_CDROMVOLREAD; |
1232 | extern unsigned IOCTL_CDROM_GET_UPC; |
1233 | extern unsigned IOCTL_FDCLRPRM; |
1234 | extern unsigned IOCTL_FDDEFPRM; |
1235 | extern unsigned IOCTL_FDFLUSH; |
1236 | extern unsigned IOCTL_FDFMTBEG; |
1237 | extern unsigned IOCTL_FDFMTEND; |
1238 | extern unsigned IOCTL_FDFMTTRK; |
1239 | extern unsigned IOCTL_FDGETDRVPRM; |
1240 | extern unsigned IOCTL_FDGETDRVSTAT; |
1241 | extern unsigned IOCTL_FDGETDRVTYP; |
1242 | extern unsigned IOCTL_FDGETFDCSTAT; |
1243 | extern unsigned IOCTL_FDGETMAXERRS; |
1244 | extern unsigned IOCTL_FDGETPRM; |
1245 | extern unsigned IOCTL_FDMSGOFF; |
1246 | extern unsigned IOCTL_FDMSGON; |
1247 | extern unsigned IOCTL_FDPOLLDRVSTAT; |
1248 | extern unsigned IOCTL_FDRAWCMD; |
1249 | extern unsigned IOCTL_FDRESET; |
1250 | extern unsigned IOCTL_FDSETDRVPRM; |
1251 | extern unsigned IOCTL_FDSETEMSGTRESH; |
1252 | extern unsigned IOCTL_FDSETMAXERRS; |
1253 | extern unsigned IOCTL_FDSETPRM; |
1254 | extern unsigned IOCTL_FDTWADDLE; |
1255 | extern unsigned IOCTL_FDWERRORCLR; |
1256 | extern unsigned IOCTL_FDWERRORGET; |
1257 | extern unsigned IOCTL_HDIO_DRIVE_CMD; |
1258 | extern unsigned IOCTL_HDIO_GETGEO; |
1259 | extern unsigned IOCTL_HDIO_GET_32BIT; |
1260 | extern unsigned IOCTL_HDIO_GET_DMA; |
1261 | extern unsigned IOCTL_HDIO_GET_IDENTITY; |
1262 | extern unsigned IOCTL_HDIO_GET_KEEPSETTINGS; |
1263 | extern unsigned IOCTL_HDIO_GET_MULTCOUNT; |
1264 | extern unsigned IOCTL_HDIO_GET_NOWERR; |
1265 | extern unsigned IOCTL_HDIO_GET_UNMASKINTR; |
1266 | extern unsigned IOCTL_HDIO_SET_32BIT; |
1267 | extern unsigned IOCTL_HDIO_SET_DMA; |
1268 | extern unsigned IOCTL_HDIO_SET_KEEPSETTINGS; |
1269 | extern unsigned IOCTL_HDIO_SET_MULTCOUNT; |
1270 | extern unsigned IOCTL_HDIO_SET_NOWERR; |
1271 | extern unsigned IOCTL_HDIO_SET_UNMASKINTR; |
1272 | extern unsigned IOCTL_MTIOCPOS; |
1273 | extern unsigned IOCTL_PPPIOCGASYNCMAP; |
1274 | extern unsigned IOCTL_PPPIOCGDEBUG; |
1275 | extern unsigned IOCTL_PPPIOCGFLAGS; |
1276 | extern unsigned IOCTL_PPPIOCGUNIT; |
1277 | extern unsigned IOCTL_PPPIOCGXASYNCMAP; |
1278 | extern unsigned IOCTL_PPPIOCSASYNCMAP; |
1279 | extern unsigned IOCTL_PPPIOCSDEBUG; |
1280 | extern unsigned IOCTL_PPPIOCSFLAGS; |
1281 | extern unsigned IOCTL_PPPIOCSMAXCID; |
1282 | extern unsigned IOCTL_PPPIOCSMRU; |
1283 | extern unsigned IOCTL_PPPIOCSXASYNCMAP; |
1284 | extern unsigned IOCTL_SIOCDARP; |
1285 | extern unsigned IOCTL_SIOCDRARP; |
1286 | extern unsigned IOCTL_SIOCGARP; |
1287 | extern unsigned IOCTL_SIOCGIFENCAP; |
1288 | extern unsigned IOCTL_SIOCGIFHWADDR; |
1289 | extern unsigned IOCTL_SIOCGIFMAP; |
1290 | extern unsigned IOCTL_SIOCGIFMEM; |
1291 | extern unsigned IOCTL_SIOCGIFNAME; |
1292 | extern unsigned IOCTL_SIOCGIFSLAVE; |
1293 | extern unsigned IOCTL_SIOCGRARP; |
1294 | extern unsigned IOCTL_SIOCGSTAMP; |
1295 | extern unsigned IOCTL_SIOCSARP; |
1296 | extern unsigned IOCTL_SIOCSIFENCAP; |
1297 | extern unsigned IOCTL_SIOCSIFHWADDR; |
1298 | extern unsigned IOCTL_SIOCSIFLINK; |
1299 | extern unsigned IOCTL_SIOCSIFMAP; |
1300 | extern unsigned IOCTL_SIOCSIFMEM; |
1301 | extern unsigned IOCTL_SIOCSIFSLAVE; |
1302 | extern unsigned IOCTL_SIOCSRARP; |
1303 | extern unsigned IOCTL_SNDCTL_COPR_HALT; |
1304 | extern unsigned IOCTL_SNDCTL_COPR_LOAD; |
1305 | extern unsigned IOCTL_SNDCTL_COPR_RCODE; |
1306 | extern unsigned IOCTL_SNDCTL_COPR_RCVMSG; |
1307 | extern unsigned IOCTL_SNDCTL_COPR_RDATA; |
1308 | extern unsigned IOCTL_SNDCTL_COPR_RESET; |
1309 | extern unsigned IOCTL_SNDCTL_COPR_RUN; |
1310 | extern unsigned IOCTL_SNDCTL_COPR_SENDMSG; |
1311 | extern unsigned IOCTL_SNDCTL_COPR_WCODE; |
1312 | extern unsigned IOCTL_SNDCTL_COPR_WDATA; |
1313 | extern unsigned IOCTL_TCFLSH; |
1314 | extern unsigned IOCTL_TCGETA; |
1315 | extern unsigned IOCTL_TCGETS; |
1316 | extern unsigned IOCTL_TCSBRK; |
1317 | extern unsigned IOCTL_TCSBRKP; |
1318 | extern unsigned IOCTL_TCSETA; |
1319 | extern unsigned IOCTL_TCSETAF; |
1320 | extern unsigned IOCTL_TCSETAW; |
1321 | extern unsigned IOCTL_TCSETS; |
1322 | extern unsigned IOCTL_TCSETSF; |
1323 | extern unsigned IOCTL_TCSETSW; |
1324 | extern unsigned IOCTL_TCXONC; |
1325 | extern unsigned IOCTL_TIOCGLCKTRMIOS; |
1326 | extern unsigned IOCTL_TIOCGSOFTCAR; |
1327 | extern unsigned IOCTL_TIOCINQ; |
1328 | extern unsigned IOCTL_TIOCLINUX; |
1329 | extern unsigned IOCTL_TIOCSERCONFIG; |
1330 | extern unsigned IOCTL_TIOCSERGETLSR; |
1331 | extern unsigned IOCTL_TIOCSERGWILD; |
1332 | extern unsigned IOCTL_TIOCSERSWILD; |
1333 | extern unsigned IOCTL_TIOCSLCKTRMIOS; |
1334 | extern unsigned IOCTL_TIOCSSOFTCAR; |
1335 | extern unsigned IOCTL_VT_DISALLOCATE; |
1336 | extern unsigned IOCTL_VT_GETSTATE; |
1337 | extern unsigned IOCTL_VT_RESIZE; |
1338 | extern unsigned IOCTL_VT_RESIZEX; |
1339 | extern unsigned IOCTL_VT_SENDSIG; |
1340 | extern unsigned IOCTL_MTIOCGET; |
1341 | extern unsigned IOCTL_MTIOCTOP; |
1342 | extern unsigned IOCTL_SIOCADDRT; |
1343 | extern unsigned IOCTL_SIOCDELRT; |
1344 | extern unsigned IOCTL_SNDCTL_DSP_GETBLKSIZE; |
1345 | extern unsigned IOCTL_SNDCTL_DSP_GETFMTS; |
1346 | extern unsigned IOCTL_SNDCTL_DSP_NONBLOCK; |
1347 | extern unsigned IOCTL_SNDCTL_DSP_POST; |
1348 | extern unsigned IOCTL_SNDCTL_DSP_RESET; |
1349 | extern unsigned IOCTL_SNDCTL_DSP_SETFMT; |
1350 | extern unsigned IOCTL_SNDCTL_DSP_SETFRAGMENT; |
1351 | extern unsigned IOCTL_SNDCTL_DSP_SPEED; |
1352 | extern unsigned IOCTL_SNDCTL_DSP_STEREO; |
1353 | extern unsigned IOCTL_SNDCTL_DSP_SUBDIVIDE; |
1354 | extern unsigned IOCTL_SNDCTL_DSP_SYNC; |
1355 | extern unsigned IOCTL_SNDCTL_FM_4OP_ENABLE; |
1356 | extern unsigned IOCTL_SNDCTL_FM_LOAD_INSTR; |
1357 | extern unsigned IOCTL_SNDCTL_MIDI_INFO; |
1358 | extern unsigned IOCTL_SNDCTL_MIDI_PRETIME; |
1359 | extern unsigned IOCTL_SNDCTL_SEQ_CTRLRATE; |
1360 | extern unsigned IOCTL_SNDCTL_SEQ_GETINCOUNT; |
1361 | extern unsigned IOCTL_SNDCTL_SEQ_GETOUTCOUNT; |
1362 | extern unsigned IOCTL_SNDCTL_SEQ_NRMIDIS; |
1363 | extern unsigned IOCTL_SNDCTL_SEQ_NRSYNTHS; |
1364 | extern unsigned IOCTL_SNDCTL_SEQ_OUTOFBAND; |
1365 | extern unsigned IOCTL_SNDCTL_SEQ_PANIC; |
1366 | extern unsigned IOCTL_SNDCTL_SEQ_PERCMODE; |
1367 | extern unsigned IOCTL_SNDCTL_SEQ_RESET; |
1368 | extern unsigned IOCTL_SNDCTL_SEQ_RESETSAMPLES; |
1369 | extern unsigned IOCTL_SNDCTL_SEQ_SYNC; |
1370 | extern unsigned IOCTL_SNDCTL_SEQ_TESTMIDI; |
1371 | extern unsigned IOCTL_SNDCTL_SEQ_THRESHOLD; |
1372 | extern unsigned IOCTL_SNDCTL_SYNTH_INFO; |
1373 | extern unsigned IOCTL_SNDCTL_SYNTH_MEMAVL; |
1374 | extern unsigned IOCTL_SNDCTL_TMR_CONTINUE; |
1375 | extern unsigned IOCTL_SNDCTL_TMR_METRONOME; |
1376 | extern unsigned IOCTL_SNDCTL_TMR_SELECT; |
1377 | extern unsigned IOCTL_SNDCTL_TMR_SOURCE; |
1378 | extern unsigned IOCTL_SNDCTL_TMR_START; |
1379 | extern unsigned IOCTL_SNDCTL_TMR_STOP; |
1380 | extern unsigned IOCTL_SNDCTL_TMR_TEMPO; |
1381 | extern unsigned IOCTL_SNDCTL_TMR_TIMEBASE; |
1382 | extern unsigned IOCTL_SOUND_MIXER_READ_ALTPCM; |
1383 | extern unsigned IOCTL_SOUND_MIXER_READ_BASS; |
1384 | extern unsigned IOCTL_SOUND_MIXER_READ_CAPS; |
1385 | extern unsigned IOCTL_SOUND_MIXER_READ_CD; |
1386 | extern unsigned IOCTL_SOUND_MIXER_READ_DEVMASK; |
1387 | extern unsigned IOCTL_SOUND_MIXER_READ_ENHANCE; |
1388 | extern unsigned IOCTL_SOUND_MIXER_READ_IGAIN; |
1389 | extern unsigned IOCTL_SOUND_MIXER_READ_IMIX; |
1390 | extern unsigned IOCTL_SOUND_MIXER_READ_LINE1; |
1391 | extern unsigned IOCTL_SOUND_MIXER_READ_LINE2; |
1392 | extern unsigned IOCTL_SOUND_MIXER_READ_LINE3; |
1393 | extern unsigned IOCTL_SOUND_MIXER_READ_LINE; |
1394 | extern unsigned IOCTL_SOUND_MIXER_READ_LOUD; |
1395 | extern unsigned IOCTL_SOUND_MIXER_READ_MIC; |
1396 | extern unsigned IOCTL_SOUND_MIXER_READ_MUTE; |
1397 | extern unsigned IOCTL_SOUND_MIXER_READ_OGAIN; |
1398 | extern unsigned IOCTL_SOUND_MIXER_READ_PCM; |
1399 | extern unsigned IOCTL_SOUND_MIXER_READ_RECLEV; |
1400 | extern unsigned IOCTL_SOUND_MIXER_READ_RECMASK; |
1401 | extern unsigned IOCTL_SOUND_MIXER_READ_RECSRC; |
1402 | extern unsigned IOCTL_SOUND_MIXER_READ_SPEAKER; |
1403 | extern unsigned IOCTL_SOUND_MIXER_READ_STEREODEVS; |
1404 | extern unsigned IOCTL_SOUND_MIXER_READ_SYNTH; |
1405 | extern unsigned IOCTL_SOUND_MIXER_READ_TREBLE; |
1406 | extern unsigned IOCTL_SOUND_MIXER_READ_VOLUME; |
1407 | extern unsigned IOCTL_SOUND_MIXER_WRITE_ALTPCM; |
1408 | extern unsigned IOCTL_SOUND_MIXER_WRITE_BASS; |
1409 | extern unsigned IOCTL_SOUND_MIXER_WRITE_CD; |
1410 | extern unsigned IOCTL_SOUND_MIXER_WRITE_ENHANCE; |
1411 | extern unsigned IOCTL_SOUND_MIXER_WRITE_IGAIN; |
1412 | extern unsigned IOCTL_SOUND_MIXER_WRITE_IMIX; |
1413 | extern unsigned IOCTL_SOUND_MIXER_WRITE_LINE1; |
1414 | extern unsigned IOCTL_SOUND_MIXER_WRITE_LINE2; |
1415 | extern unsigned IOCTL_SOUND_MIXER_WRITE_LINE3; |
1416 | extern unsigned IOCTL_SOUND_MIXER_WRITE_LINE; |
1417 | extern unsigned IOCTL_SOUND_MIXER_WRITE_LOUD; |
1418 | extern unsigned IOCTL_SOUND_MIXER_WRITE_MIC; |
1419 | extern unsigned IOCTL_SOUND_MIXER_WRITE_MUTE; |
1420 | extern unsigned IOCTL_SOUND_MIXER_WRITE_OGAIN; |
1421 | extern unsigned IOCTL_SOUND_MIXER_WRITE_PCM; |
1422 | extern unsigned IOCTL_SOUND_MIXER_WRITE_RECLEV; |
1423 | extern unsigned IOCTL_SOUND_MIXER_WRITE_RECSRC; |
1424 | extern unsigned IOCTL_SOUND_MIXER_WRITE_SPEAKER; |
1425 | extern unsigned IOCTL_SOUND_MIXER_WRITE_SYNTH; |
1426 | extern unsigned IOCTL_SOUND_MIXER_WRITE_TREBLE; |
1427 | extern unsigned IOCTL_SOUND_MIXER_WRITE_VOLUME; |
1428 | extern unsigned IOCTL_SOUND_PCM_READ_BITS; |
1429 | extern unsigned IOCTL_SOUND_PCM_READ_CHANNELS; |
1430 | extern unsigned IOCTL_SOUND_PCM_READ_FILTER; |
1431 | extern unsigned IOCTL_SOUND_PCM_READ_RATE; |
1432 | extern unsigned IOCTL_SOUND_PCM_WRITE_CHANNELS; |
1433 | extern unsigned IOCTL_SOUND_PCM_WRITE_FILTER; |
1434 | extern unsigned IOCTL_VT_ACTIVATE; |
1435 | extern unsigned IOCTL_VT_GETMODE; |
1436 | extern unsigned IOCTL_VT_OPENQRY; |
1437 | extern unsigned IOCTL_VT_RELDISP; |
1438 | extern unsigned IOCTL_VT_SETMODE; |
1439 | extern unsigned IOCTL_VT_WAITACTIVE; |
1440 | #endif // SANITIZER_LINUX |
1441 | |
1442 | #if SANITIZER_LINUX && !SANITIZER_ANDROID |
1443 | extern unsigned IOCTL_EQL_EMANCIPATE; |
1444 | extern unsigned IOCTL_EQL_ENSLAVE; |
1445 | extern unsigned IOCTL_EQL_GETMASTRCFG; |
1446 | extern unsigned IOCTL_EQL_GETSLAVECFG; |
1447 | extern unsigned IOCTL_EQL_SETMASTRCFG; |
1448 | extern unsigned IOCTL_EQL_SETSLAVECFG; |
1449 | extern unsigned IOCTL_EVIOCGKEYCODE_V2; |
1450 | extern unsigned IOCTL_EVIOCGPROP; |
1451 | extern unsigned IOCTL_EVIOCSKEYCODE_V2; |
1452 | extern unsigned IOCTL_FS_IOC_GETFLAGS; |
1453 | extern unsigned IOCTL_FS_IOC_GETVERSION; |
1454 | extern unsigned IOCTL_FS_IOC_SETFLAGS; |
1455 | extern unsigned IOCTL_FS_IOC_SETVERSION; |
1456 | extern unsigned IOCTL_GIO_CMAP; |
1457 | extern unsigned IOCTL_GIO_FONT; |
1458 | extern unsigned IOCTL_GIO_UNIMAP; |
1459 | extern unsigned IOCTL_GIO_UNISCRNMAP; |
1460 | extern unsigned IOCTL_KDADDIO; |
1461 | extern unsigned IOCTL_KDDELIO; |
1462 | extern unsigned IOCTL_KDGETKEYCODE; |
1463 | extern unsigned IOCTL_KDGKBDIACR; |
1464 | extern unsigned IOCTL_KDGKBENT; |
1465 | extern unsigned IOCTL_KDGKBLED; |
1466 | extern unsigned IOCTL_KDGKBMETA; |
1467 | extern unsigned IOCTL_KDGKBSENT; |
1468 | extern unsigned IOCTL_KDMAPDISP; |
1469 | extern unsigned IOCTL_KDSETKEYCODE; |
1470 | extern unsigned IOCTL_KDSIGACCEPT; |
1471 | extern unsigned IOCTL_KDSKBDIACR; |
1472 | extern unsigned IOCTL_KDSKBENT; |
1473 | extern unsigned IOCTL_KDSKBLED; |
1474 | extern unsigned IOCTL_KDSKBMETA; |
1475 | extern unsigned IOCTL_KDSKBSENT; |
1476 | extern unsigned IOCTL_KDUNMAPDISP; |
1477 | extern unsigned IOCTL_LPABORT; |
1478 | extern unsigned IOCTL_LPABORTOPEN; |
1479 | extern unsigned IOCTL_LPCAREFUL; |
1480 | extern unsigned IOCTL_LPCHAR; |
1481 | extern unsigned IOCTL_LPGETIRQ; |
1482 | extern unsigned IOCTL_LPGETSTATUS; |
1483 | extern unsigned IOCTL_LPRESET; |
1484 | extern unsigned IOCTL_LPSETIRQ; |
1485 | extern unsigned IOCTL_LPTIME; |
1486 | extern unsigned IOCTL_LPWAIT; |
1487 | extern unsigned IOCTL_MTIOCGETCONFIG; |
1488 | extern unsigned IOCTL_MTIOCSETCONFIG; |
1489 | extern unsigned IOCTL_PIO_CMAP; |
1490 | extern unsigned IOCTL_PIO_FONT; |
1491 | extern unsigned IOCTL_PIO_UNIMAP; |
1492 | extern unsigned IOCTL_PIO_UNIMAPCLR; |
1493 | extern unsigned IOCTL_PIO_UNISCRNMAP; |
1494 | extern unsigned IOCTL_SCSI_IOCTL_GET_IDLUN; |
1495 | extern unsigned IOCTL_SCSI_IOCTL_PROBE_HOST; |
1496 | extern unsigned IOCTL_SCSI_IOCTL_TAGGED_DISABLE; |
1497 | extern unsigned IOCTL_SCSI_IOCTL_TAGGED_ENABLE; |
1498 | extern unsigned IOCTL_SIOCAIPXITFCRT; |
1499 | extern unsigned IOCTL_SIOCAIPXPRISLT; |
1500 | extern unsigned IOCTL_SIOCAX25ADDUID; |
1501 | extern unsigned IOCTL_SIOCAX25DELUID; |
1502 | extern unsigned IOCTL_SIOCAX25GETPARMS; |
1503 | extern unsigned IOCTL_SIOCAX25GETUID; |
1504 | extern unsigned IOCTL_SIOCAX25NOUID; |
1505 | extern unsigned IOCTL_SIOCAX25SETPARMS; |
1506 | extern unsigned IOCTL_SIOCDEVPLIP; |
1507 | extern unsigned IOCTL_SIOCIPXCFGDATA; |
1508 | extern unsigned IOCTL_SIOCNRDECOBS; |
1509 | extern unsigned IOCTL_SIOCNRGETPARMS; |
1510 | extern unsigned IOCTL_SIOCNRRTCTL; |
1511 | extern unsigned IOCTL_SIOCNRSETPARMS; |
1512 | extern unsigned IOCTL_SNDCTL_DSP_GETISPACE; |
1513 | extern unsigned IOCTL_SNDCTL_DSP_GETOSPACE; |
1514 | extern unsigned IOCTL_TIOCGSERIAL; |
1515 | extern unsigned IOCTL_TIOCSERGETMULTI; |
1516 | extern unsigned IOCTL_TIOCSERSETMULTI; |
1517 | extern unsigned IOCTL_TIOCSSERIAL; |
1518 | extern unsigned IOCTL_GIO_SCRNMAP; |
1519 | extern unsigned IOCTL_KDDISABIO; |
1520 | extern unsigned IOCTL_KDENABIO; |
1521 | extern unsigned IOCTL_KDGETLED; |
1522 | extern unsigned IOCTL_KDGETMODE; |
1523 | extern unsigned IOCTL_KDGKBMODE; |
1524 | extern unsigned IOCTL_KDGKBTYPE; |
1525 | extern unsigned IOCTL_KDMKTONE; |
1526 | extern unsigned IOCTL_KDSETLED; |
1527 | extern unsigned IOCTL_KDSETMODE; |
1528 | extern unsigned IOCTL_KDSKBMODE; |
1529 | extern unsigned IOCTL_KIOCSOUND; |
1530 | extern unsigned IOCTL_PIO_SCRNMAP; |
1531 | #endif |
1532 | |
1533 | # if SANITIZER_GLIBC |
1534 | struct __sanitizer_servent { |
1535 | char *s_name; |
1536 | char **s_aliases; |
1537 | int s_port; |
1538 | char *s_proto; |
1539 | }; |
1540 | # endif |
1541 | |
1542 | extern const int si_SEGV_MAPERR; |
1543 | extern const int si_SEGV_ACCERR; |
1544 | } // namespace __sanitizer |
1545 | |
1546 | #define CHECK_TYPE_SIZE(TYPE) \ |
1547 | COMPILER_CHECK(sizeof(__sanitizer_##TYPE) == sizeof(TYPE)) |
1548 | |
1549 | #define CHECK_SIZE_AND_OFFSET(CLASS, MEMBER) \ |
1550 | COMPILER_CHECK(sizeof(((__sanitizer_##CLASS *)NULL)->MEMBER) == \ |
1551 | sizeof(((CLASS *)NULL)->MEMBER)); \ |
1552 | COMPILER_CHECK(offsetof(__sanitizer_##CLASS, MEMBER) == \ |
1553 | offsetof(CLASS, MEMBER)) |
1554 | |
1555 | // For sigaction, which is a function and struct at the same time, |
1556 | // and thus requires explicit "struct" in sizeof() expression. |
1557 | #define CHECK_STRUCT_SIZE_AND_OFFSET(CLASS, MEMBER) \ |
1558 | COMPILER_CHECK(sizeof(((struct __sanitizer_##CLASS *)NULL)->MEMBER) == \ |
1559 | sizeof(((struct CLASS *)NULL)->MEMBER)); \ |
1560 | COMPILER_CHECK(offsetof(struct __sanitizer_##CLASS, MEMBER) == \ |
1561 | offsetof(struct CLASS, MEMBER)) |
1562 | |
1563 | #define SIGACTION_SYMNAME sigaction |
1564 | |
1565 | # if SANITIZER_LINUX |
1566 | typedef void *__sanitizer_timer_t; |
1567 | # endif |
1568 | |
1569 | #endif // SANITIZER_LINUX || SANITIZER_APPLE || SANITIZER_HAIKU |
1570 | |
1571 | #endif |
1572 | |