1 //===-- sanitizer_platform_limits_freebsd.h -------------------------------===// 2 // 3 // The LLVM Compiler Infrastructure 4 // 5 // This file is distributed under the University of Illinois Open Source 6 // License. See LICENSE.TXT for details. 7 // 8 //===----------------------------------------------------------------------===// 9 // 10 // This file is a part of Sanitizer common code. 11 // 12 // Sizes and layouts of platform-specific FreeBSD data structures. 13 //===----------------------------------------------------------------------===// 14 15 #ifndef SANITIZER_PLATFORM_LIMITS_FREEBSD_H 16 #define SANITIZER_PLATFORM_LIMITS_FREEBSD_H 17 18 #if SANITIZER_FREEBSD 19 20 #include "sanitizer_internal_defs.h" 21 #include "sanitizer_platform.h" 22 23 #include "sanitizer_platform_limits_posix.h" 24 25 // FreeBSD's dlopen() returns a pointer to an Obj_Entry structure that 26 // incorporates the map structure. 27 # define GET_LINK_MAP_BY_DLOPEN_HANDLE(handle) \ 28 ((link_map*)((handle) == nullptr ? nullptr : ((char*)(handle) + 560))) 29 // Get sys/_types.h, because that tells us whether 64-bit inodes are 30 // used in struct dirent below. 31 #include <sys/_types.h> 32 33 namespace __sanitizer { 34 extern unsigned struct_utsname_sz; 35 extern unsigned struct_stat_sz; 36 #if defined(__powerpc64__) 37 const unsigned struct___old_kernel_stat_sz = 0; 38 #else 39 const unsigned struct___old_kernel_stat_sz = 32; 40 #endif 41 extern unsigned struct_rusage_sz; 42 extern unsigned siginfo_t_sz; 43 extern unsigned struct_itimerval_sz; 44 extern unsigned pthread_t_sz; 45 extern unsigned pthread_mutex_t_sz; 46 extern unsigned pthread_cond_t_sz; 47 extern unsigned pid_t_sz; 48 extern unsigned timeval_sz; 49 extern unsigned uid_t_sz; 50 extern unsigned gid_t_sz; 51 extern unsigned fpos_t_sz; 52 extern unsigned mbstate_t_sz; 53 extern unsigned struct_timezone_sz; 54 extern unsigned struct_tms_sz; 55 extern unsigned struct_itimerspec_sz; 56 extern unsigned struct_sigevent_sz; 57 extern unsigned struct_sched_param_sz; 58 extern unsigned struct_statfs64_sz; 59 extern unsigned struct_statfs_sz; 60 extern unsigned struct_sockaddr_sz; 61 extern unsigned ucontext_t_sz; 62 extern unsigned struct_rlimit_sz; 63 extern unsigned struct_utimbuf_sz; 64 extern unsigned struct_timespec_sz; 65 extern unsigned struct_regmatch_sz; 66 extern unsigned struct_regex_sz; 67 extern unsigned struct_FTS_sz; 68 extern unsigned struct_FTSENT_sz; 69 extern const int unvis_valid; 70 extern const int unvis_validpush; 71 72 struct __sanitizer_iocb { 73 u64 aio_data; 74 u32 aio_key_or_aio_reserved1; // Simply crazy. 75 u32 aio_reserved1_or_aio_key; // Luckily, we don't need these. 76 u16 aio_lio_opcode; 77 s16 aio_reqprio; 78 u32 aio_fildes; 79 u64 aio_buf; 80 u64 aio_nbytes; 81 s64 aio_offset; 82 u64 aio_reserved2; 83 u64 aio_reserved3; 84 }; 85 86 struct __sanitizer_io_event { 87 u64 data; 88 u64 obj; 89 u64 res; 90 u64 res2; 91 }; 92 93 const unsigned iocb_cmd_pread = 0; 94 const unsigned iocb_cmd_pwrite = 1; 95 const unsigned iocb_cmd_preadv = 7; 96 const unsigned iocb_cmd_pwritev = 8; 97 98 struct __sanitizer___sysctl_args { 99 int *name; 100 int nlen; 101 void *oldval; 102 uptr *oldlenp; 103 void *newval; 104 uptr newlen; 105 unsigned long ___unused[4]; 106 }; 107 108 struct __sanitizer_ipc_perm { 109 unsigned int cuid; 110 unsigned int cgid; 111 unsigned int uid; 112 unsigned int gid; 113 unsigned short mode; 114 unsigned short seq; 115 long key; 116 }; 117 118 struct __sanitizer_shmid_ds { 119 __sanitizer_ipc_perm shm_perm; 120 unsigned long shm_segsz; 121 unsigned int shm_lpid; 122 unsigned int shm_cpid; 123 int shm_nattch; 124 unsigned long shm_atime; 125 unsigned long shm_dtime; 126 unsigned long shm_ctime; 127 }; 128 129 extern unsigned struct_msqid_ds_sz; 130 extern unsigned struct_mq_attr_sz; 131 extern unsigned struct_timeb_sz; 132 extern unsigned struct_statvfs_sz; 133 134 struct __sanitizer_iovec { 135 void *iov_base; 136 uptr iov_len; 137 }; 138 139 struct __sanitizer_ifaddrs { 140 struct __sanitizer_ifaddrs *ifa_next; 141 char *ifa_name; 142 unsigned int ifa_flags; 143 void *ifa_addr; // (struct sockaddr *) 144 void *ifa_netmask; // (struct sockaddr *) 145 # undef ifa_dstaddr 146 void *ifa_dstaddr; // (struct sockaddr *) 147 void *ifa_data; 148 }; 149 150 typedef unsigned __sanitizer_pthread_key_t; 151 152 struct __sanitizer_passwd { 153 char *pw_name; 154 char *pw_passwd; 155 int pw_uid; 156 int pw_gid; 157 long pw_change; 158 char *pw_class; 159 char *pw_gecos; 160 char *pw_dir; 161 char *pw_shell; 162 long pw_expire; 163 int pw_fields; 164 }; 165 166 struct __sanitizer_group { 167 char *gr_name; 168 char *gr_passwd; 169 int gr_gid; 170 char **gr_mem; 171 }; 172 173 #if defined(__LP64___) 174 typedef long long __sanitizer_time_t; 175 #else 176 typedef long __sanitizer_time_t; 177 #endif 178 179 typedef long __sanitizer_suseconds_t; 180 181 struct __sanitizer_timeval { 182 __sanitizer_time_t tv_sec; 183 __sanitizer_suseconds_t tv_usec; 184 }; 185 186 struct __sanitizer_itimerval { 187 struct __sanitizer_timeval it_interval; 188 struct __sanitizer_timeval it_value; 189 }; 190 191 struct __sanitizer_timeb { 192 __sanitizer_time_t time; 193 unsigned short millitm; 194 short timezone; 195 short dstflag; 196 }; 197 198 struct __sanitizer_ether_addr { 199 u8 octet[6]; 200 }; 201 202 struct __sanitizer_tm { 203 int tm_sec; 204 int tm_min; 205 int tm_hour; 206 int tm_mday; 207 int tm_mon; 208 int tm_year; 209 int tm_wday; 210 int tm_yday; 211 int tm_isdst; 212 long int tm_gmtoff; 213 const char *tm_zone; 214 }; 215 216 struct __sanitizer_msghdr { 217 void *msg_name; 218 unsigned msg_namelen; 219 struct __sanitizer_iovec *msg_iov; 220 unsigned msg_iovlen; 221 void *msg_control; 222 unsigned msg_controllen; 223 int msg_flags; 224 }; 225 226 struct __sanitizer_cmsghdr { 227 unsigned cmsg_len; 228 int cmsg_level; 229 int cmsg_type; 230 }; 231 232 struct __sanitizer_dirent { 233 #if defined(__INO64) 234 unsigned long long d_fileno; 235 unsigned long long d_off; 236 #else 237 unsigned int d_fileno; 238 #endif 239 unsigned short d_reclen; 240 // more fields that we don't care about 241 }; 242 243 // 'clock_t' is 32 bits wide on x64 FreeBSD 244 typedef int __sanitizer_clock_t; 245 typedef int __sanitizer_clockid_t; 246 247 #if defined(_LP64) || defined(__x86_64__) || defined(__powerpc__)\ 248 || defined(__mips__) 249 typedef unsigned __sanitizer___kernel_uid_t; 250 typedef unsigned __sanitizer___kernel_gid_t; 251 #else 252 typedef unsigned short __sanitizer___kernel_uid_t; 253 typedef unsigned short __sanitizer___kernel_gid_t; 254 #endif 255 typedef long long __sanitizer___kernel_off_t; 256 257 #if defined(__powerpc__) || defined(__mips__) 258 typedef unsigned int __sanitizer___kernel_old_uid_t; 259 typedef unsigned int __sanitizer___kernel_old_gid_t; 260 #else 261 typedef unsigned short __sanitizer___kernel_old_uid_t; 262 typedef unsigned short __sanitizer___kernel_old_gid_t; 263 #endif 264 265 typedef long long __sanitizer___kernel_loff_t; 266 typedef struct { 267 unsigned long fds_bits[1024 / (8 * sizeof(long))]; 268 } __sanitizer___kernel_fd_set; 269 270 // This thing depends on the platform. We are only interested in the upper 271 // limit. Verified with a compiler assert in .cc. 272 const int pthread_attr_t_max_sz = 128; 273 union __sanitizer_pthread_attr_t { 274 char size[pthread_attr_t_max_sz]; // NOLINT 275 void *align; 276 }; 277 278 const unsigned old_sigset_t_sz = sizeof(unsigned long); 279 280 struct __sanitizer_sigset_t { 281 // uint32_t * 4 282 unsigned int __bits[4]; 283 }; 284 285 typedef __sanitizer_sigset_t __sanitizer_kernel_sigset_t; 286 287 struct __sanitizer_siginfo { 288 // The size is determined by looking at sizeof of real siginfo_t on linux. 289 u64 opaque[128 / sizeof(u64)]; 290 }; 291 292 using __sanitizer_sighandler_ptr = void (*)(int sig); 293 using __sanitizer_sigactionhandler_ptr = 294 void (*)(int sig, __sanitizer_siginfo *siginfo, void *uctx); 295 296 struct __sanitizer_sigaction { 297 union { 298 __sanitizer_sigactionhandler_ptr sigaction; 299 __sanitizer_sighandler_ptr handler; 300 }; 301 int sa_flags; 302 __sanitizer_sigset_t sa_mask; 303 }; 304 305 struct __sanitizer_sem_t { 306 u32 data[4]; 307 }; 308 309 extern const uptr sig_ign; 310 extern const uptr sig_dfl; 311 extern const uptr sig_err; 312 extern const uptr sa_siginfo; 313 314 extern int af_inet; 315 extern int af_inet6; 316 uptr __sanitizer_in_addr_sz(int af); 317 318 struct __sanitizer_dl_phdr_info { 319 uptr dlpi_addr; 320 const char *dlpi_name; 321 const void *dlpi_phdr; 322 short dlpi_phnum; 323 }; 324 325 extern unsigned struct_ElfW_Phdr_sz; 326 327 struct __sanitizer_addrinfo { 328 int ai_flags; 329 int ai_family; 330 int ai_socktype; 331 int ai_protocol; 332 unsigned ai_addrlen; 333 char *ai_canonname; 334 void *ai_addr; 335 struct __sanitizer_addrinfo *ai_next; 336 }; 337 338 struct __sanitizer_hostent { 339 char *h_name; 340 char **h_aliases; 341 int h_addrtype; 342 int h_length; 343 char **h_addr_list; 344 }; 345 346 struct __sanitizer_pollfd { 347 int fd; 348 short events; 349 short revents; 350 }; 351 352 typedef unsigned __sanitizer_nfds_t; 353 354 struct __sanitizer_glob_t { 355 uptr gl_pathc; 356 uptr gl_matchc; 357 uptr gl_offs; 358 int gl_flags; 359 char **gl_pathv; 360 int (*gl_errfunc)(const char*, int); 361 void (*gl_closedir)(void *dirp); 362 struct dirent *(*gl_readdir)(void *dirp); 363 void *(*gl_opendir)(const char*); 364 int (*gl_lstat)(const char*, void* /* struct stat* */); 365 int (*gl_stat)(const char*, void* /* struct stat* */); 366 }; 367 368 extern int glob_nomatch; 369 extern int glob_altdirfunc; 370 371 extern unsigned path_max; 372 373 struct __sanitizer_wordexp_t { 374 uptr we_wordc; 375 char **we_wordv; 376 uptr we_offs; 377 char *we_strings; 378 uptr we_nbytes; 379 }; 380 381 typedef void __sanitizer_FILE; 382 383 extern unsigned struct_shminfo_sz; 384 extern unsigned struct_shm_info_sz; 385 extern int shmctl_ipc_stat; 386 extern int shmctl_ipc_info; 387 extern int shmctl_shm_info; 388 extern int shmctl_shm_stat; 389 390 extern unsigned struct_utmpx_sz; 391 392 extern int map_fixed; 393 394 // ioctl arguments 395 struct __sanitizer_ifconf { 396 int ifc_len; 397 union { 398 void *ifcu_req; 399 } ifc_ifcu; 400 }; 401 402 #define IOC_NRBITS 8 403 #define IOC_TYPEBITS 8 404 #if defined(__powerpc__) || defined(__powerpc64__) || defined(__mips__) 405 #define IOC_SIZEBITS 13 406 #define IOC_DIRBITS 3 407 #define IOC_NONE 1U 408 #define IOC_WRITE 4U 409 #define IOC_READ 2U 410 #else 411 #define IOC_SIZEBITS 14 412 #define IOC_DIRBITS 2 413 #define IOC_NONE 0U 414 #define IOC_WRITE 1U 415 #define IOC_READ 2U 416 #endif 417 #define IOC_NRMASK ((1 << IOC_NRBITS) - 1) 418 #define IOC_TYPEMASK ((1 << IOC_TYPEBITS) - 1) 419 #define IOC_SIZEMASK ((1 << IOC_SIZEBITS) - 1) 420 #if defined(IOC_DIRMASK) 421 #undef IOC_DIRMASK 422 #endif 423 #define IOC_DIRMASK ((1 << IOC_DIRBITS) - 1) 424 #define IOC_NRSHIFT 0 425 #define IOC_TYPESHIFT (IOC_NRSHIFT + IOC_NRBITS) 426 #define IOC_SIZESHIFT (IOC_TYPESHIFT + IOC_TYPEBITS) 427 #define IOC_DIRSHIFT (IOC_SIZESHIFT + IOC_SIZEBITS) 428 #define EVIOC_EV_MAX 0x1f 429 #define EVIOC_ABS_MAX 0x3f 430 431 #define IOC_DIR(nr) (((nr) >> IOC_DIRSHIFT) & IOC_DIRMASK) 432 #define IOC_TYPE(nr) (((nr) >> IOC_TYPESHIFT) & IOC_TYPEMASK) 433 #define IOC_NR(nr) (((nr) >> IOC_NRSHIFT) & IOC_NRMASK) 434 #define IOC_SIZE(nr) (((nr) >> IOC_SIZESHIFT) & IOC_SIZEMASK) 435 436 extern unsigned struct_ifreq_sz; 437 extern unsigned struct_termios_sz; 438 extern unsigned struct_winsize_sz; 439 440 extern unsigned struct_copr_buffer_sz; 441 extern unsigned struct_copr_debug_buf_sz; 442 extern unsigned struct_copr_msg_sz; 443 extern unsigned struct_midi_info_sz; 444 extern unsigned struct_mtget_sz; 445 extern unsigned struct_mtop_sz; 446 extern unsigned struct_rtentry_sz; 447 extern unsigned struct_sbi_instrument_sz; 448 extern unsigned struct_seq_event_rec_sz; 449 extern unsigned struct_synth_info_sz; 450 extern unsigned struct_vt_mode_sz; 451 452 extern const unsigned long __sanitizer_bufsiz; 453 extern unsigned struct_audio_buf_info_sz; 454 extern unsigned struct_ppp_stats_sz; 455 extern unsigned struct_sioc_sg_req_sz; 456 extern unsigned struct_sioc_vif_req_sz; 457 458 // ioctl request identifiers 459 460 // A special value to mark ioctls that are not present on the target platform, 461 // when it can not be determined without including any system headers. 462 extern const unsigned IOCTL_NOT_PRESENT; 463 464 extern unsigned IOCTL_FIOASYNC; 465 extern unsigned IOCTL_FIOCLEX; 466 extern unsigned IOCTL_FIOGETOWN; 467 extern unsigned IOCTL_FIONBIO; 468 extern unsigned IOCTL_FIONCLEX; 469 extern unsigned IOCTL_FIOSETOWN; 470 extern unsigned IOCTL_SIOCADDMULTI; 471 extern unsigned IOCTL_SIOCATMARK; 472 extern unsigned IOCTL_SIOCDELMULTI; 473 extern unsigned IOCTL_SIOCGIFADDR; 474 extern unsigned IOCTL_SIOCGIFBRDADDR; 475 extern unsigned IOCTL_SIOCGIFCONF; 476 extern unsigned IOCTL_SIOCGIFDSTADDR; 477 extern unsigned IOCTL_SIOCGIFFLAGS; 478 extern unsigned IOCTL_SIOCGIFMETRIC; 479 extern unsigned IOCTL_SIOCGIFMTU; 480 extern unsigned IOCTL_SIOCGIFNETMASK; 481 extern unsigned IOCTL_SIOCGPGRP; 482 extern unsigned IOCTL_SIOCSIFADDR; 483 extern unsigned IOCTL_SIOCSIFBRDADDR; 484 extern unsigned IOCTL_SIOCSIFDSTADDR; 485 extern unsigned IOCTL_SIOCSIFFLAGS; 486 extern unsigned IOCTL_SIOCSIFMETRIC; 487 extern unsigned IOCTL_SIOCSIFMTU; 488 extern unsigned IOCTL_SIOCSIFNETMASK; 489 extern unsigned IOCTL_SIOCSPGRP; 490 extern unsigned IOCTL_TIOCCONS; 491 extern unsigned IOCTL_TIOCEXCL; 492 extern unsigned IOCTL_TIOCGETD; 493 extern unsigned IOCTL_TIOCGPGRP; 494 extern unsigned IOCTL_TIOCGWINSZ; 495 extern unsigned IOCTL_TIOCMBIC; 496 extern unsigned IOCTL_TIOCMBIS; 497 extern unsigned IOCTL_TIOCMGET; 498 extern unsigned IOCTL_TIOCMSET; 499 extern unsigned IOCTL_TIOCNOTTY; 500 extern unsigned IOCTL_TIOCNXCL; 501 extern unsigned IOCTL_TIOCOUTQ; 502 extern unsigned IOCTL_TIOCPKT; 503 extern unsigned IOCTL_TIOCSCTTY; 504 extern unsigned IOCTL_TIOCSETD; 505 extern unsigned IOCTL_TIOCSPGRP; 506 extern unsigned IOCTL_TIOCSTI; 507 extern unsigned IOCTL_TIOCSWINSZ; 508 extern unsigned IOCTL_SIOCGETSGCNT; 509 extern unsigned IOCTL_SIOCGETVIFCNT; 510 extern unsigned IOCTL_MTIOCGET; 511 extern unsigned IOCTL_MTIOCTOP; 512 extern unsigned IOCTL_SIOCADDRT; 513 extern unsigned IOCTL_SIOCDELRT; 514 extern unsigned IOCTL_SNDCTL_DSP_GETBLKSIZE; 515 extern unsigned IOCTL_SNDCTL_DSP_GETFMTS; 516 extern unsigned IOCTL_SNDCTL_DSP_NONBLOCK; 517 extern unsigned IOCTL_SNDCTL_DSP_POST; 518 extern unsigned IOCTL_SNDCTL_DSP_RESET; 519 extern unsigned IOCTL_SNDCTL_DSP_SETFMT; 520 extern unsigned IOCTL_SNDCTL_DSP_SETFRAGMENT; 521 extern unsigned IOCTL_SNDCTL_DSP_SPEED; 522 extern unsigned IOCTL_SNDCTL_DSP_STEREO; 523 extern unsigned IOCTL_SNDCTL_DSP_SUBDIVIDE; 524 extern unsigned IOCTL_SNDCTL_DSP_SYNC; 525 extern unsigned IOCTL_SNDCTL_FM_4OP_ENABLE; 526 extern unsigned IOCTL_SNDCTL_FM_LOAD_INSTR; 527 extern unsigned IOCTL_SNDCTL_MIDI_INFO; 528 extern unsigned IOCTL_SNDCTL_MIDI_PRETIME; 529 extern unsigned IOCTL_SNDCTL_SEQ_CTRLRATE; 530 extern unsigned IOCTL_SNDCTL_SEQ_GETINCOUNT; 531 extern unsigned IOCTL_SNDCTL_SEQ_GETOUTCOUNT; 532 extern unsigned IOCTL_SNDCTL_SEQ_NRMIDIS; 533 extern unsigned IOCTL_SNDCTL_SEQ_NRSYNTHS; 534 extern unsigned IOCTL_SNDCTL_SEQ_OUTOFBAND; 535 extern unsigned IOCTL_SNDCTL_SEQ_PANIC; 536 extern unsigned IOCTL_SNDCTL_SEQ_PERCMODE; 537 extern unsigned IOCTL_SNDCTL_SEQ_RESET; 538 extern unsigned IOCTL_SNDCTL_SEQ_RESETSAMPLES; 539 extern unsigned IOCTL_SNDCTL_SEQ_SYNC; 540 extern unsigned IOCTL_SNDCTL_SEQ_TESTMIDI; 541 extern unsigned IOCTL_SNDCTL_SEQ_THRESHOLD; 542 extern unsigned IOCTL_SNDCTL_SYNTH_INFO; 543 extern unsigned IOCTL_SNDCTL_SYNTH_MEMAVL; 544 extern unsigned IOCTL_SNDCTL_TMR_CONTINUE; 545 extern unsigned IOCTL_SNDCTL_TMR_METRONOME; 546 extern unsigned IOCTL_SNDCTL_TMR_SELECT; 547 extern unsigned IOCTL_SNDCTL_TMR_SOURCE; 548 extern unsigned IOCTL_SNDCTL_TMR_START; 549 extern unsigned IOCTL_SNDCTL_TMR_STOP; 550 extern unsigned IOCTL_SNDCTL_TMR_TEMPO; 551 extern unsigned IOCTL_SNDCTL_TMR_TIMEBASE; 552 extern unsigned IOCTL_SOUND_MIXER_READ_ALTPCM; 553 extern unsigned IOCTL_SOUND_MIXER_READ_BASS; 554 extern unsigned IOCTL_SOUND_MIXER_READ_CAPS; 555 extern unsigned IOCTL_SOUND_MIXER_READ_CD; 556 extern unsigned IOCTL_SOUND_MIXER_READ_DEVMASK; 557 extern unsigned IOCTL_SOUND_MIXER_READ_ENHANCE; 558 extern unsigned IOCTL_SOUND_MIXER_READ_IGAIN; 559 extern unsigned IOCTL_SOUND_MIXER_READ_IMIX; 560 extern unsigned IOCTL_SOUND_MIXER_READ_LINE1; 561 extern unsigned IOCTL_SOUND_MIXER_READ_LINE2; 562 extern unsigned IOCTL_SOUND_MIXER_READ_LINE3; 563 extern unsigned IOCTL_SOUND_MIXER_READ_LINE; 564 extern unsigned IOCTL_SOUND_MIXER_READ_LOUD; 565 extern unsigned IOCTL_SOUND_MIXER_READ_MIC; 566 extern unsigned IOCTL_SOUND_MIXER_READ_MUTE; 567 extern unsigned IOCTL_SOUND_MIXER_READ_OGAIN; 568 extern unsigned IOCTL_SOUND_MIXER_READ_PCM; 569 extern unsigned IOCTL_SOUND_MIXER_READ_RECLEV; 570 extern unsigned IOCTL_SOUND_MIXER_READ_RECMASK; 571 extern unsigned IOCTL_SOUND_MIXER_READ_RECSRC; 572 extern unsigned IOCTL_SOUND_MIXER_READ_SPEAKER; 573 extern unsigned IOCTL_SOUND_MIXER_READ_STEREODEVS; 574 extern unsigned IOCTL_SOUND_MIXER_READ_SYNTH; 575 extern unsigned IOCTL_SOUND_MIXER_READ_TREBLE; 576 extern unsigned IOCTL_SOUND_MIXER_READ_VOLUME; 577 extern unsigned IOCTL_SOUND_MIXER_WRITE_ALTPCM; 578 extern unsigned IOCTL_SOUND_MIXER_WRITE_BASS; 579 extern unsigned IOCTL_SOUND_MIXER_WRITE_CD; 580 extern unsigned IOCTL_SOUND_MIXER_WRITE_ENHANCE; 581 extern unsigned IOCTL_SOUND_MIXER_WRITE_IGAIN; 582 extern unsigned IOCTL_SOUND_MIXER_WRITE_IMIX; 583 extern unsigned IOCTL_SOUND_MIXER_WRITE_LINE1; 584 extern unsigned IOCTL_SOUND_MIXER_WRITE_LINE2; 585 extern unsigned IOCTL_SOUND_MIXER_WRITE_LINE3; 586 extern unsigned IOCTL_SOUND_MIXER_WRITE_LINE; 587 extern unsigned IOCTL_SOUND_MIXER_WRITE_LOUD; 588 extern unsigned IOCTL_SOUND_MIXER_WRITE_MIC; 589 extern unsigned IOCTL_SOUND_MIXER_WRITE_MUTE; 590 extern unsigned IOCTL_SOUND_MIXER_WRITE_OGAIN; 591 extern unsigned IOCTL_SOUND_MIXER_WRITE_PCM; 592 extern unsigned IOCTL_SOUND_MIXER_WRITE_RECLEV; 593 extern unsigned IOCTL_SOUND_MIXER_WRITE_RECSRC; 594 extern unsigned IOCTL_SOUND_MIXER_WRITE_SPEAKER; 595 extern unsigned IOCTL_SOUND_MIXER_WRITE_SYNTH; 596 extern unsigned IOCTL_SOUND_MIXER_WRITE_TREBLE; 597 extern unsigned IOCTL_SOUND_MIXER_WRITE_VOLUME; 598 extern unsigned IOCTL_SOUND_PCM_READ_BITS; 599 extern unsigned IOCTL_SOUND_PCM_READ_CHANNELS; 600 extern unsigned IOCTL_SOUND_PCM_READ_FILTER; 601 extern unsigned IOCTL_SOUND_PCM_READ_RATE; 602 extern unsigned IOCTL_SOUND_PCM_WRITE_CHANNELS; 603 extern unsigned IOCTL_SOUND_PCM_WRITE_FILTER; 604 extern unsigned IOCTL_VT_ACTIVATE; 605 extern unsigned IOCTL_VT_GETMODE; 606 extern unsigned IOCTL_VT_OPENQRY; 607 extern unsigned IOCTL_VT_RELDISP; 608 extern unsigned IOCTL_VT_SETMODE; 609 extern unsigned IOCTL_VT_WAITACTIVE; 610 extern unsigned IOCTL_GIO_SCRNMAP; 611 extern unsigned IOCTL_KDDISABIO; 612 extern unsigned IOCTL_KDENABIO; 613 extern unsigned IOCTL_KDGETLED; 614 extern unsigned IOCTL_KDGETMODE; 615 extern unsigned IOCTL_KDGKBMODE; 616 extern unsigned IOCTL_KDGKBTYPE; 617 extern unsigned IOCTL_KDMKTONE; 618 extern unsigned IOCTL_KDSETLED; 619 extern unsigned IOCTL_KDSETMODE; 620 extern unsigned IOCTL_KDSKBMODE; 621 622 extern const int si_SEGV_MAPERR; 623 extern const int si_SEGV_ACCERR; 624 625 struct __sanitizer_cap_rights { 626 u64 cr_rights[2]; 627 }; 628 629 typedef struct __sanitizer_cap_rights __sanitizer_cap_rights_t; 630 extern unsigned struct_cap_rights_sz; 631 632 extern unsigned struct_fstab_sz; 633 } // namespace __sanitizer 634 635 #define CHECK_TYPE_SIZE(TYPE) \ 636 COMPILER_CHECK(sizeof(__sanitizer_##TYPE) == sizeof(TYPE)) 637 638 #define CHECK_SIZE_AND_OFFSET(CLASS, MEMBER) \ 639 COMPILER_CHECK(sizeof(((__sanitizer_##CLASS *) NULL)->MEMBER) == \ 640 sizeof(((CLASS *) NULL)->MEMBER)); \ 641 COMPILER_CHECK(offsetof(__sanitizer_##CLASS, MEMBER) == \ 642 offsetof(CLASS, MEMBER)) 643 644 // For sigaction, which is a function and struct at the same time, 645 // and thus requires explicit "struct" in sizeof() expression. 646 #define CHECK_STRUCT_SIZE_AND_OFFSET(CLASS, MEMBER) \ 647 COMPILER_CHECK(sizeof(((struct __sanitizer_##CLASS *) NULL)->MEMBER) == \ 648 sizeof(((struct CLASS *) NULL)->MEMBER)); \ 649 COMPILER_CHECK(offsetof(struct __sanitizer_##CLASS, MEMBER) == \ 650 offsetof(struct CLASS, MEMBER)) 651 652 #define SIGACTION_SYMNAME sigaction 653 654 #endif 655 656 #endif // SANITIZER_FREEBSD 657