1 pub type c_char = i8; 2 pub type wchar_t = i32; 3 pub type nlink_t = u64; 4 pub type blksize_t = ::c_long; 5 pub type __u64 = ::c_ulonglong; 6 pub type greg_t = i64; 7 8 s! { 9 pub struct stat { 10 pub st_dev: ::dev_t, 11 pub st_ino: ::ino_t, 12 pub st_nlink: ::nlink_t, 13 pub st_mode: ::mode_t, 14 pub st_uid: ::uid_t, 15 pub st_gid: ::gid_t, 16 __pad0: ::c_int, 17 pub st_rdev: ::dev_t, 18 pub st_size: ::off_t, 19 pub st_blksize: ::blksize_t, 20 pub st_blocks: ::blkcnt_t, 21 pub st_atime: ::time_t, 22 pub st_atime_nsec: ::c_long, 23 pub st_mtime: ::time_t, 24 pub st_mtime_nsec: ::c_long, 25 pub st_ctime: ::time_t, 26 pub st_ctime_nsec: ::c_long, 27 __unused: [::c_long; 3], 28 } 29 30 pub struct stat64 { 31 pub st_dev: ::dev_t, 32 pub st_ino: ::ino64_t, 33 pub st_nlink: ::nlink_t, 34 pub st_mode: ::mode_t, 35 pub st_uid: ::uid_t, 36 pub st_gid: ::gid_t, 37 __pad0: ::c_int, 38 pub st_rdev: ::dev_t, 39 pub st_size: ::off_t, 40 pub st_blksize: ::blksize_t, 41 pub st_blocks: ::blkcnt64_t, 42 pub st_atime: ::time_t, 43 pub st_atime_nsec: ::c_long, 44 pub st_mtime: ::time_t, 45 pub st_mtime_nsec: ::c_long, 46 pub st_ctime: ::time_t, 47 pub st_ctime_nsec: ::c_long, 48 __reserved: [::c_long; 3], 49 } 50 51 pub struct user_regs_struct { 52 pub r15: ::c_ulong, 53 pub r14: ::c_ulong, 54 pub r13: ::c_ulong, 55 pub r12: ::c_ulong, 56 pub rbp: ::c_ulong, 57 pub rbx: ::c_ulong, 58 pub r11: ::c_ulong, 59 pub r10: ::c_ulong, 60 pub r9: ::c_ulong, 61 pub r8: ::c_ulong, 62 pub rax: ::c_ulong, 63 pub rcx: ::c_ulong, 64 pub rdx: ::c_ulong, 65 pub rsi: ::c_ulong, 66 pub rdi: ::c_ulong, 67 pub orig_rax: ::c_ulong, 68 pub rip: ::c_ulong, 69 pub cs: ::c_ulong, 70 pub eflags: ::c_ulong, 71 pub rsp: ::c_ulong, 72 pub ss: ::c_ulong, 73 pub fs_base: ::c_ulong, 74 pub gs_base: ::c_ulong, 75 pub ds: ::c_ulong, 76 pub es: ::c_ulong, 77 pub fs: ::c_ulong, 78 pub gs: ::c_ulong, 79 } 80 81 pub struct user { 82 pub regs: user_regs_struct, 83 pub u_fpvalid: ::c_int, 84 pub i387: user_fpregs_struct, 85 pub u_tsize: ::c_ulong, 86 pub u_dsize: ::c_ulong, 87 pub u_ssize: ::c_ulong, 88 pub start_code: ::c_ulong, 89 pub start_stack: ::c_ulong, 90 pub signal: ::c_long, 91 __reserved: ::c_int, 92 #[cfg(target_pointer_width = "32")] 93 __pad1: u32, 94 pub u_ar0: *mut user_regs_struct, 95 #[cfg(target_pointer_width = "32")] 96 __pad2: u32, 97 pub u_fpstate: *mut user_fpregs_struct, 98 pub magic: ::c_ulong, 99 pub u_comm: [::c_char; 32], 100 pub u_debugreg: [::c_ulong; 8], 101 } 102 103 // GitHub repo: ifduyue/musl/ 104 // commit: b4b1e10364c8737a632be61582e05a8d3acf5690 105 // file: arch/x86_64/bits/signal.h#L80-L84 106 pub struct mcontext_t { 107 pub gregs: [greg_t; 23], 108 __private: [u64; 9], 109 } 110 111 pub struct ipc_perm { 112 pub __ipc_perm_key: ::key_t, 113 pub uid: ::uid_t, 114 pub gid: ::gid_t, 115 pub cuid: ::uid_t, 116 pub cgid: ::gid_t, 117 pub mode: ::mode_t, 118 pub __seq: ::c_int, 119 __unused1: ::c_long, 120 __unused2: ::c_long 121 } 122 } 123 124 s_no_extra_traits! { 125 pub struct user_fpregs_struct { 126 pub cwd: ::c_ushort, 127 pub swd: ::c_ushort, 128 pub ftw: ::c_ushort, 129 pub fop: ::c_ushort, 130 pub rip: ::c_ulong, 131 pub rdp: ::c_ulong, 132 pub mxcsr: ::c_uint, 133 pub mxcr_mask: ::c_uint, 134 pub st_space: [::c_uint; 32], 135 pub xmm_space: [::c_uint; 64], 136 padding: [::c_uint; 24], 137 } 138 139 pub struct ucontext_t { 140 pub uc_flags: ::c_ulong, 141 pub uc_link: *mut ucontext_t, 142 pub uc_stack: ::stack_t, 143 pub uc_mcontext: mcontext_t, 144 pub uc_sigmask: ::sigset_t, 145 __private: [u8; 512], 146 } 147 } 148 149 cfg_if! { 150 if #[cfg(feature = "extra_traits")] { 151 impl PartialEq for user_fpregs_struct { 152 fn eq(&self, other: &user_fpregs_struct) -> bool { 153 self.cwd == other.cwd 154 && self.swd == other.swd 155 && self.ftw == other.ftw 156 && self.fop == other.fop 157 && self.rip == other.rip 158 && self.rdp == other.rdp 159 && self.mxcsr == other.mxcsr 160 && self.mxcr_mask == other.mxcr_mask 161 && self.st_space == other.st_space 162 && self 163 .xmm_space 164 .iter() 165 .zip(other.xmm_space.iter()) 166 .all(|(a,b)| a == b) 167 // Ignore padding field 168 } 169 } 170 171 impl Eq for user_fpregs_struct {} 172 173 impl ::fmt::Debug for user_fpregs_struct { 174 fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { 175 f.debug_struct("user_fpregs_struct") 176 .field("cwd", &self.cwd) 177 .field("ftw", &self.ftw) 178 .field("fop", &self.fop) 179 .field("rip", &self.rip) 180 .field("rdp", &self.rdp) 181 .field("mxcsr", &self.mxcsr) 182 .field("mxcr_mask", &self.mxcr_mask) 183 .field("st_space", &self.st_space) 184 // FIXME: .field("xmm_space", &self.xmm_space) 185 // Ignore padding field 186 .finish() 187 } 188 } 189 190 impl ::hash::Hash for user_fpregs_struct { 191 fn hash<H: ::hash::Hasher>(&self, state: &mut H) { 192 self.cwd.hash(state); 193 self.ftw.hash(state); 194 self.fop.hash(state); 195 self.rip.hash(state); 196 self.rdp.hash(state); 197 self.mxcsr.hash(state); 198 self.mxcr_mask.hash(state); 199 self.st_space.hash(state); 200 self.xmm_space.hash(state); 201 // Ignore padding field 202 } 203 } 204 205 impl PartialEq for ucontext_t { 206 fn eq(&self, other: &ucontext_t) -> bool { 207 self.uc_flags == other.uc_flags 208 && self.uc_link == other.uc_link 209 && self.uc_stack == other.uc_stack 210 && self.uc_mcontext == other.uc_mcontext 211 && self.uc_sigmask == other.uc_sigmask 212 && self 213 .__private 214 .iter() 215 .zip(other.__private.iter()) 216 .all(|(a,b)| a == b) 217 } 218 } 219 220 impl Eq for ucontext_t {} 221 222 impl ::fmt::Debug for ucontext_t { 223 fn fmt(&self, f: &mut ::fmt::Formatter) -> ::fmt::Result { 224 f.debug_struct("ucontext_t") 225 .field("uc_flags", &self.uc_flags) 226 .field("uc_link", &self.uc_link) 227 .field("uc_stack", &self.uc_stack) 228 .field("uc_mcontext", &self.uc_mcontext) 229 .field("uc_sigmask", &self.uc_sigmask) 230 // Ignore __private field 231 .finish() 232 } 233 } 234 235 impl ::hash::Hash for ucontext_t { 236 fn hash<H: ::hash::Hasher>(&self, state: &mut H) { 237 self.uc_flags.hash(state); 238 self.uc_link.hash(state); 239 self.uc_stack.hash(state); 240 self.uc_mcontext.hash(state); 241 self.uc_sigmask.hash(state); 242 self.__private.hash(state); 243 } 244 } 245 } 246 } 247 248 // Syscall table 249 250 pub const SYS_read: ::c_long = 0; 251 pub const SYS_write: ::c_long = 1; 252 pub const SYS_open: ::c_long = 2; 253 pub const SYS_close: ::c_long = 3; 254 pub const SYS_stat: ::c_long = 4; 255 pub const SYS_fstat: ::c_long = 5; 256 pub const SYS_lstat: ::c_long = 6; 257 pub const SYS_poll: ::c_long = 7; 258 pub const SYS_lseek: ::c_long = 8; 259 pub const SYS_mmap: ::c_long = 9; 260 pub const SYS_mprotect: ::c_long = 10; 261 pub const SYS_munmap: ::c_long = 11; 262 pub const SYS_brk: ::c_long = 12; 263 pub const SYS_rt_sigaction: ::c_long = 13; 264 pub const SYS_rt_sigprocmask: ::c_long = 14; 265 pub const SYS_rt_sigreturn: ::c_long = 15; 266 pub const SYS_ioctl: ::c_long = 16; 267 pub const SYS_pread64: ::c_long = 17; 268 pub const SYS_pwrite64: ::c_long = 18; 269 pub const SYS_readv: ::c_long = 19; 270 pub const SYS_writev: ::c_long = 20; 271 pub const SYS_access: ::c_long = 21; 272 pub const SYS_pipe: ::c_long = 22; 273 pub const SYS_select: ::c_long = 23; 274 pub const SYS_sched_yield: ::c_long = 24; 275 pub const SYS_mremap: ::c_long = 25; 276 pub const SYS_msync: ::c_long = 26; 277 pub const SYS_mincore: ::c_long = 27; 278 pub const SYS_madvise: ::c_long = 28; 279 pub const SYS_shmget: ::c_long = 29; 280 pub const SYS_shmat: ::c_long = 30; 281 pub const SYS_shmctl: ::c_long = 31; 282 pub const SYS_dup: ::c_long = 32; 283 pub const SYS_dup2: ::c_long = 33; 284 pub const SYS_pause: ::c_long = 34; 285 pub const SYS_nanosleep: ::c_long = 35; 286 pub const SYS_getitimer: ::c_long = 36; 287 pub const SYS_alarm: ::c_long = 37; 288 pub const SYS_setitimer: ::c_long = 38; 289 pub const SYS_getpid: ::c_long = 39; 290 pub const SYS_sendfile: ::c_long = 40; 291 pub const SYS_socket: ::c_long = 41; 292 pub const SYS_connect: ::c_long = 42; 293 pub const SYS_accept: ::c_long = 43; 294 pub const SYS_sendto: ::c_long = 44; 295 pub const SYS_recvfrom: ::c_long = 45; 296 pub const SYS_sendmsg: ::c_long = 46; 297 pub const SYS_recvmsg: ::c_long = 47; 298 pub const SYS_shutdown: ::c_long = 48; 299 pub const SYS_bind: ::c_long = 49; 300 pub const SYS_listen: ::c_long = 50; 301 pub const SYS_getsockname: ::c_long = 51; 302 pub const SYS_getpeername: ::c_long = 52; 303 pub const SYS_socketpair: ::c_long = 53; 304 pub const SYS_setsockopt: ::c_long = 54; 305 pub const SYS_getsockopt: ::c_long = 55; 306 pub const SYS_clone: ::c_long = 56; 307 pub const SYS_fork: ::c_long = 57; 308 pub const SYS_vfork: ::c_long = 58; 309 pub const SYS_execve: ::c_long = 59; 310 pub const SYS_exit: ::c_long = 60; 311 pub const SYS_wait4: ::c_long = 61; 312 pub const SYS_kill: ::c_long = 62; 313 pub const SYS_uname: ::c_long = 63; 314 pub const SYS_semget: ::c_long = 64; 315 pub const SYS_semop: ::c_long = 65; 316 pub const SYS_semctl: ::c_long = 66; 317 pub const SYS_shmdt: ::c_long = 67; 318 pub const SYS_msgget: ::c_long = 68; 319 pub const SYS_msgsnd: ::c_long = 69; 320 pub const SYS_msgrcv: ::c_long = 70; 321 pub const SYS_msgctl: ::c_long = 71; 322 pub const SYS_fcntl: ::c_long = 72; 323 pub const SYS_flock: ::c_long = 73; 324 pub const SYS_fsync: ::c_long = 74; 325 pub const SYS_fdatasync: ::c_long = 75; 326 pub const SYS_truncate: ::c_long = 76; 327 pub const SYS_ftruncate: ::c_long = 77; 328 pub const SYS_getdents: ::c_long = 78; 329 pub const SYS_getcwd: ::c_long = 79; 330 pub const SYS_chdir: ::c_long = 80; 331 pub const SYS_fchdir: ::c_long = 81; 332 pub const SYS_rename: ::c_long = 82; 333 pub const SYS_mkdir: ::c_long = 83; 334 pub const SYS_rmdir: ::c_long = 84; 335 pub const SYS_creat: ::c_long = 85; 336 pub const SYS_link: ::c_long = 86; 337 pub const SYS_unlink: ::c_long = 87; 338 pub const SYS_symlink: ::c_long = 88; 339 pub const SYS_readlink: ::c_long = 89; 340 pub const SYS_chmod: ::c_long = 90; 341 pub const SYS_fchmod: ::c_long = 91; 342 pub const SYS_chown: ::c_long = 92; 343 pub const SYS_fchown: ::c_long = 93; 344 pub const SYS_lchown: ::c_long = 94; 345 pub const SYS_umask: ::c_long = 95; 346 pub const SYS_gettimeofday: ::c_long = 96; 347 pub const SYS_getrlimit: ::c_long = 97; 348 pub const SYS_getrusage: ::c_long = 98; 349 pub const SYS_sysinfo: ::c_long = 99; 350 pub const SYS_times: ::c_long = 100; 351 pub const SYS_ptrace: ::c_long = 101; 352 pub const SYS_getuid: ::c_long = 102; 353 pub const SYS_syslog: ::c_long = 103; 354 pub const SYS_getgid: ::c_long = 104; 355 pub const SYS_setuid: ::c_long = 105; 356 pub const SYS_setgid: ::c_long = 106; 357 pub const SYS_geteuid: ::c_long = 107; 358 pub const SYS_getegid: ::c_long = 108; 359 pub const SYS_setpgid: ::c_long = 109; 360 pub const SYS_getppid: ::c_long = 110; 361 pub const SYS_getpgrp: ::c_long = 111; 362 pub const SYS_setsid: ::c_long = 112; 363 pub const SYS_setreuid: ::c_long = 113; 364 pub const SYS_setregid: ::c_long = 114; 365 pub const SYS_getgroups: ::c_long = 115; 366 pub const SYS_setgroups: ::c_long = 116; 367 pub const SYS_setresuid: ::c_long = 117; 368 pub const SYS_getresuid: ::c_long = 118; 369 pub const SYS_setresgid: ::c_long = 119; 370 pub const SYS_getresgid: ::c_long = 120; 371 pub const SYS_getpgid: ::c_long = 121; 372 pub const SYS_setfsuid: ::c_long = 122; 373 pub const SYS_setfsgid: ::c_long = 123; 374 pub const SYS_getsid: ::c_long = 124; 375 pub const SYS_capget: ::c_long = 125; 376 pub const SYS_capset: ::c_long = 126; 377 pub const SYS_rt_sigpending: ::c_long = 127; 378 pub const SYS_rt_sigtimedwait: ::c_long = 128; 379 pub const SYS_rt_sigqueueinfo: ::c_long = 129; 380 pub const SYS_rt_sigsuspend: ::c_long = 130; 381 pub const SYS_sigaltstack: ::c_long = 131; 382 pub const SYS_utime: ::c_long = 132; 383 pub const SYS_mknod: ::c_long = 133; 384 pub const SYS_uselib: ::c_long = 134; 385 pub const SYS_personality: ::c_long = 135; 386 pub const SYS_ustat: ::c_long = 136; 387 pub const SYS_statfs: ::c_long = 137; 388 pub const SYS_fstatfs: ::c_long = 138; 389 pub const SYS_sysfs: ::c_long = 139; 390 pub const SYS_getpriority: ::c_long = 140; 391 pub const SYS_setpriority: ::c_long = 141; 392 pub const SYS_sched_setparam: ::c_long = 142; 393 pub const SYS_sched_getparam: ::c_long = 143; 394 pub const SYS_sched_setscheduler: ::c_long = 144; 395 pub const SYS_sched_getscheduler: ::c_long = 145; 396 pub const SYS_sched_get_priority_max: ::c_long = 146; 397 pub const SYS_sched_get_priority_min: ::c_long = 147; 398 pub const SYS_sched_rr_get_interval: ::c_long = 148; 399 pub const SYS_mlock: ::c_long = 149; 400 pub const SYS_munlock: ::c_long = 150; 401 pub const SYS_mlockall: ::c_long = 151; 402 pub const SYS_munlockall: ::c_long = 152; 403 pub const SYS_vhangup: ::c_long = 153; 404 pub const SYS_modify_ldt: ::c_long = 154; 405 pub const SYS_pivot_root: ::c_long = 155; 406 pub const SYS__sysctl: ::c_long = 156; 407 pub const SYS_prctl: ::c_long = 157; 408 pub const SYS_arch_prctl: ::c_long = 158; 409 pub const SYS_adjtimex: ::c_long = 159; 410 pub const SYS_setrlimit: ::c_long = 160; 411 pub const SYS_chroot: ::c_long = 161; 412 pub const SYS_sync: ::c_long = 162; 413 pub const SYS_acct: ::c_long = 163; 414 pub const SYS_settimeofday: ::c_long = 164; 415 pub const SYS_mount: ::c_long = 165; 416 pub const SYS_umount2: ::c_long = 166; 417 pub const SYS_swapon: ::c_long = 167; 418 pub const SYS_swapoff: ::c_long = 168; 419 pub const SYS_reboot: ::c_long = 169; 420 pub const SYS_sethostname: ::c_long = 170; 421 pub const SYS_setdomainname: ::c_long = 171; 422 pub const SYS_iopl: ::c_long = 172; 423 pub const SYS_ioperm: ::c_long = 173; 424 pub const SYS_create_module: ::c_long = 174; 425 pub const SYS_init_module: ::c_long = 175; 426 pub const SYS_delete_module: ::c_long = 176; 427 pub const SYS_get_kernel_syms: ::c_long = 177; 428 pub const SYS_query_module: ::c_long = 178; 429 pub const SYS_quotactl: ::c_long = 179; 430 pub const SYS_nfsservctl: ::c_long = 180; 431 pub const SYS_getpmsg: ::c_long = 181; 432 pub const SYS_putpmsg: ::c_long = 182; 433 pub const SYS_afs_syscall: ::c_long = 183; 434 pub const SYS_tuxcall: ::c_long = 184; 435 pub const SYS_security: ::c_long = 185; 436 pub const SYS_gettid: ::c_long = 186; 437 pub const SYS_readahead: ::c_long = 187; 438 pub const SYS_setxattr: ::c_long = 188; 439 pub const SYS_lsetxattr: ::c_long = 189; 440 pub const SYS_fsetxattr: ::c_long = 190; 441 pub const SYS_getxattr: ::c_long = 191; 442 pub const SYS_lgetxattr: ::c_long = 192; 443 pub const SYS_fgetxattr: ::c_long = 193; 444 pub const SYS_listxattr: ::c_long = 194; 445 pub const SYS_llistxattr: ::c_long = 195; 446 pub const SYS_flistxattr: ::c_long = 196; 447 pub const SYS_removexattr: ::c_long = 197; 448 pub const SYS_lremovexattr: ::c_long = 198; 449 pub const SYS_fremovexattr: ::c_long = 199; 450 pub const SYS_tkill: ::c_long = 200; 451 pub const SYS_time: ::c_long = 201; 452 pub const SYS_futex: ::c_long = 202; 453 pub const SYS_sched_setaffinity: ::c_long = 203; 454 pub const SYS_sched_getaffinity: ::c_long = 204; 455 pub const SYS_set_thread_area: ::c_long = 205; 456 pub const SYS_io_setup: ::c_long = 206; 457 pub const SYS_io_destroy: ::c_long = 207; 458 pub const SYS_io_getevents: ::c_long = 208; 459 pub const SYS_io_submit: ::c_long = 209; 460 pub const SYS_io_cancel: ::c_long = 210; 461 pub const SYS_get_thread_area: ::c_long = 211; 462 pub const SYS_lookup_dcookie: ::c_long = 212; 463 pub const SYS_epoll_create: ::c_long = 213; 464 pub const SYS_epoll_ctl_old: ::c_long = 214; 465 pub const SYS_epoll_wait_old: ::c_long = 215; 466 pub const SYS_remap_file_pages: ::c_long = 216; 467 pub const SYS_getdents64: ::c_long = 217; 468 pub const SYS_set_tid_address: ::c_long = 218; 469 pub const SYS_restart_syscall: ::c_long = 219; 470 pub const SYS_semtimedop: ::c_long = 220; 471 pub const SYS_fadvise64: ::c_long = 221; 472 pub const SYS_timer_create: ::c_long = 222; 473 pub const SYS_timer_settime: ::c_long = 223; 474 pub const SYS_timer_gettime: ::c_long = 224; 475 pub const SYS_timer_getoverrun: ::c_long = 225; 476 pub const SYS_timer_delete: ::c_long = 226; 477 pub const SYS_clock_settime: ::c_long = 227; 478 pub const SYS_clock_gettime: ::c_long = 228; 479 pub const SYS_clock_getres: ::c_long = 229; 480 pub const SYS_clock_nanosleep: ::c_long = 230; 481 pub const SYS_exit_group: ::c_long = 231; 482 pub const SYS_epoll_wait: ::c_long = 232; 483 pub const SYS_epoll_ctl: ::c_long = 233; 484 pub const SYS_tgkill: ::c_long = 234; 485 pub const SYS_utimes: ::c_long = 235; 486 pub const SYS_vserver: ::c_long = 236; 487 pub const SYS_mbind: ::c_long = 237; 488 pub const SYS_set_mempolicy: ::c_long = 238; 489 pub const SYS_get_mempolicy: ::c_long = 239; 490 pub const SYS_mq_open: ::c_long = 240; 491 pub const SYS_mq_unlink: ::c_long = 241; 492 pub const SYS_mq_timedsend: ::c_long = 242; 493 pub const SYS_mq_timedreceive: ::c_long = 243; 494 pub const SYS_mq_notify: ::c_long = 244; 495 pub const SYS_mq_getsetattr: ::c_long = 245; 496 pub const SYS_kexec_load: ::c_long = 246; 497 pub const SYS_waitid: ::c_long = 247; 498 pub const SYS_add_key: ::c_long = 248; 499 pub const SYS_request_key: ::c_long = 249; 500 pub const SYS_keyctl: ::c_long = 250; 501 pub const SYS_ioprio_set: ::c_long = 251; 502 pub const SYS_ioprio_get: ::c_long = 252; 503 pub const SYS_inotify_init: ::c_long = 253; 504 pub const SYS_inotify_add_watch: ::c_long = 254; 505 pub const SYS_inotify_rm_watch: ::c_long = 255; 506 pub const SYS_migrate_pages: ::c_long = 256; 507 pub const SYS_openat: ::c_long = 257; 508 pub const SYS_mkdirat: ::c_long = 258; 509 pub const SYS_mknodat: ::c_long = 259; 510 pub const SYS_fchownat: ::c_long = 260; 511 pub const SYS_futimesat: ::c_long = 261; 512 pub const SYS_newfstatat: ::c_long = 262; 513 pub const SYS_unlinkat: ::c_long = 263; 514 pub const SYS_renameat: ::c_long = 264; 515 pub const SYS_linkat: ::c_long = 265; 516 pub const SYS_symlinkat: ::c_long = 266; 517 pub const SYS_readlinkat: ::c_long = 267; 518 pub const SYS_fchmodat: ::c_long = 268; 519 pub const SYS_faccessat: ::c_long = 269; 520 pub const SYS_pselect6: ::c_long = 270; 521 pub const SYS_ppoll: ::c_long = 271; 522 pub const SYS_unshare: ::c_long = 272; 523 pub const SYS_set_robust_list: ::c_long = 273; 524 pub const SYS_get_robust_list: ::c_long = 274; 525 pub const SYS_splice: ::c_long = 275; 526 pub const SYS_tee: ::c_long = 276; 527 pub const SYS_sync_file_range: ::c_long = 277; 528 pub const SYS_vmsplice: ::c_long = 278; 529 pub const SYS_move_pages: ::c_long = 279; 530 pub const SYS_utimensat: ::c_long = 280; 531 pub const SYS_epoll_pwait: ::c_long = 281; 532 pub const SYS_signalfd: ::c_long = 282; 533 pub const SYS_timerfd_create: ::c_long = 283; 534 pub const SYS_eventfd: ::c_long = 284; 535 pub const SYS_fallocate: ::c_long = 285; 536 pub const SYS_timerfd_settime: ::c_long = 286; 537 pub const SYS_timerfd_gettime: ::c_long = 287; 538 pub const SYS_accept4: ::c_long = 288; 539 pub const SYS_signalfd4: ::c_long = 289; 540 pub const SYS_eventfd2: ::c_long = 290; 541 pub const SYS_epoll_create1: ::c_long = 291; 542 pub const SYS_dup3: ::c_long = 292; 543 pub const SYS_pipe2: ::c_long = 293; 544 pub const SYS_inotify_init1: ::c_long = 294; 545 pub const SYS_preadv: ::c_long = 295; 546 pub const SYS_pwritev: ::c_long = 296; 547 pub const SYS_rt_tgsigqueueinfo: ::c_long = 297; 548 pub const SYS_perf_event_open: ::c_long = 298; 549 pub const SYS_recvmmsg: ::c_long = 299; 550 pub const SYS_fanotify_init: ::c_long = 300; 551 pub const SYS_fanotify_mark: ::c_long = 301; 552 pub const SYS_prlimit64: ::c_long = 302; 553 pub const SYS_name_to_handle_at: ::c_long = 303; 554 pub const SYS_open_by_handle_at: ::c_long = 304; 555 pub const SYS_clock_adjtime: ::c_long = 305; 556 pub const SYS_syncfs: ::c_long = 306; 557 pub const SYS_sendmmsg: ::c_long = 307; 558 pub const SYS_setns: ::c_long = 308; 559 pub const SYS_getcpu: ::c_long = 309; 560 pub const SYS_process_vm_readv: ::c_long = 310; 561 pub const SYS_process_vm_writev: ::c_long = 311; 562 pub const SYS_kcmp: ::c_long = 312; 563 pub const SYS_finit_module: ::c_long = 313; 564 pub const SYS_sched_setattr: ::c_long = 314; 565 pub const SYS_sched_getattr: ::c_long = 315; 566 pub const SYS_renameat2: ::c_long = 316; 567 pub const SYS_seccomp: ::c_long = 317; 568 pub const SYS_getrandom: ::c_long = 318; 569 pub const SYS_memfd_create: ::c_long = 319; 570 pub const SYS_kexec_file_load: ::c_long = 320; 571 pub const SYS_bpf: ::c_long = 321; 572 pub const SYS_execveat: ::c_long = 322; 573 pub const SYS_userfaultfd: ::c_long = 323; 574 pub const SYS_membarrier: ::c_long = 324; 575 pub const SYS_mlock2: ::c_long = 325; 576 pub const SYS_copy_file_range: ::c_long = 326; 577 pub const SYS_preadv2: ::c_long = 327; 578 pub const SYS_pwritev2: ::c_long = 328; 579 pub const SYS_pkey_mprotect: ::c_long = 329; 580 pub const SYS_pkey_alloc: ::c_long = 330; 581 pub const SYS_pkey_free: ::c_long = 331; 582 pub const SYS_statx: ::c_long = 332; 583 pub const SYS_pidfd_send_signal: ::c_long = 424; 584 pub const SYS_io_uring_setup: ::c_long = 425; 585 pub const SYS_io_uring_enter: ::c_long = 426; 586 pub const SYS_io_uring_register: ::c_long = 427; 587 pub const SYS_open_tree: ::c_long = 428; 588 pub const SYS_move_mount: ::c_long = 429; 589 pub const SYS_fsopen: ::c_long = 430; 590 pub const SYS_fsconfig: ::c_long = 431; 591 pub const SYS_fsmount: ::c_long = 432; 592 pub const SYS_fspick: ::c_long = 433; 593 pub const SYS_pidfd_open: ::c_long = 434; 594 pub const SYS_clone3: ::c_long = 435; 595 pub const SYS_close_range: ::c_long = 436; 596 pub const SYS_openat2: ::c_long = 437; 597 pub const SYS_pidfd_getfd: ::c_long = 438; 598 pub const SYS_faccessat2: ::c_long = 439; 599 pub const SYS_process_madvise: ::c_long = 440; 600 pub const SYS_epoll_pwait2: ::c_long = 441; 601 pub const SYS_mount_setattr: ::c_long = 442; 602 603 // offsets in user_regs_structs, from sys/reg.h 604 pub const R15: ::c_int = 0; 605 pub const R14: ::c_int = 1; 606 pub const R13: ::c_int = 2; 607 pub const R12: ::c_int = 3; 608 pub const RBP: ::c_int = 4; 609 pub const RBX: ::c_int = 5; 610 pub const R11: ::c_int = 6; 611 pub const R10: ::c_int = 7; 612 pub const R9: ::c_int = 8; 613 pub const R8: ::c_int = 9; 614 pub const RAX: ::c_int = 10; 615 pub const RCX: ::c_int = 11; 616 pub const RDX: ::c_int = 12; 617 pub const RSI: ::c_int = 13; 618 pub const RDI: ::c_int = 14; 619 pub const ORIG_RAX: ::c_int = 15; 620 pub const RIP: ::c_int = 16; 621 pub const CS: ::c_int = 17; 622 pub const EFLAGS: ::c_int = 18; 623 pub const RSP: ::c_int = 19; 624 pub const SS: ::c_int = 20; 625 pub const FS_BASE: ::c_int = 21; 626 pub const GS_BASE: ::c_int = 22; 627 pub const DS: ::c_int = 23; 628 pub const ES: ::c_int = 24; 629 pub const FS: ::c_int = 25; 630 pub const GS: ::c_int = 26; 631 632 // offsets in mcontext_t.gregs from bits/signal.h 633 // GitHub repo: ifduyue/musl/ 634 // commit: b4b1e10364c8737a632be61582e05a8d3acf5690 635 // file: arch/x86_64/bits/signal.h#L9-L56 636 pub const REG_R8: ::c_int = 0; 637 pub const REG_R9: ::c_int = 1; 638 pub const REG_R10: ::c_int = 2; 639 pub const REG_R11: ::c_int = 3; 640 pub const REG_R12: ::c_int = 4; 641 pub const REG_R13: ::c_int = 5; 642 pub const REG_R14: ::c_int = 6; 643 pub const REG_R15: ::c_int = 7; 644 pub const REG_RDI: ::c_int = 8; 645 pub const REG_RSI: ::c_int = 9; 646 pub const REG_RBP: ::c_int = 10; 647 pub const REG_RBX: ::c_int = 11; 648 pub const REG_RDX: ::c_int = 12; 649 pub const REG_RAX: ::c_int = 13; 650 pub const REG_RCX: ::c_int = 14; 651 pub const REG_RSP: ::c_int = 15; 652 pub const REG_RIP: ::c_int = 16; 653 pub const REG_EFL: ::c_int = 17; 654 pub const REG_CSGSFS: ::c_int = 18; 655 pub const REG_ERR: ::c_int = 19; 656 pub const REG_TRAPNO: ::c_int = 20; 657 pub const REG_OLDMASK: ::c_int = 21; 658 pub const REG_CR2: ::c_int = 22; 659 660 pub const MADV_SOFT_OFFLINE: ::c_int = 101; 661 pub const MAP_32BIT: ::c_int = 0x0040; 662 pub const O_APPEND: ::c_int = 1024; 663 pub const O_DIRECT: ::c_int = 0x4000; 664 pub const O_DIRECTORY: ::c_int = 0x10000; 665 pub const O_LARGEFILE: ::c_int = 0; 666 pub const O_NOFOLLOW: ::c_int = 0x20000; 667 pub const O_CREAT: ::c_int = 64; 668 pub const O_EXCL: ::c_int = 128; 669 pub const O_NOCTTY: ::c_int = 256; 670 pub const O_NONBLOCK: ::c_int = 2048; 671 pub const O_SYNC: ::c_int = 1052672; 672 pub const O_RSYNC: ::c_int = 1052672; 673 pub const O_DSYNC: ::c_int = 4096; 674 pub const O_ASYNC: ::c_int = 0x2000; 675 676 pub const TIOCGRS485: ::c_int = 0x542E; 677 pub const TIOCSRS485: ::c_int = 0x542F; 678 679 pub const SIGSTKSZ: ::size_t = 8192; 680 pub const MINSIGSTKSZ: ::size_t = 2048; 681 682 pub const ENAMETOOLONG: ::c_int = 36; 683 pub const ENOLCK: ::c_int = 37; 684 pub const ENOSYS: ::c_int = 38; 685 pub const ENOTEMPTY: ::c_int = 39; 686 pub const ELOOP: ::c_int = 40; 687 pub const ENOMSG: ::c_int = 42; 688 pub const EIDRM: ::c_int = 43; 689 pub const ECHRNG: ::c_int = 44; 690 pub const EL2NSYNC: ::c_int = 45; 691 pub const EL3HLT: ::c_int = 46; 692 pub const EL3RST: ::c_int = 47; 693 pub const ELNRNG: ::c_int = 48; 694 pub const EUNATCH: ::c_int = 49; 695 pub const ENOCSI: ::c_int = 50; 696 pub const EL2HLT: ::c_int = 51; 697 pub const EBADE: ::c_int = 52; 698 pub const EBADR: ::c_int = 53; 699 pub const EXFULL: ::c_int = 54; 700 pub const ENOANO: ::c_int = 55; 701 pub const EBADRQC: ::c_int = 56; 702 pub const EBADSLT: ::c_int = 57; 703 pub const EMULTIHOP: ::c_int = 72; 704 pub const EBADMSG: ::c_int = 74; 705 pub const EOVERFLOW: ::c_int = 75; 706 pub const ENOTUNIQ: ::c_int = 76; 707 pub const EBADFD: ::c_int = 77; 708 pub const EREMCHG: ::c_int = 78; 709 pub const ELIBACC: ::c_int = 79; 710 pub const ELIBBAD: ::c_int = 80; 711 pub const ELIBSCN: ::c_int = 81; 712 pub const ELIBMAX: ::c_int = 82; 713 pub const ELIBEXEC: ::c_int = 83; 714 pub const EILSEQ: ::c_int = 84; 715 pub const ERESTART: ::c_int = 85; 716 pub const ESTRPIPE: ::c_int = 86; 717 pub const EUSERS: ::c_int = 87; 718 pub const ENOTSOCK: ::c_int = 88; 719 pub const EDESTADDRREQ: ::c_int = 89; 720 pub const EMSGSIZE: ::c_int = 90; 721 pub const EPROTOTYPE: ::c_int = 91; 722 pub const ENOPROTOOPT: ::c_int = 92; 723 pub const EPROTONOSUPPORT: ::c_int = 93; 724 pub const ESOCKTNOSUPPORT: ::c_int = 94; 725 pub const EOPNOTSUPP: ::c_int = 95; 726 pub const ENOTSUP: ::c_int = EOPNOTSUPP; 727 pub const EPFNOSUPPORT: ::c_int = 96; 728 pub const EAFNOSUPPORT: ::c_int = 97; 729 pub const EADDRINUSE: ::c_int = 98; 730 pub const EADDRNOTAVAIL: ::c_int = 99; 731 pub const ENETDOWN: ::c_int = 100; 732 pub const ENETUNREACH: ::c_int = 101; 733 pub const ENETRESET: ::c_int = 102; 734 pub const ECONNABORTED: ::c_int = 103; 735 pub const ECONNRESET: ::c_int = 104; 736 pub const ENOBUFS: ::c_int = 105; 737 pub const EISCONN: ::c_int = 106; 738 pub const ENOTCONN: ::c_int = 107; 739 pub const ESHUTDOWN: ::c_int = 108; 740 pub const ETOOMANYREFS: ::c_int = 109; 741 pub const ETIMEDOUT: ::c_int = 110; 742 pub const ECONNREFUSED: ::c_int = 111; 743 pub const EHOSTDOWN: ::c_int = 112; 744 pub const EHOSTUNREACH: ::c_int = 113; 745 pub const EALREADY: ::c_int = 114; 746 pub const EINPROGRESS: ::c_int = 115; 747 pub const ESTALE: ::c_int = 116; 748 pub const EUCLEAN: ::c_int = 117; 749 pub const ENOTNAM: ::c_int = 118; 750 pub const ENAVAIL: ::c_int = 119; 751 pub const EISNAM: ::c_int = 120; 752 pub const EREMOTEIO: ::c_int = 121; 753 pub const EDQUOT: ::c_int = 122; 754 pub const ENOMEDIUM: ::c_int = 123; 755 pub const EMEDIUMTYPE: ::c_int = 124; 756 pub const ECANCELED: ::c_int = 125; 757 pub const ENOKEY: ::c_int = 126; 758 pub const EKEYEXPIRED: ::c_int = 127; 759 pub const EKEYREVOKED: ::c_int = 128; 760 pub const EKEYREJECTED: ::c_int = 129; 761 pub const EOWNERDEAD: ::c_int = 130; 762 pub const ENOTRECOVERABLE: ::c_int = 131; 763 pub const ERFKILL: ::c_int = 132; 764 pub const EHWPOISON: ::c_int = 133; 765 766 pub const SA_ONSTACK: ::c_int = 0x08000000; 767 pub const SA_SIGINFO: ::c_int = 0x00000004; 768 pub const SA_NOCLDWAIT: ::c_int = 0x00000002; 769 770 pub const SIGCHLD: ::c_int = 17; 771 pub const SIGBUS: ::c_int = 7; 772 pub const SIGTTIN: ::c_int = 21; 773 pub const SIGTTOU: ::c_int = 22; 774 pub const SIGXCPU: ::c_int = 24; 775 pub const SIGXFSZ: ::c_int = 25; 776 pub const SIGVTALRM: ::c_int = 26; 777 pub const SIGPROF: ::c_int = 27; 778 pub const SIGWINCH: ::c_int = 28; 779 pub const SIGUSR1: ::c_int = 10; 780 pub const SIGUSR2: ::c_int = 12; 781 pub const SIGCONT: ::c_int = 18; 782 pub const SIGSTOP: ::c_int = 19; 783 pub const SIGTSTP: ::c_int = 20; 784 pub const SIGURG: ::c_int = 23; 785 pub const SIGIO: ::c_int = 29; 786 pub const SIGSYS: ::c_int = 31; 787 pub const SIGSTKFLT: ::c_int = 16; 788 pub const SIGPOLL: ::c_int = 29; 789 pub const SIGPWR: ::c_int = 30; 790 pub const SIG_SETMASK: ::c_int = 2; 791 pub const SIG_BLOCK: ::c_int = 0x000000; 792 pub const SIG_UNBLOCK: ::c_int = 0x01; 793 794 pub const F_GETLK: ::c_int = 5; 795 pub const F_GETOWN: ::c_int = 9; 796 pub const F_SETLK: ::c_int = 6; 797 pub const F_SETLKW: ::c_int = 7; 798 pub const F_SETOWN: ::c_int = 8; 799 pub const F_OFD_GETLK: ::c_int = 36; 800 pub const F_OFD_SETLK: ::c_int = 37; 801 pub const F_OFD_SETLKW: ::c_int = 38; 802 803 pub const VEOF: usize = 4; 804 805 pub const POLLWRNORM: ::c_short = 0x100; 806 pub const POLLWRBAND: ::c_short = 0x200; 807 808 pub const SOCK_STREAM: ::c_int = 1; 809 pub const SOCK_DGRAM: ::c_int = 2; 810 811 pub const MAP_ANON: ::c_int = 0x0020; 812 pub const MAP_GROWSDOWN: ::c_int = 0x0100; 813 pub const MAP_DENYWRITE: ::c_int = 0x0800; 814 pub const MAP_EXECUTABLE: ::c_int = 0x01000; 815 pub const MAP_LOCKED: ::c_int = 0x02000; 816 pub const MAP_NORESERVE: ::c_int = 0x04000; 817 pub const MAP_POPULATE: ::c_int = 0x08000; 818 pub const MAP_NONBLOCK: ::c_int = 0x010000; 819 pub const MAP_STACK: ::c_int = 0x020000; 820 pub const MAP_HUGETLB: ::c_int = 0x040000; 821 pub const MAP_SYNC: ::c_int = 0x080000; 822 823 pub const RLIMIT_NLIMITS: ::c_int = 15; 824 pub const RLIM_NLIMITS: ::c_int = RLIMIT_NLIMITS; 825 pub const TIOCINQ: ::c_int = ::FIONREAD; 826 pub const MCL_CURRENT: ::c_int = 0x0001; 827 pub const MCL_FUTURE: ::c_int = 0x0002; 828 pub const CBAUD: ::tcflag_t = 0o0010017; 829 pub const TAB1: ::c_int = 0x00000800; 830 pub const TAB2: ::c_int = 0x00001000; 831 pub const TAB3: ::c_int = 0x00001800; 832 pub const CR1: ::c_int = 0x00000200; 833 pub const CR2: ::c_int = 0x00000400; 834 pub const CR3: ::c_int = 0x00000600; 835 pub const FF1: ::c_int = 0x00008000; 836 pub const BS1: ::c_int = 0x00002000; 837 pub const VT1: ::c_int = 0x00004000; 838 pub const VWERASE: usize = 14; 839 pub const VREPRINT: usize = 12; 840 pub const VSUSP: usize = 10; 841 pub const VSTART: usize = 8; 842 pub const VSTOP: usize = 9; 843 pub const VDISCARD: usize = 13; 844 pub const VTIME: usize = 5; 845 pub const IXON: ::tcflag_t = 0x00000400; 846 pub const IXOFF: ::tcflag_t = 0x00001000; 847 pub const ONLCR: ::tcflag_t = 0x4; 848 pub const CSIZE: ::tcflag_t = 0x00000030; 849 pub const CS6: ::tcflag_t = 0x00000010; 850 pub const CS7: ::tcflag_t = 0x00000020; 851 pub const CS8: ::tcflag_t = 0x00000030; 852 pub const CSTOPB: ::tcflag_t = 0x00000040; 853 pub const CREAD: ::tcflag_t = 0x00000080; 854 pub const PARENB: ::tcflag_t = 0x00000100; 855 pub const PARODD: ::tcflag_t = 0x00000200; 856 pub const HUPCL: ::tcflag_t = 0x00000400; 857 pub const CLOCAL: ::tcflag_t = 0x00000800; 858 pub const ECHOKE: ::tcflag_t = 0x00000800; 859 pub const ECHOE: ::tcflag_t = 0x00000010; 860 pub const ECHOK: ::tcflag_t = 0x00000020; 861 pub const ECHONL: ::tcflag_t = 0x00000040; 862 pub const ECHOPRT: ::tcflag_t = 0x00000400; 863 pub const ECHOCTL: ::tcflag_t = 0x00000200; 864 pub const ISIG: ::tcflag_t = 0x00000001; 865 pub const ICANON: ::tcflag_t = 0x00000002; 866 pub const PENDIN: ::tcflag_t = 0x00004000; 867 pub const NOFLSH: ::tcflag_t = 0x00000080; 868 pub const CIBAUD: ::tcflag_t = 0o02003600000; 869 pub const CBAUDEX: ::tcflag_t = 0o010000; 870 pub const VSWTC: usize = 7; 871 pub const OLCUC: ::tcflag_t = 0o000002; 872 pub const NLDLY: ::tcflag_t = 0o000400; 873 pub const CRDLY: ::tcflag_t = 0o003000; 874 pub const TABDLY: ::tcflag_t = 0o014000; 875 pub const BSDLY: ::tcflag_t = 0o020000; 876 pub const FFDLY: ::tcflag_t = 0o100000; 877 pub const VTDLY: ::tcflag_t = 0o040000; 878 pub const XTABS: ::tcflag_t = 0o014000; 879 pub const B57600: ::speed_t = 0o010001; 880 pub const B115200: ::speed_t = 0o010002; 881 pub const B230400: ::speed_t = 0o010003; 882 pub const B460800: ::speed_t = 0o010004; 883 pub const B500000: ::speed_t = 0o010005; 884 pub const B576000: ::speed_t = 0o010006; 885 pub const B921600: ::speed_t = 0o010007; 886 pub const B1000000: ::speed_t = 0o010010; 887 pub const B1152000: ::speed_t = 0o010011; 888 pub const B1500000: ::speed_t = 0o010012; 889 pub const B2000000: ::speed_t = 0o010013; 890 pub const B2500000: ::speed_t = 0o010014; 891 pub const B3000000: ::speed_t = 0o010015; 892 pub const B3500000: ::speed_t = 0o010016; 893 pub const B4000000: ::speed_t = 0o010017; 894 895 pub const FIOCLEX: ::c_int = 0x5451; 896 pub const FIONCLEX: ::c_int = 0x5450; 897 pub const FIONBIO: ::c_int = 0x5421; 898 pub const EDEADLK: ::c_int = 35; 899 pub const EDEADLOCK: ::c_int = EDEADLK; 900 901 pub const EXTPROC: ::tcflag_t = 0x00010000; 902 pub const VEOL: usize = 11; 903 pub const VEOL2: usize = 16; 904 pub const VMIN: usize = 6; 905 pub const IEXTEN: ::tcflag_t = 0x00008000; 906 pub const TOSTOP: ::tcflag_t = 0x00000100; 907 pub const FLUSHO: ::tcflag_t = 0x00001000; 908 pub const TCGETS: ::c_int = 0x5401; 909 pub const TCSETS: ::c_int = 0x5402; 910 pub const TCSETSW: ::c_int = 0x5403; 911 pub const TCSETSF: ::c_int = 0x5404; 912 pub const TCGETA: ::c_int = 0x5405; 913 pub const TCSETA: ::c_int = 0x5406; 914 pub const TCSETAW: ::c_int = 0x5407; 915 pub const TCSETAF: ::c_int = 0x5408; 916 pub const TCSBRK: ::c_int = 0x5409; 917 pub const TCXONC: ::c_int = 0x540A; 918 pub const TCFLSH: ::c_int = 0x540B; 919 pub const TIOCGSOFTCAR: ::c_int = 0x5419; 920 pub const TIOCSSOFTCAR: ::c_int = 0x541A; 921 pub const TIOCLINUX: ::c_int = 0x541C; 922 pub const TIOCGSERIAL: ::c_int = 0x541E; 923 pub const TIOCEXCL: ::c_int = 0x540C; 924 pub const TIOCNXCL: ::c_int = 0x540D; 925 pub const TIOCSCTTY: ::c_int = 0x540E; 926 pub const TIOCGPGRP: ::c_int = 0x540F; 927 pub const TIOCSPGRP: ::c_int = 0x5410; 928 pub const TIOCOUTQ: ::c_int = 0x5411; 929 pub const TIOCSTI: ::c_int = 0x5412; 930 pub const TIOCGWINSZ: ::c_int = 0x5413; 931 pub const TIOCSWINSZ: ::c_int = 0x5414; 932 pub const TIOCMGET: ::c_int = 0x5415; 933 pub const TIOCMBIS: ::c_int = 0x5416; 934 pub const TIOCMBIC: ::c_int = 0x5417; 935 pub const TIOCMSET: ::c_int = 0x5418; 936 pub const FIONREAD: ::c_int = 0x541B; 937 pub const TIOCCONS: ::c_int = 0x541D; 938 939 pub const TIOCM_LE: ::c_int = 0x001; 940 pub const TIOCM_DTR: ::c_int = 0x002; 941 pub const TIOCM_RTS: ::c_int = 0x004; 942 pub const TIOCM_ST: ::c_int = 0x008; 943 pub const TIOCM_SR: ::c_int = 0x010; 944 pub const TIOCM_CTS: ::c_int = 0x020; 945 pub const TIOCM_CAR: ::c_int = 0x040; 946 pub const TIOCM_RNG: ::c_int = 0x080; 947 pub const TIOCM_DSR: ::c_int = 0x100; 948 pub const TIOCM_CD: ::c_int = TIOCM_CAR; 949 pub const TIOCM_RI: ::c_int = TIOCM_RNG; 950 951 extern "C" { ioctl(fd: ::c_int, request: ::c_int, ...) -> ::c_int952 pub fn ioctl(fd: ::c_int, request: ::c_int, ...) -> ::c_int; 953 } 954 955 cfg_if! { 956 if #[cfg(libc_align)] { 957 mod align; 958 pub use self::align::*; 959 } 960 } 961