1 pub type pthread_t
= *mut ::c_void
;
2 pub type clock_t
= c_long
;
4 not(feature
= "rustc-dep-of-std"),
7 note
= "This type is changed to 64-bit in musl 1.2.0, \
8 we'll follow that change in the future release. \
9 See #1848 for more info."
12 pub type time_t
= c_long
;
13 pub type suseconds_t
= c_long
;
16 pub type blkcnt_t
= i64;
18 pub type shmatt_t
= ::c_ulong
;
19 pub type msgqnum_t
= ::c_ulong
;
20 pub type msglen_t
= ::c_ulong
;
21 pub type fsblkcnt_t
= ::c_ulonglong
;
22 pub type fsfilcnt_t
= ::c_ulonglong
;
23 pub type rlim_t
= ::c_ulonglong
;
25 pub type flock64
= flock
;
29 // Used in `linux::arch` to define ioctl constants.
30 pub(crate) type Ioctl
= ::c_int
;
33 pub type Ioctl
= ::c_int
;
38 pub unsafe fn si_addr(&self) -> *mut ::c_void
{
40 struct siginfo_sigfault
{
44 si_addr
: *mut ::c_void
,
46 (*(self as *const siginfo_t
as *const siginfo_sigfault
)).si_addr
49 pub unsafe fn si_value(&self) -> ::sigval
{
51 struct siginfo_si_value
{
59 (*(self as *const siginfo_t
as *const siginfo_si_value
)).si_value
64 if #[cfg(libc_union)] {
65 // Internal, for casts to access union fields
67 struct sifields_sigchld
{
74 impl ::Copy
for sifields_sigchld {}
75 impl ::Clone
for sifields_sigchld
{
76 fn clone(&self) -> sifields_sigchld
{
81 // Internal, for casts to access union fields
84 _align_pointer
: *mut ::c_void
,
85 sigchld
: sifields_sigchld
,
88 // Internal, for casts to access union fields. Note that some variants
89 // of sifields start with a pointer, which makes the alignment of
90 // sifields vary on 32-bit and 64-bit architectures.
93 _siginfo_base
: [::c_int
; 3],
98 unsafe fn sifields(&self) -> &sifields
{
99 &(*(self as *const siginfo_t
as *const siginfo_f
)).sifields
102 pub unsafe fn si_pid(&self) -> ::pid_t
{
103 self.sifields().sigchld
.si_pid
106 pub unsafe fn si_uid(&self) -> ::uid_t
{
107 self.sifields().sigchld
.si_uid
110 pub unsafe fn si_status(&self) -> ::c_int
{
111 self.sifields().sigchld
.si_status
114 pub unsafe fn si_utime(&self) -> ::c_long
{
115 self.sifields().sigchld
.si_utime
118 pub unsafe fn si_stime(&self) -> ::c_long
{
119 self.sifields().sigchld
.si_stime
127 pub aio_fildes
: ::c_int
,
128 pub aio_lio_opcode
: ::c_int
,
129 pub aio_reqprio
: ::c_int
,
130 pub aio_buf
: *mut ::c_void
,
131 pub aio_nbytes
: ::size_t
,
132 pub aio_sigevent
: ::sigevent
,
134 __lock
: [::c_int
; 2],
137 pub aio_offset
: off_t
,
138 __next
: *mut ::c_void
,
139 __prev
: *mut ::c_void
,
140 #[cfg(target_pointer_width = "32")]
141 __dummy4
: [::c_char
; 24],
142 #[cfg(target_pointer_width = "64")]
143 __dummy4
: [::c_char
; 16],
146 pub struct sigaction
{
147 pub sa_sigaction
: ::sighandler_t
,
148 pub sa_mask
: ::sigset_t
,
149 pub sa_flags
: ::c_int
,
150 pub sa_restorer
: ::Option
<extern fn()>,
154 pub f_bsize
: ::c_ulong
,
155 pub f_frsize
: ::c_ulong
,
156 pub f_blocks
: ::fsblkcnt_t
,
157 pub f_bfree
: ::fsblkcnt_t
,
158 pub f_bavail
: ::fsblkcnt_t
,
159 pub f_files
: ::fsfilcnt_t
,
160 pub f_ffree
: ::fsfilcnt_t
,
161 pub f_favail
: ::fsfilcnt_t
,
162 #[cfg(target_endian = "little")]
163 pub f_fsid
: ::c_ulong
,
164 #[cfg(target_pointer_width = "32")]
166 #[cfg(target_endian = "big")]
167 pub f_fsid
: ::c_ulong
,
168 pub f_flag
: ::c_ulong
,
169 pub f_namemax
: ::c_ulong
,
170 __f_spare
: [::c_int
; 6],
174 pub c_iflag
: ::tcflag_t
,
175 pub c_oflag
: ::tcflag_t
,
176 pub c_cflag
: ::tcflag_t
,
177 pub c_lflag
: ::tcflag_t
,
179 pub c_cc
: [::cc_t
; ::NCCS
],
180 pub __c_ispeed
: ::speed_t
,
181 pub __c_ospeed
: ::speed_t
,
185 pub l_type
: ::c_short
,
186 pub l_whence
: ::c_short
,
187 pub l_start
: ::off_t
,
194 __opaque
: *mut ::c_void
,
195 __padding
: [*mut ::c_void
; 4usize
],
197 __padding2
: ::c_char
,
201 pub rt_pad1
: ::c_ulong
,
202 pub rt_dst
: ::sockaddr
,
203 pub rt_gateway
: ::sockaddr
,
204 pub rt_genmask
: ::sockaddr
,
205 pub rt_flags
: ::c_ushort
,
206 pub rt_pad2
: ::c_short
,
207 pub rt_pad3
: ::c_ulong
,
208 pub rt_tos
: ::c_uchar
,
209 pub rt_class
: ::c_uchar
,
210 #[cfg(target_pointer_width = "64")]
211 pub rt_pad4
: [::c_short
; 3usize
],
212 #[cfg(not(target_pointer_width = "64"))]
213 pub rt_pad4
: [::c_short
; 1usize
],
214 pub rt_metric
: ::c_short
,
215 pub rt_dev
: *mut ::c_char
,
216 pub rt_mtu
: ::c_ulong
,
217 pub rt_window
: ::c_ulong
,
218 pub rt_irtt
: ::c_ushort
,
221 pub struct __exit_status
{
222 pub e_termination
: ::c_short
,
223 pub e_exit
: ::c_short
,
226 pub struct Elf64_Chdr
{
227 pub ch_type
: ::Elf64_Word
,
228 pub ch_reserved
: ::Elf64_Word
,
229 pub ch_size
: ::Elf64_Xword
,
230 pub ch_addralign
: ::Elf64_Xword
,
233 pub struct Elf32_Chdr
{
234 pub ch_type
: ::Elf32_Word
,
235 pub ch_size
: ::Elf32_Word
,
236 pub ch_addralign
: ::Elf32_Word
,
241 pub offset
: ::c_long
,
243 pub maxerror
: ::c_long
,
244 pub esterror
: ::c_long
,
246 pub constant
: ::c_long
,
247 pub precision
: ::c_long
,
248 pub tolerance
: ::c_long
,
251 pub ppsfreq
: ::c_long
,
252 pub jitter
: ::c_long
,
254 pub stabil
: ::c_long
,
255 pub jitcnt
: ::c_long
,
256 pub calcnt
: ::c_long
,
257 pub errcnt
: ::c_long
,
258 pub stbcnt
: ::c_long
,
260 pub __padding
: [::c_int
; 11],
263 pub struct ntptimeval
{
265 pub maxerror
: ::c_long
,
266 pub esterror
: ::c_long
,
272 pub uptime
: ::c_ulong
,
273 pub loads
: [::c_ulong
; 3],
274 pub totalram
: ::c_ulong
,
275 pub freeram
: ::c_ulong
,
276 pub sharedram
: ::c_ulong
,
277 pub bufferram
: ::c_ulong
,
278 pub totalswap
: ::c_ulong
,
279 pub freeswap
: ::c_ulong
,
280 pub procs
: ::c_ushort
,
282 pub totalhigh
: ::c_ulong
,
283 pub freehigh
: ::c_ulong
,
284 pub mem_unit
: ::c_uint
,
285 pub __reserved
: [::c_char
; 256],
288 // FIXME: musl added paddings and adjusted
289 // layout in 1.2.0 but our CI is still 1.1.24.
290 // So, I'm leaving some fields as comments for now.
291 // ref. https://github.com/bminor/musl/commit/
292 // 1e7f0fcd7ff2096904fd93a2ee6d12a2392be392
294 pub ut_type
: ::c_short
,
295 //__ut_pad1: ::c_short,
297 pub ut_line
: [::c_char
; 32],
298 pub ut_id
: [::c_char
; 4],
299 pub ut_user
: [::c_char
; 32],
300 pub ut_host
: [::c_char
; 256],
301 pub ut_exit
: __exit_status
,
303 //#[cfg(target_endian = "little")]
304 pub ut_session
: ::c_long
,
305 //#[cfg(target_endian = "little")]
306 //__ut_pad2: ::c_long,
308 //#[cfg(not(target_endian = "little"))]
309 //__ut_pad2: ::c_int,
310 //#[cfg(not(target_endian = "little"))]
311 //pub ut_session: ::c_int,
313 pub ut_tv
: ::timeval
,
314 pub ut_addr_v6
: [::c_uint
; 4],
315 __unused
: [::c_char
; 20],
320 if #[cfg(feature = "extra_traits")] {
321 impl PartialEq
for sysinfo
{
322 fn eq(&self, other
: &sysinfo
) -> bool
{
323 self.uptime
== other
.uptime
324 && self.loads
== other
.loads
325 && self.totalram
== other
.totalram
326 && self.freeram
== other
.freeram
327 && self.sharedram
== other
.sharedram
328 && self.bufferram
== other
.bufferram
329 && self.totalswap
== other
.totalswap
330 && self.freeswap
== other
.freeswap
331 && self.procs
== other
.procs
332 && self.pad
== other
.pad
333 && self.totalhigh
== other
.totalhigh
334 && self.freehigh
== other
.freehigh
335 && self.mem_unit
== other
.mem_unit
339 .zip(other
.__reserved
.iter())
344 impl Eq
for sysinfo {}
346 impl ::fmt
::Debug
for sysinfo
{
347 fn fmt(&self, f
: &mut ::fmt
::Formatter
) -> ::fmt
::Result
{
348 f
.debug_struct("sysinfo")
349 .field("uptime", &self.uptime
)
350 .field("loads", &self.loads
)
351 .field("totalram", &self.totalram
)
352 .field("freeram", &self.freeram
)
353 .field("sharedram", &self.sharedram
)
354 .field("bufferram", &self.bufferram
)
355 .field("totalswap", &self.totalswap
)
356 .field("freeswap", &self.freeswap
)
357 .field("procs", &self.procs
)
358 .field("pad", &self.pad
)
359 .field("totalhigh", &self.totalhigh
)
360 .field("freehigh", &self.freehigh
)
361 .field("mem_unit", &self.mem_unit
)
362 // FIXME: .field("__reserved", &self.__reserved)
367 impl ::hash
::Hash
for sysinfo
{
368 fn hash
<H
: ::hash
::Hasher
>(&self, state
: &mut H
) {
369 self.uptime
.hash(state
);
370 self.loads
.hash(state
);
371 self.totalram
.hash(state
);
372 self.freeram
.hash(state
);
373 self.sharedram
.hash(state
);
374 self.bufferram
.hash(state
);
375 self.totalswap
.hash(state
);
376 self.freeswap
.hash(state
);
377 self.procs
.hash(state
);
378 self.pad
.hash(state
);
379 self.totalhigh
.hash(state
);
380 self.freehigh
.hash(state
);
381 self.mem_unit
.hash(state
);
382 self.__reserved
.hash(state
);
386 impl PartialEq
for utmpx
{
387 fn eq(&self, other
: &utmpx
) -> bool
{
388 self.ut_type
== other
.ut_type
389 //&& self.__ut_pad1 == other.__ut_pad1
390 && self.ut_pid
== other
.ut_pid
391 && self.ut_line
== other
.ut_line
392 && self.ut_id
== other
.ut_id
393 && self.ut_user
== other
.ut_user
397 .zip(other
.ut_host
.iter())
399 && self.ut_exit
== other
.ut_exit
400 && self.ut_session
== other
.ut_session
401 //&& self.__ut_pad2 == other.__ut_pad2
402 && self.ut_tv
== other
.ut_tv
403 && self.ut_addr_v6
== other
.ut_addr_v6
404 && self.__unused
== other
.__unused
410 impl ::fmt
::Debug
for utmpx
{
411 fn fmt(&self, f
: &mut ::fmt
::Formatter
) -> ::fmt
::Result
{
412 f
.debug_struct("utmpx")
413 .field("ut_type", &self.ut_type
)
414 //.field("__ut_pad1", &self.__ut_pad1)
415 .field("ut_pid", &self.ut_pid
)
416 .field("ut_line", &self.ut_line
)
417 .field("ut_id", &self.ut_id
)
418 .field("ut_user", &self.ut_user
)
419 //FIXME: .field("ut_host", &self.ut_host)
420 .field("ut_exit", &self.ut_exit
)
421 .field("ut_session", &self.ut_session
)
422 //.field("__ut_pad2", &self.__ut_pad2)
423 .field("ut_tv", &self.ut_tv
)
424 .field("ut_addr_v6", &self.ut_addr_v6
)
425 .field("__unused", &self.__unused
)
430 impl ::hash
::Hash
for utmpx
{
431 fn hash
<H
: ::hash
::Hasher
>(&self, state
: &mut H
) {
432 self.ut_type
.hash(state
);
433 //self.__ut_pad1.hash(state);
434 self.ut_pid
.hash(state
);
435 self.ut_line
.hash(state
);
436 self.ut_id
.hash(state
);
437 self.ut_user
.hash(state
);
438 self.ut_host
.hash(state
);
439 self.ut_exit
.hash(state
);
440 self.ut_session
.hash(state
);
441 //self.__ut_pad2.hash(state);
442 self.ut_tv
.hash(state
);
443 self.ut_addr_v6
.hash(state
);
444 self.__unused
.hash(state
);
450 // include/sys/mman.h
452 * Huge page size encoding when MAP_HUGETLB is specified, and a huge page
453 * size other than the default is desired. See hugetlb_encode.h.
454 * All known huge page size encodings are provided here. It is the
455 * responsibility of the application to know which sizes are supported on
456 * the running system. See mmap(2) man page for details.
458 pub const MAP_HUGE_SHIFT
: ::c_int
= 26;
459 pub const MAP_HUGE_MASK
: ::c_int
= 0x3f;
461 pub const MAP_HUGE_64KB
: ::c_int
= 16 << MAP_HUGE_SHIFT
;
462 pub const MAP_HUGE_512KB
: ::c_int
= 19 << MAP_HUGE_SHIFT
;
463 pub const MAP_HUGE_1MB
: ::c_int
= 20 << MAP_HUGE_SHIFT
;
464 pub const MAP_HUGE_2MB
: ::c_int
= 21 << MAP_HUGE_SHIFT
;
465 pub const MAP_HUGE_8MB
: ::c_int
= 23 << MAP_HUGE_SHIFT
;
466 pub const MAP_HUGE_16MB
: ::c_int
= 24 << MAP_HUGE_SHIFT
;
467 pub const MAP_HUGE_32MB
: ::c_int
= 25 << MAP_HUGE_SHIFT
;
468 pub const MAP_HUGE_256MB
: ::c_int
= 28 << MAP_HUGE_SHIFT
;
469 pub const MAP_HUGE_512MB
: ::c_int
= 29 << MAP_HUGE_SHIFT
;
470 pub const MAP_HUGE_1GB
: ::c_int
= 30 << MAP_HUGE_SHIFT
;
471 pub const MAP_HUGE_2GB
: ::c_int
= 31 << MAP_HUGE_SHIFT
;
472 pub const MAP_HUGE_16GB
: ::c_int
= 34 << MAP_HUGE_SHIFT
;
474 pub const MS_RMT_MASK
: ::c_ulong
= 0x02800051;
476 pub const SFD_CLOEXEC
: ::c_int
= 0x080000;
478 pub const NCCS
: usize = 32;
480 pub const O_TRUNC
: ::c_int
= 512;
481 pub const O_NOATIME
: ::c_int
= 0o1000000;
482 pub const O_CLOEXEC
: ::c_int
= 0x80000;
483 pub const O_TMPFILE
: ::c_int
= 0o20000000 | O_DIRECTORY
;
485 pub const EBFONT
: ::c_int
= 59;
486 pub const ENOSTR
: ::c_int
= 60;
487 pub const ENODATA
: ::c_int
= 61;
488 pub const ETIME
: ::c_int
= 62;
489 pub const ENOSR
: ::c_int
= 63;
490 pub const ENONET
: ::c_int
= 64;
491 pub const ENOPKG
: ::c_int
= 65;
492 pub const EREMOTE
: ::c_int
= 66;
493 pub const ENOLINK
: ::c_int
= 67;
494 pub const EADV
: ::c_int
= 68;
495 pub const ESRMNT
: ::c_int
= 69;
496 pub const ECOMM
: ::c_int
= 70;
497 pub const EPROTO
: ::c_int
= 71;
498 pub const EDOTDOT
: ::c_int
= 73;
500 pub const F_RDLCK
: ::c_int
= 0;
501 pub const F_WRLCK
: ::c_int
= 1;
502 pub const F_UNLCK
: ::c_int
= 2;
504 pub const SA_NODEFER
: ::c_int
= 0x40000000;
505 pub const SA_RESETHAND
: ::c_int
= 0x80000000;
506 pub const SA_RESTART
: ::c_int
= 0x10000000;
507 pub const SA_NOCLDSTOP
: ::c_int
= 0x00000001;
509 pub const EPOLL_CLOEXEC
: ::c_int
= 0x80000;
511 pub const EFD_CLOEXEC
: ::c_int
= 0x80000;
513 pub const BUFSIZ
: ::c_uint
= 1024;
514 pub const TMP_MAX
: ::c_uint
= 10000;
515 pub const FOPEN_MAX
: ::c_uint
= 1000;
516 pub const FILENAME_MAX
: ::c_uint
= 4096;
517 pub const O_PATH
: ::c_int
= 0o10000000;
518 pub const O_EXEC
: ::c_int
= 0o10000000;
519 pub const O_SEARCH
: ::c_int
= 0o10000000;
520 pub const O_ACCMODE
: ::c_int
= 0o10000003;
521 pub const O_NDELAY
: ::c_int
= O_NONBLOCK
;
522 pub const NI_MAXHOST
: ::socklen_t
= 255;
523 pub const PTHREAD_STACK_MIN
: ::size_t
= 2048;
525 pub const POSIX_MADV_DONTNEED
: ::c_int
= 4;
527 pub const MAP_ANONYMOUS
: ::c_int
= MAP_ANON
;
529 pub const SOCK_DCCP
: ::c_int
= 6;
530 pub const SOCK_PACKET
: ::c_int
= 10;
532 pub const SOMAXCONN
: ::c_int
= 128;
534 #[deprecated(since = "0.2.55", note = "Use SIGSYS instead")]
535 pub const SIGUNUSED
: ::c_int
= ::SIGSYS
;
537 pub const __SIZEOF_PTHREAD_CONDATTR_T
: usize = 4;
538 pub const __SIZEOF_PTHREAD_MUTEXATTR_T
: usize = 4;
539 pub const __SIZEOF_PTHREAD_RWLOCKATTR_T
: usize = 8;
541 pub const CPU_SETSIZE
: ::c_int
= 128;
543 pub const PTRACE_TRACEME
: ::c_int
= 0;
544 pub const PTRACE_PEEKTEXT
: ::c_int
= 1;
545 pub const PTRACE_PEEKDATA
: ::c_int
= 2;
546 pub const PTRACE_PEEKUSER
: ::c_int
= 3;
547 pub const PTRACE_POKETEXT
: ::c_int
= 4;
548 pub const PTRACE_POKEDATA
: ::c_int
= 5;
549 pub const PTRACE_POKEUSER
: ::c_int
= 6;
550 pub const PTRACE_CONT
: ::c_int
= 7;
551 pub const PTRACE_KILL
: ::c_int
= 8;
552 pub const PTRACE_SINGLESTEP
: ::c_int
= 9;
553 pub const PTRACE_GETREGS
: ::c_int
= 12;
554 pub const PTRACE_SETREGS
: ::c_int
= 13;
555 pub const PTRACE_GETFPREGS
: ::c_int
= 14;
556 pub const PTRACE_SETFPREGS
: ::c_int
= 15;
557 pub const PTRACE_ATTACH
: ::c_int
= 16;
558 pub const PTRACE_DETACH
: ::c_int
= 17;
559 pub const PTRACE_GETFPXREGS
: ::c_int
= 18;
560 pub const PTRACE_SETFPXREGS
: ::c_int
= 19;
561 pub const PTRACE_SYSCALL
: ::c_int
= 24;
562 pub const PTRACE_SETOPTIONS
: ::c_int
= 0x4200;
563 pub const PTRACE_GETEVENTMSG
: ::c_int
= 0x4201;
564 pub const PTRACE_GETSIGINFO
: ::c_int
= 0x4202;
565 pub const PTRACE_SETSIGINFO
: ::c_int
= 0x4203;
566 pub const PTRACE_GETREGSET
: ::c_int
= 0x4204;
567 pub const PTRACE_SETREGSET
: ::c_int
= 0x4205;
568 pub const PTRACE_SEIZE
: ::c_int
= 0x4206;
569 pub const PTRACE_INTERRUPT
: ::c_int
= 0x4207;
570 pub const PTRACE_LISTEN
: ::c_int
= 0x4208;
571 pub const PTRACE_PEEKSIGINFO
: ::c_int
= 0x4209;
573 pub const FAN_MARK_INODE
: ::c_uint
= 0x0000_0000;
574 pub const FAN_MARK_MOUNT
: ::c_uint
= 0x0000_0010;
575 // NOTE: FAN_MARK_FILESYSTEM requires Linux Kernel >= 4.20.0
576 pub const FAN_MARK_FILESYSTEM
: ::c_uint
= 0x0000_0100;
578 pub const AF_IB
: ::c_int
= 27;
579 pub const AF_MPLS
: ::c_int
= 28;
580 pub const AF_NFC
: ::c_int
= 39;
581 pub const AF_VSOCK
: ::c_int
= 40;
582 pub const AF_XDP
: ::c_int
= 44;
583 pub const PF_IB
: ::c_int
= AF_IB
;
584 pub const PF_MPLS
: ::c_int
= AF_MPLS
;
585 pub const PF_NFC
: ::c_int
= AF_NFC
;
586 pub const PF_VSOCK
: ::c_int
= AF_VSOCK
;
587 pub const PF_XDP
: ::c_int
= AF_XDP
;
589 pub const EFD_NONBLOCK
: ::c_int
= ::O_NONBLOCK
;
591 pub const SFD_NONBLOCK
: ::c_int
= ::O_NONBLOCK
;
593 pub const TCSANOW
: ::c_int
= 0;
594 pub const TCSADRAIN
: ::c_int
= 1;
595 pub const TCSAFLUSH
: ::c_int
= 2;
597 pub const RTLD_GLOBAL
: ::c_int
= 0x100;
598 pub const RTLD_NOLOAD
: ::c_int
= 0x4;
600 pub const CLOCK_SGI_CYCLE
: ::clockid_t
= 10;
602 pub const B0
: ::speed_t
= 0o000000;
603 pub const B50
: ::speed_t
= 0o000001;
604 pub const B75
: ::speed_t
= 0o000002;
605 pub const B110
: ::speed_t
= 0o000003;
606 pub const B134
: ::speed_t
= 0o000004;
607 pub const B150
: ::speed_t
= 0o000005;
608 pub const B200
: ::speed_t
= 0o000006;
609 pub const B300
: ::speed_t
= 0o000007;
610 pub const B600
: ::speed_t
= 0o000010;
611 pub const B1200
: ::speed_t
= 0o000011;
612 pub const B1800
: ::speed_t
= 0o000012;
613 pub const B2400
: ::speed_t
= 0o000013;
614 pub const B4800
: ::speed_t
= 0o000014;
615 pub const B9600
: ::speed_t
= 0o000015;
616 pub const B19200
: ::speed_t
= 0o000016;
617 pub const B38400
: ::speed_t
= 0o000017;
618 pub const EXTA
: ::speed_t
= B19200
;
619 pub const EXTB
: ::speed_t
= B38400
;
621 pub const REG_OK
: ::c_int
= 0;
623 pub const PRIO_PROCESS
: ::c_int
= 0;
624 pub const PRIO_PGRP
: ::c_int
= 1;
625 pub const PRIO_USER
: ::c_int
= 2;
627 pub const ADJ_OFFSET
: ::c_uint
= 0x0001;
628 pub const ADJ_FREQUENCY
: ::c_uint
= 0x0002;
629 pub const ADJ_MAXERROR
: ::c_uint
= 0x0004;
630 pub const ADJ_ESTERROR
: ::c_uint
= 0x0008;
631 pub const ADJ_STATUS
: ::c_uint
= 0x0010;
632 pub const ADJ_TIMECONST
: ::c_uint
= 0x0020;
633 pub const ADJ_TAI
: ::c_uint
= 0x0080;
634 pub const ADJ_SETOFFSET
: ::c_uint
= 0x0100;
635 pub const ADJ_MICRO
: ::c_uint
= 0x1000;
636 pub const ADJ_NANO
: ::c_uint
= 0x2000;
637 pub const ADJ_TICK
: ::c_uint
= 0x4000;
638 pub const ADJ_OFFSET_SINGLESHOT
: ::c_uint
= 0x8001;
639 pub const ADJ_OFFSET_SS_READ
: ::c_uint
= 0xa001;
640 pub const MOD_OFFSET
: ::c_uint
= ADJ_OFFSET
;
641 pub const MOD_FREQUENCY
: ::c_uint
= ADJ_FREQUENCY
;
642 pub const MOD_MAXERROR
: ::c_uint
= ADJ_MAXERROR
;
643 pub const MOD_ESTERROR
: ::c_uint
= ADJ_ESTERROR
;
644 pub const MOD_STATUS
: ::c_uint
= ADJ_STATUS
;
645 pub const MOD_TIMECONST
: ::c_uint
= ADJ_TIMECONST
;
646 pub const MOD_CLKB
: ::c_uint
= ADJ_TICK
;
647 pub const MOD_CLKA
: ::c_uint
= ADJ_OFFSET_SINGLESHOT
;
648 pub const MOD_TAI
: ::c_uint
= ADJ_TAI
;
649 pub const MOD_MICRO
: ::c_uint
= ADJ_MICRO
;
650 pub const MOD_NANO
: ::c_uint
= ADJ_NANO
;
651 pub const STA_PLL
: ::c_int
= 0x0001;
652 pub const STA_PPSFREQ
: ::c_int
= 0x0002;
653 pub const STA_PPSTIME
: ::c_int
= 0x0004;
654 pub const STA_FLL
: ::c_int
= 0x0008;
655 pub const STA_INS
: ::c_int
= 0x0010;
656 pub const STA_DEL
: ::c_int
= 0x0020;
657 pub const STA_UNSYNC
: ::c_int
= 0x0040;
658 pub const STA_FREQHOLD
: ::c_int
= 0x0080;
659 pub const STA_PPSSIGNAL
: ::c_int
= 0x0100;
660 pub const STA_PPSJITTER
: ::c_int
= 0x0200;
661 pub const STA_PPSWANDER
: ::c_int
= 0x0400;
662 pub const STA_PPSERROR
: ::c_int
= 0x0800;
663 pub const STA_CLOCKERR
: ::c_int
= 0x1000;
664 pub const STA_NANO
: ::c_int
= 0x2000;
665 pub const STA_MODE
: ::c_int
= 0x4000;
666 pub const STA_CLK
: ::c_int
= 0x8000;
667 pub const STA_RONLY
: ::c_int
= STA_PPSSIGNAL
676 pub const TIME_OK
: ::c_int
= 0;
677 pub const TIME_INS
: ::c_int
= 1;
678 pub const TIME_DEL
: ::c_int
= 2;
679 pub const TIME_OOP
: ::c_int
= 3;
680 pub const TIME_WAIT
: ::c_int
= 4;
681 pub const TIME_ERROR
: ::c_int
= 5;
682 pub const TIME_BAD
: ::c_int
= TIME_ERROR
;
683 pub const MAXTC
: ::c_long
= 6;
686 if #[cfg(target_arch = "s390x")] {
687 pub const POSIX_FADV_DONTNEED
: ::c_int
= 6;
688 pub const POSIX_FADV_NOREUSE
: ::c_int
= 7;
690 pub const POSIX_FADV_DONTNEED
: ::c_int
= 4;
691 pub const POSIX_FADV_NOREUSE
: ::c_int
= 5;
698 msgvec
: *mut ::mmsghdr
,
704 msgvec
: *mut ::mmsghdr
,
707 timeout
: *mut ::timespec
,
710 pub fn getrlimit64(resource
: ::c_int
, rlim
: *mut ::rlimit64
) -> ::c_int
;
711 pub fn setrlimit64(resource
: ::c_int
, rlim
: *const ::rlimit64
) -> ::c_int
;
712 pub fn getrlimit(resource
: ::c_int
, rlim
: *mut ::rlimit
) -> ::c_int
;
713 pub fn setrlimit(resource
: ::c_int
, rlim
: *const ::rlimit
) -> ::c_int
;
717 new_limit
: *const ::rlimit
,
718 old_limit
: *mut ::rlimit
,
723 new_limit
: *const ::rlimit64
,
724 old_limit
: *mut ::rlimit64
,
727 pub fn ioctl(fd
: ::c_int
, request
: ::c_int
, ...) -> ::c_int
;
728 pub fn gettimeofday(tp
: *mut ::timeval
, tz
: *mut ::c_void
) -> ::c_int
;
729 pub fn ptrace(request
: ::c_int
, ...) -> ::c_long
;
730 pub fn getpriority(which
: ::c_int
, who
: ::id_t
) -> ::c_int
;
731 pub fn setpriority(which
: ::c_int
, who
: ::id_t
, prio
: ::c_int
) -> ::c_int
;
732 // Musl targets need the `mask` argument of `fanotify_mark` be specified
733 // `::c_ulonglong` instead of `u64` or there will be a type mismatch between
734 // `long long unsigned int` and the expected `uint64_t`.
735 pub fn fanotify_mark(
740 path
: *const ::c_char
,
742 pub fn getauxval(type_
: ::c_ulong
) -> ::c_ulong
;
744 // Added in `musl` 1.1.20
745 pub fn explicit_bzero(s
: *mut ::c_void
, len
: ::size_t
);
746 // Added in `musl` 1.2.2
747 pub fn reallocarray(ptr
: *mut ::c_void
, nmemb
: ::size_t
, size
: ::size_t
) -> *mut ::c_void
;
749 pub fn adjtimex(buf
: *mut ::timex
) -> ::c_int
;
750 pub fn clock_adjtime(clk_id
: ::clockid_t
, buf
: *mut ::timex
) -> ::c_int
;
752 pub fn ctermid(s
: *mut ::c_char
) -> *mut ::c_char
;
754 pub fn memfd_create(name
: *const ::c_char
, flags
: ::c_uint
) -> ::c_int
;
755 pub fn mlock2(addr
: *const ::c_void
, len
: ::size_t
, flags
: ::c_uint
) -> ::c_int
;
756 pub fn malloc_usable_size(ptr
: *mut ::c_void
) -> ::size_t
;
758 pub fn euidaccess(pathname
: *const ::c_char
, mode
: ::c_int
) -> ::c_int
;
759 pub fn eaccess(pathname
: *const ::c_char
, mode
: ::c_int
) -> ::c_int
;
763 if #[cfg(any(target_arch = "x86_64",
764 target_arch
= "aarch64",
765 target_arch
= "mips64",
766 target_arch
= "powerpc64",
767 target_arch
= "s390x",
768 target_arch
= "riscv64"))] {
770 pub use self::b64
::*;
771 } else if #[cfg(any(target_arch = "x86",
772 target_arch
= "mips",
773 target_arch
= "powerpc",
774 target_arch
= "hexagon",
775 target_arch
= "riscv32",
776 target_arch
= "arm"))] {
778 pub use self::b32
::*;