1#![allow(non_camel_case_types)]
6
7use std::fmt::{self, Debug};
8use std::hash::{Hash, Hasher};
9use std::sync::atomic::AtomicI32;
10#[cfg(feature = "zerocopy")]
11use zerocopy::{FromBytes, FromZeros, Immutable, IntoBytes, KnownLayout};
12
13pub type zx_addr_t = usize;
14pub type zx_stream_seek_origin_t = u32;
15pub type zx_clock_t = u32;
16pub type zx_duration_t = i64;
17pub type zx_duration_mono_t = i64;
18pub type zx_duration_mono_ticks_t = i64;
19pub type zx_duration_boot_t = i64;
20pub type zx_duration_boot_ticks_t = i64;
21pub type zx_futex_t = AtomicI32;
22pub type zx_gpaddr_t = usize;
23pub type zx_vcpu_option_t = u32;
24pub type zx_guest_trap_t = u32;
25pub type zx_handle_t = u32;
26pub type zx_handle_op_t = u32;
27pub type zx_koid_t = u64;
28pub type zx_obj_type_t = u32;
29pub type zx_object_info_topic_t = u32;
30pub type zx_info_maps_type_t = u32;
31pub type zx_instant_boot_t = i64;
32pub type zx_instant_boot_ticks_t = i64;
33pub type zx_instant_mono_t = i64;
34pub type zx_instant_mono_ticks_t = i64;
35pub type zx_iob_access_t = u32;
36pub type zx_iob_allocate_id_options_t = u32;
37pub type zx_iob_discipline_type_t = u64;
38pub type zx_iob_region_type_t = u32;
39pub type zx_iob_write_options_t = u64;
40pub type zx_off_t = u64;
41pub type zx_paddr_t = usize;
42pub type zx_rights_t = u32;
43pub type zx_rsrc_flags_t = u32;
44pub type zx_rsrc_kind_t = u32;
45pub type zx_signals_t = u32;
46pub type zx_ssize_t = isize;
47pub type zx_status_t = i32;
48pub type zx_rsrc_system_base_t = u64;
49pub type zx_ticks_t = i64;
50pub type zx_time_t = i64;
51pub type zx_txid_t = u32;
52pub type zx_vaddr_t = usize;
53pub type zx_vm_option_t = u32;
54pub type zx_thread_state_topic_t = u32;
55pub type zx_vcpu_state_topic_t = u32;
56pub type zx_restricted_reason_t = u64;
57pub type zx_processor_power_level_options_t = u64;
58pub type zx_processor_power_control_t = u64;
59pub type zx_system_memory_stall_type_t = u32;
60pub type zx_system_suspend_option_t = u64;
61pub type zx_system_wake_report_entry_flag_t = u32;
62
63macro_rules! const_assert {
64 ($e:expr $(,)?) => {
65 const _: [(); 1 - { const ASSERT: bool = $e; ASSERT as usize }] = [];
66 };
67}
68macro_rules! const_assert_eq {
69 ($lhs:expr, $rhs:expr $(,)?) => {
70 const_assert!($lhs == $rhs);
71 };
72}
73
74#[repr(C)]
76#[derive(Debug, Copy, Clone, Eq, PartialEq)]
77pub struct zx_string_view_t {
78 pub c_str: *const u8, pub length: usize,
80}
81
82pub const ZX_MAX_NAME_LEN: usize = 32;
83
84macro_rules! multiconst {
92 ($typename:ident, [$($(#[$attr:meta])* $rawname:ident = $value:expr;)*]) => {
93 $(
94 $(#[$attr])*
95 pub const $rawname: $typename = $value;
96 )*
97 }
98}
99
100multiconst!(zx_handle_t, [
101 ZX_HANDLE_INVALID = 0;
102]);
103
104multiconst!(zx_handle_op_t, [
105 ZX_HANDLE_OP_MOVE = 0;
106 ZX_HANDLE_OP_DUPLICATE = 1;
107]);
108
109multiconst!(zx_koid_t, [
110 ZX_KOID_INVALID = 0;
111 ZX_KOID_KERNEL = 1;
112 ZX_KOID_FIRST = 1024;
113]);
114
115multiconst!(zx_time_t, [
116 ZX_TIME_INFINITE = i64::MAX;
117 ZX_TIME_INFINITE_PAST = ::std::i64::MIN;
118]);
119
120multiconst!(zx_rights_t, [
121 ZX_RIGHT_NONE = 0;
122 ZX_RIGHT_DUPLICATE = 1 << 0;
123 ZX_RIGHT_TRANSFER = 1 << 1;
124 ZX_RIGHT_READ = 1 << 2;
125 ZX_RIGHT_WRITE = 1 << 3;
126 ZX_RIGHT_EXECUTE = 1 << 4;
127 ZX_RIGHT_MAP = 1 << 5;
128 ZX_RIGHT_GET_PROPERTY = 1 << 6;
129 ZX_RIGHT_SET_PROPERTY = 1 << 7;
130 ZX_RIGHT_ENUMERATE = 1 << 8;
131 ZX_RIGHT_DESTROY = 1 << 9;
132 ZX_RIGHT_SET_POLICY = 1 << 10;
133 ZX_RIGHT_GET_POLICY = 1 << 11;
134 ZX_RIGHT_SIGNAL = 1 << 12;
135 ZX_RIGHT_SIGNAL_PEER = 1 << 13;
136 ZX_RIGHT_WAIT = 1 << 14;
137 ZX_RIGHT_INSPECT = 1 << 15;
138 ZX_RIGHT_MANAGE_JOB = 1 << 16;
139 ZX_RIGHT_MANAGE_PROCESS = 1 << 17;
140 ZX_RIGHT_MANAGE_THREAD = 1 << 18;
141 ZX_RIGHT_APPLY_PROFILE = 1 << 19;
142 ZX_RIGHT_MANAGE_SOCKET = 1 << 20;
143 ZX_RIGHT_OP_CHILDREN = 1 << 21;
144 ZX_RIGHT_RESIZE = 1 << 22;
145 ZX_RIGHT_ATTACH_VMO = 1 << 23;
146 ZX_RIGHT_MANAGE_VMO = 1 << 24;
147 ZX_RIGHT_SAME_RIGHTS = 1 << 31;
148]);
149
150multiconst!(u32, [
151 ZX_VMO_RESIZABLE = 1 << 1;
152 ZX_VMO_DISCARDABLE = 1 << 2;
153 ZX_VMO_TRAP_DIRTY = 1 << 3;
154 ZX_VMO_UNBOUNDED = 1 << 4;
155]);
156
157multiconst!(u64, [
158 ZX_VMO_DIRTY_RANGE_IS_ZERO = 1;
159]);
160
161multiconst!(u32, [
162 ZX_INFO_VMO_TYPE_PAGED = 1 << 0;
163 ZX_INFO_VMO_RESIZABLE = 1 << 1;
164 ZX_INFO_VMO_IS_COW_CLONE = 1 << 2;
165 ZX_INFO_VMO_VIA_HANDLE = 1 << 3;
166 ZX_INFO_VMO_VIA_MAPPING = 1 << 4;
167 ZX_INFO_VMO_PAGER_BACKED = 1 << 5;
168 ZX_INFO_VMO_CONTIGUOUS = 1 << 6;
169 ZX_INFO_VMO_DISCARDABLE = 1 << 7;
170 ZX_INFO_VMO_IMMUTABLE = 1 << 8;
171 ZX_INFO_VMO_VIA_IOB_HANDLE = 1 << 9;
172]);
173
174multiconst!(u32, [
175 ZX_VMO_OP_COMMIT = 1;
176 ZX_VMO_OP_DECOMMIT = 2;
177 ZX_VMO_OP_LOCK = 3;
178 ZX_VMO_OP_UNLOCK = 4;
179 ZX_VMO_OP_CACHE_SYNC = 6;
180 ZX_VMO_OP_CACHE_INVALIDATE = 7;
181 ZX_VMO_OP_CACHE_CLEAN = 8;
182 ZX_VMO_OP_CACHE_CLEAN_INVALIDATE = 9;
183 ZX_VMO_OP_ZERO = 10;
184 ZX_VMO_OP_TRY_LOCK = 11;
185 ZX_VMO_OP_DONT_NEED = 12;
186 ZX_VMO_OP_ALWAYS_NEED = 13;
187 ZX_VMO_OP_PREFETCH = 14;
188]);
189
190multiconst!(u32, [
191 ZX_VMAR_OP_COMMIT = 1;
192 ZX_VMAR_OP_DECOMMIT = 2;
193 ZX_VMAR_OP_MAP_RANGE = 3;
194 ZX_VMAR_OP_ZERO = 10;
195 ZX_VMAR_OP_DONT_NEED = 12;
196 ZX_VMAR_OP_ALWAYS_NEED = 13;
197 ZX_VMAR_OP_PREFETCH = 14;
198]);
199
200multiconst!(zx_vm_option_t, [
201 ZX_VM_PERM_READ = 1 << 0;
202 ZX_VM_PERM_WRITE = 1 << 1;
203 ZX_VM_PERM_EXECUTE = 1 << 2;
204 ZX_VM_COMPACT = 1 << 3;
205 ZX_VM_SPECIFIC = 1 << 4;
206 ZX_VM_SPECIFIC_OVERWRITE = 1 << 5;
207 ZX_VM_CAN_MAP_SPECIFIC = 1 << 6;
208 ZX_VM_CAN_MAP_READ = 1 << 7;
209 ZX_VM_CAN_MAP_WRITE = 1 << 8;
210 ZX_VM_CAN_MAP_EXECUTE = 1 << 9;
211 ZX_VM_MAP_RANGE = 1 << 10;
212 ZX_VM_REQUIRE_NON_RESIZABLE = 1 << 11;
213 ZX_VM_ALLOW_FAULTS = 1 << 12;
214 ZX_VM_OFFSET_IS_UPPER_LIMIT = 1 << 13;
215 ZX_VM_PERM_READ_IF_XOM_UNSUPPORTED = 1 << 14;
216 ZX_VM_FAULT_BEYOND_STREAM_SIZE = 1 << 15;
217
218 ZX_VM_ALIGN_BASE = 24;
220 ZX_VM_ALIGN_1KB = 10 << ZX_VM_ALIGN_BASE;
221 ZX_VM_ALIGN_2KB = 11 << ZX_VM_ALIGN_BASE;
222 ZX_VM_ALIGN_4KB = 12 << ZX_VM_ALIGN_BASE;
223 ZX_VM_ALIGN_8KB = 13 << ZX_VM_ALIGN_BASE;
224 ZX_VM_ALIGN_16KB = 14 << ZX_VM_ALIGN_BASE;
225 ZX_VM_ALIGN_32KB = 15 << ZX_VM_ALIGN_BASE;
226 ZX_VM_ALIGN_64KB = 16 << ZX_VM_ALIGN_BASE;
227 ZX_VM_ALIGN_128KB = 17 << ZX_VM_ALIGN_BASE;
228 ZX_VM_ALIGN_256KB = 18 << ZX_VM_ALIGN_BASE;
229 ZX_VM_ALIGN_512KB = 19 << ZX_VM_ALIGN_BASE;
230 ZX_VM_ALIGN_1MB = 20 << ZX_VM_ALIGN_BASE;
231 ZX_VM_ALIGN_2MB = 21 << ZX_VM_ALIGN_BASE;
232 ZX_VM_ALIGN_4MB = 22 << ZX_VM_ALIGN_BASE;
233 ZX_VM_ALIGN_8MB = 23 << ZX_VM_ALIGN_BASE;
234 ZX_VM_ALIGN_16MB = 24 << ZX_VM_ALIGN_BASE;
235 ZX_VM_ALIGN_32MB = 25 << ZX_VM_ALIGN_BASE;
236 ZX_VM_ALIGN_64MB = 26 << ZX_VM_ALIGN_BASE;
237 ZX_VM_ALIGN_128MB = 27 << ZX_VM_ALIGN_BASE;
238 ZX_VM_ALIGN_256MB = 28 << ZX_VM_ALIGN_BASE;
239 ZX_VM_ALIGN_512MB = 29 << ZX_VM_ALIGN_BASE;
240 ZX_VM_ALIGN_1GB = 30 << ZX_VM_ALIGN_BASE;
241 ZX_VM_ALIGN_2GB = 31 << ZX_VM_ALIGN_BASE;
242 ZX_VM_ALIGN_4GB = 32 << ZX_VM_ALIGN_BASE;
243]);
244
245multiconst!(u32, [
246 ZX_PROCESS_SHARED = 1 << 0;
247]);
248
249multiconst!(zx_status_t, [
252 ZX_OK = 0;
254 ZX_ERR_INTERNAL = -1;
257 ZX_ERR_NOT_SUPPORTED = -2;
259 ZX_ERR_NO_RESOURCES = -3;
261 ZX_ERR_NO_MEMORY = -4;
263 ZX_ERR_INTERRUPTED_RETRY = -6;
266 ZX_ERR_INVALID_ARGS = -10;
269 ZX_ERR_BAD_HANDLE = -11;
271 ZX_ERR_WRONG_TYPE = -12;
275 ZX_ERR_BAD_SYSCALL = -13;
277 ZX_ERR_OUT_OF_RANGE = -14;
279 ZX_ERR_BUFFER_TOO_SMALL = -15;
281 ZX_ERR_BAD_STATE = -20;
284 ZX_ERR_TIMED_OUT = -21;
286 ZX_ERR_SHOULD_WAIT = -22;
295 ZX_ERR_CANCELED = -23;
297 ZX_ERR_PEER_CLOSED = -24;
300 ZX_ERR_NOT_FOUND = -25;
302 ZX_ERR_ALREADY_EXISTS = -26;
307 ZX_ERR_ALREADY_BOUND = -27;
311 ZX_ERR_UNAVAILABLE = -28;
316 ZX_ERR_ACCESS_DENIED = -30;
318 ZX_ERR_IO = -40;
320 ZX_ERR_IO_REFUSED = -41;
325 ZX_ERR_IO_DATA_INTEGRITY = -42;
330 ZX_ERR_IO_DATA_LOSS = -43;
335 ZX_ERR_IO_NOT_PRESENT = -44;
338 ZX_ERR_IO_OVERRUN = -45;
343 ZX_ERR_IO_MISSED_DEADLINE = -46;
348 ZX_ERR_IO_INVALID = -47;
352 ZX_ERR_BAD_PATH = -50;
354 ZX_ERR_NOT_DIR = -51;
359 ZX_ERR_NOT_FILE = -52;
361 ZX_ERR_FILE_BIG = -53;
364 ZX_ERR_NO_SPACE = -54;
366 ZX_ERR_NOT_EMPTY = -55;
370 ZX_ERR_STOP = -60;
380 ZX_ERR_NEXT = -61;
389 ZX_ERR_ASYNC = -62;
405 ZX_ERR_PROTOCOL_NOT_SUPPORTED = -70;
407 ZX_ERR_ADDRESS_UNREACHABLE = -71;
409 ZX_ERR_ADDRESS_IN_USE = -72;
411 ZX_ERR_NOT_CONNECTED = -73;
413 ZX_ERR_CONNECTION_REFUSED = -74;
415 ZX_ERR_CONNECTION_RESET = -75;
417 ZX_ERR_CONNECTION_ABORTED = -76;
419]);
420multiconst!(zx_signals_t, [
423 ZX_SIGNAL_NONE = 0;
424 ZX_OBJECT_SIGNAL_ALL = 0x00ffffff;
425 ZX_USER_SIGNAL_ALL = 0xff000000;
426 ZX_OBJECT_SIGNAL_0 = 1 << 0;
427 ZX_OBJECT_SIGNAL_1 = 1 << 1;
428 ZX_OBJECT_SIGNAL_2 = 1 << 2;
429 ZX_OBJECT_SIGNAL_3 = 1 << 3;
430 ZX_OBJECT_SIGNAL_4 = 1 << 4;
431 ZX_OBJECT_SIGNAL_5 = 1 << 5;
432 ZX_OBJECT_SIGNAL_6 = 1 << 6;
433 ZX_OBJECT_SIGNAL_7 = 1 << 7;
434 ZX_OBJECT_SIGNAL_8 = 1 << 8;
435 ZX_OBJECT_SIGNAL_9 = 1 << 9;
436 ZX_OBJECT_SIGNAL_10 = 1 << 10;
437 ZX_OBJECT_SIGNAL_11 = 1 << 11;
438 ZX_OBJECT_SIGNAL_12 = 1 << 12;
439 ZX_OBJECT_SIGNAL_13 = 1 << 13;
440 ZX_OBJECT_SIGNAL_14 = 1 << 14;
441 ZX_OBJECT_SIGNAL_15 = 1 << 15;
442 ZX_OBJECT_SIGNAL_16 = 1 << 16;
443 ZX_OBJECT_SIGNAL_17 = 1 << 17;
444 ZX_OBJECT_SIGNAL_18 = 1 << 18;
445 ZX_OBJECT_SIGNAL_19 = 1 << 19;
446 ZX_OBJECT_SIGNAL_20 = 1 << 20;
447 ZX_OBJECT_SIGNAL_21 = 1 << 21;
448 ZX_OBJECT_SIGNAL_22 = 1 << 22;
449 ZX_OBJECT_HANDLE_CLOSED = 1 << 23;
450 ZX_USER_SIGNAL_0 = 1 << 24;
451 ZX_USER_SIGNAL_1 = 1 << 25;
452 ZX_USER_SIGNAL_2 = 1 << 26;
453 ZX_USER_SIGNAL_3 = 1 << 27;
454 ZX_USER_SIGNAL_4 = 1 << 28;
455 ZX_USER_SIGNAL_5 = 1 << 29;
456 ZX_USER_SIGNAL_6 = 1 << 30;
457 ZX_USER_SIGNAL_7 = 1 << 31;
458
459 ZX_OBJECT_READABLE = ZX_OBJECT_SIGNAL_0;
460 ZX_OBJECT_WRITABLE = ZX_OBJECT_SIGNAL_1;
461 ZX_OBJECT_PEER_CLOSED = ZX_OBJECT_SIGNAL_2;
462
463 ZX_SIGNAL_HANDLE_CLOSED = ZX_OBJECT_HANDLE_CLOSED;
465
466 ZX_EVENT_SIGNALED = ZX_OBJECT_SIGNAL_3;
468
469 ZX_EVENTPAIR_SIGNALED = ZX_OBJECT_SIGNAL_3;
471 ZX_EVENTPAIR_PEER_CLOSED = ZX_OBJECT_SIGNAL_2;
472
473 ZX_TASK_TERMINATED = ZX_OBJECT_SIGNAL_3;
475
476 ZX_CHANNEL_READABLE = ZX_OBJECT_SIGNAL_0;
478 ZX_CHANNEL_WRITABLE = ZX_OBJECT_SIGNAL_1;
479 ZX_CHANNEL_PEER_CLOSED = ZX_OBJECT_SIGNAL_2;
480
481 ZX_CLOCK_STARTED = ZX_OBJECT_SIGNAL_4;
483 ZX_CLOCK_UPDATED = ZX_OBJECT_SIGNAL_5;
484
485 ZX_SOCKET_READABLE = ZX_OBJECT_READABLE;
487 ZX_SOCKET_WRITABLE = ZX_OBJECT_WRITABLE;
488 ZX_SOCKET_PEER_CLOSED = ZX_OBJECT_PEER_CLOSED;
489 ZX_SOCKET_PEER_WRITE_DISABLED = ZX_OBJECT_SIGNAL_4;
490 ZX_SOCKET_WRITE_DISABLED = ZX_OBJECT_SIGNAL_5;
491 ZX_SOCKET_READ_THRESHOLD = ZX_OBJECT_SIGNAL_10;
492 ZX_SOCKET_WRITE_THRESHOLD = ZX_OBJECT_SIGNAL_11;
493
494 ZX_RESOURCE_DESTROYED = ZX_OBJECT_SIGNAL_3;
496 ZX_RESOURCE_READABLE = ZX_OBJECT_READABLE;
497 ZX_RESOURCE_WRITABLE = ZX_OBJECT_WRITABLE;
498 ZX_RESOURCE_CHILD_ADDED = ZX_OBJECT_SIGNAL_4;
499
500 ZX_FIFO_READABLE = ZX_OBJECT_READABLE;
502 ZX_FIFO_WRITABLE = ZX_OBJECT_WRITABLE;
503 ZX_FIFO_PEER_CLOSED = ZX_OBJECT_PEER_CLOSED;
504
505 ZX_IOB_PEER_CLOSED = ZX_OBJECT_PEER_CLOSED;
507 ZX_IOB_SHARED_REGION_UPDATED = ZX_OBJECT_SIGNAL_3;
508
509 ZX_JOB_TERMINATED = ZX_OBJECT_SIGNAL_3;
511 ZX_JOB_NO_JOBS = ZX_OBJECT_SIGNAL_4;
512 ZX_JOB_NO_PROCESSES = ZX_OBJECT_SIGNAL_5;
513
514 ZX_PROCESS_TERMINATED = ZX_OBJECT_SIGNAL_3;
516
517 ZX_THREAD_TERMINATED = ZX_OBJECT_SIGNAL_3;
519 ZX_THREAD_RUNNING = ZX_OBJECT_SIGNAL_4;
520 ZX_THREAD_SUSPENDED = ZX_OBJECT_SIGNAL_5;
521
522 ZX_LOG_READABLE = ZX_OBJECT_READABLE;
524 ZX_LOG_WRITABLE = ZX_OBJECT_WRITABLE;
525
526 ZX_TIMER_SIGNALED = ZX_OBJECT_SIGNAL_3;
528
529 ZX_VMO_ZERO_CHILDREN = ZX_OBJECT_SIGNAL_3;
531
532 ZX_COUNTER_SIGNALED = ZX_OBJECT_SIGNAL_3;
534 ZX_COUNTER_POSITIVE = ZX_OBJECT_SIGNAL_4;
535 ZX_COUNTER_NON_POSITIVE = ZX_OBJECT_SIGNAL_5;
536]);
537
538multiconst!(zx_obj_type_t, [
539 ZX_OBJ_TYPE_NONE = 0;
540 ZX_OBJ_TYPE_PROCESS = 1;
541 ZX_OBJ_TYPE_THREAD = 2;
542 ZX_OBJ_TYPE_VMO = 3;
543 ZX_OBJ_TYPE_CHANNEL = 4;
544 ZX_OBJ_TYPE_EVENT = 5;
545 ZX_OBJ_TYPE_PORT = 6;
546 ZX_OBJ_TYPE_INTERRUPT = 9;
547 ZX_OBJ_TYPE_PCI_DEVICE = 11;
548 ZX_OBJ_TYPE_DEBUGLOG = 12;
549 ZX_OBJ_TYPE_SOCKET = 14;
550 ZX_OBJ_TYPE_RESOURCE = 15;
551 ZX_OBJ_TYPE_EVENTPAIR = 16;
552 ZX_OBJ_TYPE_JOB = 17;
553 ZX_OBJ_TYPE_VMAR = 18;
554 ZX_OBJ_TYPE_FIFO = 19;
555 ZX_OBJ_TYPE_GUEST = 20;
556 ZX_OBJ_TYPE_VCPU = 21;
557 ZX_OBJ_TYPE_TIMER = 22;
558 ZX_OBJ_TYPE_IOMMU = 23;
559 ZX_OBJ_TYPE_BTI = 24;
560 ZX_OBJ_TYPE_PROFILE = 25;
561 ZX_OBJ_TYPE_PMT = 26;
562 ZX_OBJ_TYPE_SUSPEND_TOKEN = 27;
563 ZX_OBJ_TYPE_PAGER = 28;
564 ZX_OBJ_TYPE_EXCEPTION = 29;
565 ZX_OBJ_TYPE_CLOCK = 30;
566 ZX_OBJ_TYPE_STREAM = 31;
567 ZX_OBJ_TYPE_MSI = 32;
568 ZX_OBJ_TYPE_IOB = 33;
569 ZX_OBJ_TYPE_COUNTER = 34;
570]);
571
572pub const ZX_OBJ_TYPE_UPPER_BOUND: usize = 64;
577
578multiconst!(u32, [
580 ZX_PROP_NAME = 3;
582
583 #[cfg(target_arch = "x86_64")]
585 ZX_PROP_REGISTER_GS = 2;
586 #[cfg(target_arch = "x86_64")]
587 ZX_PROP_REGISTER_FS = 4;
588
589 ZX_PROP_PROCESS_DEBUG_ADDR = 5;
591
592 ZX_PROP_PROCESS_VDSO_BASE_ADDRESS = 6;
594
595 ZX_PROP_PROCESS_BREAK_ON_LOAD = 7;
598
599 ZX_PROP_SOCKET_RX_THRESHOLD = 12;
601 ZX_PROP_SOCKET_TX_THRESHOLD = 13;
602
603 ZX_PROP_CHANNEL_TX_MSG_MAX = 14;
606
607 ZX_PROP_JOB_KILL_ON_OOM = 15;
609
610 ZX_PROP_EXCEPTION_STATE = 16;
612
613 ZX_PROP_VMO_CONTENT_SIZE = 17;
615
616 ZX_PROP_EXCEPTION_STRATEGY = 18;
618
619 ZX_PROP_STREAM_MODE_APPEND = 19;
621]);
622
623pub type zx_thread_state_single_step_t = u32;
626
627multiconst!(zx_thread_state_topic_t, [
629 ZX_THREAD_STATE_GENERAL_REGS = 0;
630 ZX_THREAD_STATE_FP_REGS = 1;
631 ZX_THREAD_STATE_VECTOR_REGS = 2;
632 ZX_THREAD_STATE_DEBUG_REGS = 4;
634 ZX_THREAD_STATE_SINGLE_STEP = 5;
635]);
636
637multiconst!(zx_vcpu_state_topic_t, [
639 ZX_VCPU_STATE = 0;
640 ZX_VCPU_IO = 1;
641]);
642
643multiconst!(u32, [
645 ZX_FEATURE_KIND_CPU = 0;
646 ZX_FEATURE_KIND_HW_BREAKPOINT_COUNT = 1;
647 ZX_FEATURE_KIND_HW_WATCHPOINT_COUNT = 2;
648 ZX_FEATURE_KIND_ADDRESS_TAGGING = 3;
649 ZX_FEATURE_KIND_VM = 4;
650]);
651
652multiconst!(u32, [
654 ZX_HAS_CPU_FEATURES = 1 << 0;
655
656 ZX_VM_FEATURE_CAN_MAP_XOM = 1 << 0;
657
658 ZX_ARM64_FEATURE_ISA_FP = 1 << 1;
659 ZX_ARM64_FEATURE_ISA_ASIMD = 1 << 2;
660 ZX_ARM64_FEATURE_ISA_AES = 1 << 3;
661 ZX_ARM64_FEATURE_ISA_PMULL = 1 << 4;
662 ZX_ARM64_FEATURE_ISA_SHA1 = 1 << 5;
663 ZX_ARM64_FEATURE_ISA_SHA256 = 1 << 6;
664 ZX_ARM64_FEATURE_ISA_CRC32 = 1 << 7;
665 ZX_ARM64_FEATURE_ISA_ATOMICS = 1 << 8;
666 ZX_ARM64_FEATURE_ISA_RDM = 1 << 9;
667 ZX_ARM64_FEATURE_ISA_SHA3 = 1 << 10;
668 ZX_ARM64_FEATURE_ISA_SM3 = 1 << 11;
669 ZX_ARM64_FEATURE_ISA_SM4 = 1 << 12;
670 ZX_ARM64_FEATURE_ISA_DP = 1 << 13;
671 ZX_ARM64_FEATURE_ISA_DPB = 1 << 14;
672 ZX_ARM64_FEATURE_ISA_FHM = 1 << 15;
673 ZX_ARM64_FEATURE_ISA_TS = 1 << 16;
674 ZX_ARM64_FEATURE_ISA_RNDR = 1 << 17;
675 ZX_ARM64_FEATURE_ISA_SHA512 = 1 << 18;
676 ZX_ARM64_FEATURE_ISA_I8MM = 1 << 19;
677 ZX_ARM64_FEATURE_ISA_SVE = 1 << 20;
678 ZX_ARM64_FEATURE_ISA_ARM32 = 1 << 21;
679 ZX_ARM64_FEATURE_ISA_SHA2 = 1 << 6;
680 ZX_ARM64_FEATURE_ADDRESS_TAGGING_TBI = 1 << 0;
681]);
682
683multiconst!(zx_rsrc_kind_t, [
685 ZX_RSRC_KIND_MMIO = 0;
686 ZX_RSRC_KIND_IRQ = 1;
687 ZX_RSRC_KIND_IOPORT = 2;
688 ZX_RSRC_KIND_ROOT = 3;
689 ZX_RSRC_KIND_SMC = 4;
690 ZX_RSRC_KIND_SYSTEM = 5;
691]);
692
693multiconst!(zx_rsrc_system_base_t, [
695 ZX_RSRC_SYSTEM_HYPERVISOR_BASE = 0;
696 ZX_RSRC_SYSTEM_VMEX_BASE = 1;
697 ZX_RSRC_SYSTEM_DEBUG_BASE = 2;
698 ZX_RSRC_SYSTEM_INFO_BASE = 3;
699 ZX_RSRC_SYSTEM_CPU_BASE = 4;
700 ZX_RSRC_SYSTEM_POWER_BASE = 5;
701 ZX_RSRC_SYSTEM_MEXEC_BASE = 6;
702 ZX_RSRC_SYSTEM_ENERGY_INFO_BASE = 7;
703 ZX_RSRC_SYSTEM_IOMMU_BASE = 8;
704 ZX_RSRC_SYSTEM_FRAMEBUFFER_BASE = 9;
705 ZX_RSRC_SYSTEM_PROFILE_BASE = 10;
706 ZX_RSRC_SYSTEM_MSI_BASE = 11;
707 ZX_RSRC_SYSTEM_DEBUGLOG_BASE = 12;
708 ZX_RSRC_SYSTEM_STALL_BASE = 13;
709 ZX_RSRC_SYSTEM_TRACING_BASE = 14;
710 ZX_RSRC_SYSTEM_SAMPLING_BASE = 15;
712]);
713
714multiconst!(zx_clock_t, [
716 ZX_CLOCK_MONOTONIC = 0;
717 ZX_CLOCK_BOOT = 1;
718]);
719
720multiconst!(u64, [
722 ZX_CLOCK_OPT_MONOTONIC = 1 << 0;
723 ZX_CLOCK_OPT_CONTINUOUS = 1 << 1;
724 ZX_CLOCK_OPT_AUTO_START = 1 << 2;
725 ZX_CLOCK_OPT_BOOT = 1 << 3;
726 ZX_CLOCK_OPT_MAPPABLE = 1 << 4;
727
728 ZX_CLOCK_UPDATE_OPTION_VALUE_VALID = 1 << 0;
730 ZX_CLOCK_UPDATE_OPTION_RATE_ADJUST_VALID = 1 << 1;
731 ZX_CLOCK_UPDATE_OPTION_ERROR_BOUND_VALID = 1 << 2;
732
733 ZX_CLOCK_UPDATE_OPTION_REFERENCE_VALUE_VALID = 1 << 3;
735 ZX_CLOCK_UPDATE_OPTION_SYNTHETIC_VALUE_VALID = ZX_CLOCK_UPDATE_OPTION_VALUE_VALID;
736
737 ZX_CLOCK_ARGS_VERSION_1 = 1 << 58;
738 ZX_CLOCK_ARGS_VERSION_2 = 2 << 58;
739]);
740
741multiconst!(u32, [
743 ZX_EXCEPTION_CHANNEL_DEBUGGER = 1 << 0;
744 ZX_EXCEPTION_TARGET_JOB_DEBUGGER = 1 << 0;
745
746 ZX_EXCEPTION_CHANNEL_TYPE_NONE = 0;
748 ZX_EXCEPTION_CHANNEL_TYPE_DEBUGGER = 1;
749 ZX_EXCEPTION_CHANNEL_TYPE_THREAD = 2;
750 ZX_EXCEPTION_CHANNEL_TYPE_PROCESS = 3;
751 ZX_EXCEPTION_CHANNEL_TYPE_JOB = 4;
752 ZX_EXCEPTION_CHANNEL_TYPE_JOB_DEBUGGER = 5;
753]);
754
755#[repr(transparent)]
763#[derive(Copy, Clone, Eq, Default)]
764#[cfg_attr(feature = "zerocopy", derive(FromBytes, Immutable, IntoBytes))]
765pub struct PadByte(u8);
766
767impl PartialEq for PadByte {
768 fn eq(&self, _other: &Self) -> bool {
769 true
770 }
771}
772
773impl Hash for PadByte {
774 fn hash<H: Hasher>(&self, state: &mut H) {
775 state.write_u8(0);
776 }
777}
778
779impl Debug for PadByte {
780 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
781 f.write_str("-")
782 }
783}
784
785#[repr(C)]
786#[derive(Debug, Clone, Eq, PartialEq)]
787pub struct zx_clock_create_args_v1_t {
788 pub backstop_time: zx_time_t,
789}
790
791#[repr(C)]
792#[derive(Debug, Default, Clone, Eq, PartialEq)]
793pub struct zx_clock_rate_t {
794 pub synthetic_ticks: u32,
795 pub reference_ticks: u32,
796}
797
798#[repr(C)]
799#[derive(Debug, Default, Clone, Eq, PartialEq)]
800pub struct zx_clock_transformation_t {
801 pub reference_offset: i64,
802 pub synthetic_offset: i64,
803 pub rate: zx_clock_rate_t,
804}
805
806#[repr(C)]
807#[derive(Debug, Default, Clone, Eq, PartialEq)]
808pub struct zx_clock_details_v1_t {
809 pub options: u64,
810 pub backstop_time: zx_time_t,
811 pub reference_ticks_to_synthetic: zx_clock_transformation_t,
812 pub reference_to_synthetic: zx_clock_transformation_t,
813 pub error_bound: u64,
814 pub query_ticks: zx_ticks_t,
815 pub last_value_update_ticks: zx_ticks_t,
816 pub last_rate_adjust_update_ticks: zx_ticks_t,
817 pub last_error_bounds_update_ticks: zx_ticks_t,
818 pub generation_counter: u32,
819 padding1: [PadByte; 4],
820}
821
822#[repr(C)]
823#[derive(Debug, Clone, Eq, PartialEq)]
824pub struct zx_clock_update_args_v1_t {
825 pub rate_adjust: i32,
826 padding1: [PadByte; 4],
827 pub value: i64,
828 pub error_bound: u64,
829}
830
831#[repr(C)]
832#[derive(Debug, Default, Clone, Eq, PartialEq)]
833pub struct zx_clock_update_args_v2_t {
834 pub rate_adjust: i32,
835 padding1: [PadByte; 4],
836 pub synthetic_value: i64,
837 pub reference_value: i64,
838 pub error_bound: u64,
839}
840
841multiconst!(zx_stream_seek_origin_t, [
842 ZX_STREAM_SEEK_ORIGIN_START = 0;
843 ZX_STREAM_SEEK_ORIGIN_CURRENT = 1;
844 ZX_STREAM_SEEK_ORIGIN_END = 2;
845]);
846
847pub const ZX_STREAM_MODE_READ: u32 = 1 << 0;
849pub const ZX_STREAM_MODE_WRITE: u32 = 1 << 1;
850pub const ZX_STREAM_MODE_APPEND: u32 = 1 << 2;
851
852pub const ZX_STREAM_APPEND: u32 = 1 << 0;
853
854pub const ZX_CPRNG_ADD_ENTROPY_MAX_LEN: usize = 256;
855
856pub const ZX_SOCKET_STREAM: u32 = 0;
858pub const ZX_SOCKET_DATAGRAM: u32 = 1 << 0;
859pub const ZX_SOCKET_DISPOSITION_WRITE_DISABLED: u32 = 1 << 0;
860pub const ZX_SOCKET_DISPOSITION_WRITE_ENABLED: u32 = 1 << 1;
861
862pub const ZX_VMO_CHILD_SNAPSHOT: u32 = 1 << 0;
864pub const ZX_VMO_CHILD_SNAPSHOT_AT_LEAST_ON_WRITE: u32 = 1 << 4;
865pub const ZX_VMO_CHILD_RESIZABLE: u32 = 1 << 2;
866pub const ZX_VMO_CHILD_SLICE: u32 = 1 << 3;
867pub const ZX_VMO_CHILD_NO_WRITE: u32 = 1 << 5;
868pub const ZX_VMO_CHILD_REFERENCE: u32 = 1 << 6;
869pub const ZX_VMO_CHILD_SNAPSHOT_MODIFIED: u32 = 1 << 7;
870
871pub const ZX_CHANNEL_MAX_MSG_HANDLES: u32 = 64;
873pub const ZX_CHANNEL_MAX_MSG_BYTES: u32 = 65536;
874pub const ZX_CHANNEL_MAX_MSG_IOVEC: u32 = 8192;
875
876pub const ZX_FIFO_MAX_SIZE_BYTES: u32 = 4096;
878
879#[cfg(target_arch = "x86_64")]
881pub const ZX_MIN_PAGE_SHIFT: u32 = 12;
882#[cfg(target_arch = "x86_64")]
883pub const ZX_MAX_PAGE_SHIFT: u32 = 21;
884
885#[cfg(target_arch = "aarch64")]
886pub const ZX_MIN_PAGE_SHIFT: u32 = 12;
887#[cfg(target_arch = "aarch64")]
888pub const ZX_MAX_PAGE_SHIFT: u32 = 16;
889
890#[cfg(target_arch = "riscv64")]
891pub const ZX_MIN_PAGE_SHIFT: u32 = 12;
892#[cfg(target_arch = "riscv64")]
893pub const ZX_MAX_PAGE_SHIFT: u32 = 21;
894
895pub const ZX_TASK_RETCODE_SYSCALL_KILL: i64 = -1024;
897pub const ZX_TASK_RETCODE_OOM_KILL: i64 = -1025;
898pub const ZX_TASK_RETCODE_POLICY_KILL: i64 = -1026;
899pub const ZX_TASK_RETCODE_VDSO_KILL: i64 = -1027;
900pub const ZX_TASK_RETCODE_EXCEPTION_KILL: i64 = -1028;
901
902pub const ZX_RSRC_FLAG_EXCLUSIVE: zx_rsrc_flags_t = 0x00010000;
904
905pub const ZX_CPU_PERF_SCALE: u32 = 1;
907pub const ZX_CPU_DEFAULT_PERF_SCALE: u32 = 2;
908pub const ZX_CPU_PERF_LIMIT: u32 = 3;
909
910pub const ZX_CPU_PERF_LIMIT_TYPE_RATE: u32 = 0;
912pub const ZX_CPU_PERF_LIMIT_TYPE_POWER: u32 = 1;
913
914pub const ZX_CACHE_POLICY_CACHED: u32 = 0;
916pub const ZX_CACHE_POLICY_UNCACHED: u32 = 1;
917pub const ZX_CACHE_POLICY_UNCACHED_DEVICE: u32 = 2;
918pub const ZX_CACHE_POLICY_WRITE_COMBINING: u32 = 3;
919
920multiconst!(u32, [
922 ZX_CACHE_FLUSH_INSN = 1 << 0;
923 ZX_CACHE_FLUSH_DATA = 1 << 1;
924 ZX_CACHE_FLUSH_INVALIDATE = 1 << 2;
925]);
926
927#[repr(C)]
928#[derive(Debug, Copy, Clone, Eq, PartialEq)]
929pub struct zx_wait_item_t {
930 pub handle: zx_handle_t,
931 pub waitfor: zx_signals_t,
932 pub pending: zx_signals_t,
933}
934
935#[repr(C)]
936#[derive(Debug, Copy, Clone, Eq, PartialEq)]
937pub struct zx_waitset_result_t {
938 pub cookie: u64,
939 pub status: zx_status_t,
940 pub observed: zx_signals_t,
941}
942
943#[repr(C)]
944#[derive(Debug, Copy, Clone, Eq, PartialEq)]
945pub struct zx_handle_info_t {
946 pub handle: zx_handle_t,
947 pub ty: zx_obj_type_t,
948 pub rights: zx_rights_t,
949 pub unused: u32,
950}
951
952pub const ZX_CHANNEL_READ_MAY_DISCARD: u32 = 1;
953pub const ZX_CHANNEL_WRITE_USE_IOVEC: u32 = 2;
954
955#[repr(C)]
956#[derive(Debug, Copy, Clone, Eq, PartialEq)]
957pub struct zx_channel_call_args_t {
958 pub wr_bytes: *const u8,
959 pub wr_handles: *const zx_handle_t,
960 pub rd_bytes: *mut u8,
961 pub rd_handles: *mut zx_handle_t,
962 pub wr_num_bytes: u32,
963 pub wr_num_handles: u32,
964 pub rd_num_bytes: u32,
965 pub rd_num_handles: u32,
966}
967
968#[repr(C)]
969#[derive(Debug, Copy, Clone, Eq, PartialEq)]
970pub struct zx_channel_call_etc_args_t {
971 pub wr_bytes: *const u8,
972 pub wr_handles: *mut zx_handle_disposition_t,
973 pub rd_bytes: *mut u8,
974 pub rd_handles: *mut zx_handle_info_t,
975 pub wr_num_bytes: u32,
976 pub wr_num_handles: u32,
977 pub rd_num_bytes: u32,
978 pub rd_num_handles: u32,
979}
980
981#[repr(C)]
982#[derive(Debug, Copy, Clone, Eq, PartialEq)]
983pub struct zx_channel_iovec_t {
984 pub buffer: *const u8,
985 pub capacity: u32,
986 padding1: [PadByte; 4],
987}
988
989impl Default for zx_channel_iovec_t {
990 fn default() -> Self {
991 Self {
992 buffer: std::ptr::null(),
993 capacity: Default::default(),
994 padding1: Default::default(),
995 }
996 }
997}
998
999#[repr(C)]
1000#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1001pub struct zx_handle_disposition_t {
1002 pub operation: zx_handle_op_t,
1003 pub handle: zx_handle_t,
1004 pub type_: zx_obj_type_t,
1005 pub rights: zx_rights_t,
1006 pub result: zx_status_t,
1007}
1008
1009#[repr(C)]
1010#[derive(Debug, Copy, Clone)]
1011pub struct zx_iovec_t {
1012 pub buffer: *const u8,
1013 pub capacity: usize,
1014}
1015
1016pub type zx_pci_irq_swizzle_lut_t = [[[u32; 4]; 8]; 32];
1017
1018#[repr(C)]
1019#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1020pub struct zx_pci_init_arg_t {
1021 pub dev_pin_to_global_irq: zx_pci_irq_swizzle_lut_t,
1022 pub num_irqs: u32,
1023 pub irqs: [zx_irq_t; 32],
1024 pub ecam_window_count: u32,
1025 pub ecam_windows: [zx_ecam_window_t; 1],
1028}
1029
1030#[repr(C)]
1031#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1032pub struct zx_irq_t {
1033 pub global_irq: u32,
1034 pub level_triggered: bool,
1035 pub active_high: bool,
1036}
1037
1038#[repr(C)]
1039#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1040pub struct zx_ecam_window_t {
1041 pub base: u64,
1042 pub size: usize,
1043 pub bus_start: u8,
1044 pub bus_end: u8,
1045}
1046
1047#[repr(C)]
1048#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1049pub struct zx_pcie_device_info_t {
1050 pub vendor_id: u16,
1051 pub device_id: u16,
1052 pub base_class: u8,
1053 pub sub_class: u8,
1054 pub program_interface: u8,
1055 pub revision_id: u8,
1056 pub bus_id: u8,
1057 pub dev_id: u8,
1058 pub func_id: u8,
1059}
1060
1061#[repr(C)]
1062#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1063pub struct zx_pci_resource_t {
1064 pub type_: u32,
1065 pub size: usize,
1066 pub pio_addr: usize,
1068}
1069
1070pub type zx_rrec_t = [u8; 64];
1072
1073#[repr(u32)]
1075#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1076pub enum zx_packet_type_t {
1077 ZX_PKT_TYPE_USER = 0,
1078 ZX_PKT_TYPE_SIGNAL_ONE = 1,
1079 ZX_PKT_TYPE_GUEST_BELL = 3,
1080 ZX_PKT_TYPE_GUEST_MEM = 4,
1081 ZX_PKT_TYPE_GUEST_IO = 5,
1082 ZX_PKT_TYPE_GUEST_VCPU = 6,
1083 ZX_PKT_TYPE_INTERRUPT = 7,
1084 ZX_PKT_TYPE_PAGE_REQUEST = 9,
1085 ZX_PKT_TYPE_PROCESSOR_POWER_LEVEL_TRANSITION_REQUEST = 10,
1086 #[doc(hidden)]
1087 __Nonexhaustive,
1088}
1089
1090impl Default for zx_packet_type_t {
1091 fn default() -> Self {
1092 zx_packet_type_t::ZX_PKT_TYPE_USER
1093 }
1094}
1095
1096#[repr(u32)]
1097#[derive(Debug, Copy, Clone, Default, Eq, PartialEq)]
1098pub enum zx_packet_guest_vcpu_type_t {
1099 #[default]
1100 ZX_PKT_GUEST_VCPU_INTERRUPT = 0,
1101 ZX_PKT_GUEST_VCPU_STARTUP = 1,
1102 #[doc(hidden)]
1103 __Nonexhaustive,
1104}
1105
1106#[repr(C)]
1107#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1108pub struct zx_packet_signal_t {
1109 pub trigger: zx_signals_t,
1110 pub observed: zx_signals_t,
1111 pub count: u64,
1112 pub timestamp: zx_time_t,
1113}
1114
1115pub const ZX_WAIT_ASYNC_TIMESTAMP: u32 = 1;
1116pub const ZX_WAIT_ASYNC_EDGE: u32 = 2;
1117pub const ZX_WAIT_ASYNC_BOOT_TIMESTAMP: u32 = 4;
1118
1119pub type zx_packet_user_t = [u8; 32];
1121
1122#[repr(C)]
1123#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1124pub struct zx_port_packet_t {
1125 pub key: u64,
1126 pub packet_type: zx_packet_type_t,
1127 pub status: i32,
1128 pub union: [u8; 32],
1129}
1130
1131#[repr(C)]
1132#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1133pub struct zx_packet_guest_bell_t {
1134 pub addr: zx_gpaddr_t,
1135}
1136
1137#[repr(C)]
1138#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1139pub struct zx_packet_guest_io_t {
1140 pub port: u16,
1141 pub access_size: u8,
1142 pub input: bool,
1143 pub data: [u8; 4],
1144}
1145
1146#[repr(C)]
1147#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1148#[cfg_attr(feature = "zerocopy", derive(FromBytes, Immutable))]
1149pub struct zx_packet_guest_vcpu_interrupt_t {
1150 pub mask: u64,
1151 pub vector: u8,
1152 padding1: [PadByte; 7],
1153}
1154
1155#[repr(C)]
1156#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1157#[cfg_attr(feature = "zerocopy", derive(FromBytes, Immutable))]
1158pub struct zx_packet_guest_vcpu_startup_t {
1159 pub id: u64,
1160 pub entry: zx_gpaddr_t,
1161}
1162
1163#[repr(C)]
1164#[derive(Copy, Clone)]
1165#[cfg_attr(feature = "zerocopy", derive(FromBytes, Immutable))]
1166pub union zx_packet_guest_vcpu_union_t {
1167 pub interrupt: zx_packet_guest_vcpu_interrupt_t,
1168 pub startup: zx_packet_guest_vcpu_startup_t,
1169}
1170
1171#[cfg(feature = "zerocopy")]
1172impl Default for zx_packet_guest_vcpu_union_t {
1173 fn default() -> Self {
1174 Self::new_zeroed()
1175 }
1176}
1177
1178#[repr(C)]
1179#[derive(Copy, Clone, Default)]
1180pub struct zx_packet_guest_vcpu_t {
1181 pub r#type: zx_packet_guest_vcpu_type_t,
1182 padding1: [PadByte; 4],
1183 pub union: zx_packet_guest_vcpu_union_t,
1184 padding2: [PadByte; 8],
1185}
1186
1187impl PartialEq for zx_packet_guest_vcpu_t {
1188 fn eq(&self, other: &Self) -> bool {
1189 if self.r#type != other.r#type {
1190 return false;
1191 }
1192 match self.r#type {
1193 zx_packet_guest_vcpu_type_t::ZX_PKT_GUEST_VCPU_INTERRUPT => unsafe {
1194 self.union.interrupt == other.union.interrupt
1195 },
1196 zx_packet_guest_vcpu_type_t::ZX_PKT_GUEST_VCPU_STARTUP => unsafe {
1197 self.union.startup == other.union.startup
1198 },
1199 _ => false,
1201 }
1202 }
1203}
1204
1205impl Eq for zx_packet_guest_vcpu_t {}
1206
1207impl Debug for zx_packet_guest_vcpu_t {
1208 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1209 match self.r#type {
1210 zx_packet_guest_vcpu_type_t::ZX_PKT_GUEST_VCPU_INTERRUPT => {
1211 write!(f, "type: {:?} union: {:?}", self.r#type, unsafe { self.union.interrupt })
1212 }
1213 zx_packet_guest_vcpu_type_t::ZX_PKT_GUEST_VCPU_STARTUP => {
1214 write!(f, "type: {:?} union: {:?}", self.r#type, unsafe { self.union.startup })
1215 }
1216 _ => panic!("unexpected VCPU packet type"),
1217 }
1218 }
1219}
1220
1221#[repr(C)]
1222#[derive(Debug, Copy, Clone, Default, Eq, PartialEq)]
1223pub struct zx_packet_page_request_t {
1224 pub command: zx_page_request_command_t,
1225 pub flags: u16,
1226 padding1: [PadByte; 4],
1227 pub offset: u64,
1228 pub length: u64,
1229 padding2: [PadByte; 8],
1230}
1231
1232#[repr(u16)]
1233#[derive(Debug, Copy, Clone, Default, Eq, PartialEq)]
1234pub enum zx_page_request_command_t {
1235 #[default]
1236 ZX_PAGER_VMO_READ = 0x0000,
1237 ZX_PAGER_VMO_COMPLETE = 0x0001,
1238 ZX_PAGER_VMO_DIRTY = 0x0002,
1239 #[doc(hidden)]
1240 __Nonexhaustive,
1241}
1242
1243multiconst!(u32, [
1244 ZX_PAGER_OP_FAIL = 1;
1245 ZX_PAGER_OP_DIRTY = 2;
1246 ZX_PAGER_OP_WRITEBACK_BEGIN = 3;
1247 ZX_PAGER_OP_WRITEBACK_END = 4;
1248]);
1249
1250pub type zx_excp_type_t = u32;
1251
1252multiconst!(zx_excp_type_t, [
1253 ZX_EXCP_GENERAL = 0x008;
1254 ZX_EXCP_FATAL_PAGE_FAULT = 0x108;
1255 ZX_EXCP_UNDEFINED_INSTRUCTION = 0x208;
1256 ZX_EXCP_SW_BREAKPOINT = 0x308;
1257 ZX_EXCP_HW_BREAKPOINT = 0x408;
1258 ZX_EXCP_UNALIGNED_ACCESS = 0x508;
1259
1260 ZX_EXCP_SYNTH = 0x8000;
1261
1262 ZX_EXCP_THREAD_STARTING = 0x008 | ZX_EXCP_SYNTH;
1263 ZX_EXCP_THREAD_EXITING = 0x108 | ZX_EXCP_SYNTH;
1264 ZX_EXCP_POLICY_ERROR = 0x208 | ZX_EXCP_SYNTH;
1265 ZX_EXCP_PROCESS_STARTING = 0x308 | ZX_EXCP_SYNTH;
1266 ZX_EXCP_USER = 0x309 | ZX_EXCP_SYNTH;
1267]);
1268
1269multiconst!(u32, [
1270 ZX_EXCP_USER_CODE_PROCESS_NAME_CHANGED = 0x0001;
1271
1272 ZX_EXCP_USER_CODE_USER0 = 0xF000;
1273 ZX_EXCP_USER_CODE_USER1 = 0xF001;
1274 ZX_EXCP_USER_CODE_USER2 = 0xF002;
1275]);
1276
1277#[repr(C)]
1278#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1279#[cfg_attr(feature = "zerocopy", derive(FromBytes, Immutable, IntoBytes))]
1280pub struct zx_exception_info_t {
1281 pub pid: zx_koid_t,
1282 pub tid: zx_koid_t,
1283 pub type_: zx_excp_type_t,
1284 padding1: [PadByte; 4],
1285}
1286
1287#[repr(C)]
1288#[derive(Default, Copy, Clone, Eq, PartialEq, KnownLayout, FromBytes, Immutable)]
1289pub struct zx_x86_64_exc_data_t {
1290 pub vector: u64,
1291 pub err_code: u64,
1292 pub cr2: u64,
1293}
1294
1295impl Debug for zx_x86_64_exc_data_t {
1296 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1297 write!(f, "vector 0x{:x} err_code {} cr2 0x{:x}", self.vector, self.err_code, self.cr2)
1298 }
1299}
1300
1301#[repr(C)]
1302#[derive(Default, Copy, Clone, Eq, PartialEq, FromBytes, Immutable)]
1303pub struct zx_arm64_exc_data_t {
1304 pub esr: u32,
1305 padding1: [PadByte; 4],
1306 pub far: u64,
1307 padding2: [PadByte; 8],
1308}
1309
1310impl Debug for zx_arm64_exc_data_t {
1311 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1312 write!(f, "esr 0x{:x} far 0x{:x}", self.esr, self.far)
1313 }
1314}
1315
1316#[repr(C)]
1317#[derive(Default, Copy, Clone, Eq, PartialEq, FromBytes, Immutable)]
1318pub struct zx_riscv64_exc_data_t {
1319 pub cause: u64,
1320 pub tval: u64,
1321 padding1: [PadByte; 8],
1322}
1323
1324impl Debug for zx_riscv64_exc_data_t {
1325 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1326 write!(f, "cause {} tval {}", self.cause, self.tval)
1327 }
1328}
1329
1330#[repr(C)]
1331#[derive(Copy, Clone, KnownLayout, FromBytes, Immutable)]
1332pub union zx_exception_header_arch_t {
1333 pub x86_64: zx_x86_64_exc_data_t,
1334 pub arm_64: zx_arm64_exc_data_t,
1335 pub riscv_64: zx_riscv64_exc_data_t,
1336}
1337
1338impl Debug for zx_exception_header_arch_t {
1339 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1340 write!(f, "zx_exception_header_arch_t ")?;
1341 #[cfg(target_arch = "x86_64")]
1342 {
1343 let x86_64 = unsafe { self.x86_64 };
1348 write!(f, "{x86_64:?}")
1349 }
1350 #[cfg(target_arch = "aarch64")]
1351 {
1352 let arm_64 = unsafe { self.arm_64 };
1357 write!(f, "{arm_64:?}")
1358 }
1359 #[cfg(target_arch = "riscv64")]
1360 {
1361 let riscv_64 = unsafe { self.riscv_64 };
1366 write!(f, "{riscv_64:?}")
1367 }
1368 }
1369}
1370
1371#[repr(C)]
1372#[derive(Debug, Copy, Clone, Eq, PartialEq, KnownLayout, FromBytes, Immutable)]
1373pub struct zx_exception_header_t {
1374 pub size: u32,
1375 pub type_: zx_excp_type_t,
1376}
1377
1378pub type zx_excp_policy_code_t = u32;
1379
1380multiconst!(zx_excp_policy_code_t, [
1381 ZX_EXCP_POLICY_CODE_BAD_HANDLE = 0;
1382 ZX_EXCP_POLICY_CODE_WRONG_OBJECT = 1;
1383 ZX_EXCP_POLICY_CODE_VMAR_WX = 2;
1384 ZX_EXCP_POLICY_CODE_NEW_ANY = 3;
1385 ZX_EXCP_POLICY_CODE_NEW_VMO = 4;
1386 ZX_EXCP_POLICY_CODE_NEW_CHANNEL = 5;
1387 ZX_EXCP_POLICY_CODE_NEW_EVENT = 6;
1388 ZX_EXCP_POLICY_CODE_NEW_EVENTPAIR = 7;
1389 ZX_EXCP_POLICY_CODE_NEW_PORT = 8;
1390 ZX_EXCP_POLICY_CODE_NEW_SOCKET = 9;
1391 ZX_EXCP_POLICY_CODE_NEW_FIFO = 10;
1392 ZX_EXCP_POLICY_CODE_NEW_TIMER = 11;
1393 ZX_EXCP_POLICY_CODE_NEW_PROCESS = 12;
1394 ZX_EXCP_POLICY_CODE_NEW_PROFILE = 13;
1395 ZX_EXCP_POLICY_CODE_NEW_PAGER = 14;
1396 ZX_EXCP_POLICY_CODE_AMBIENT_MARK_VMO_EXEC = 15;
1397 ZX_EXCP_POLICY_CODE_CHANNEL_FULL_WRITE = 16;
1398 ZX_EXCP_POLICY_CODE_PORT_TOO_MANY_PACKETS = 17;
1399 ZX_EXCP_POLICY_CODE_BAD_SYSCALL = 18;
1400 ZX_EXCP_POLICY_CODE_PORT_TOO_MANY_OBSERVERS = 19;
1401 ZX_EXCP_POLICY_CODE_HANDLE_LEAK = 20;
1402 ZX_EXCP_POLICY_CODE_NEW_IOB = 21;
1403]);
1404
1405#[repr(C)]
1406#[derive(Debug, Copy, Clone, KnownLayout, FromBytes, Immutable)]
1407pub struct zx_exception_context_t {
1408 pub arch: zx_exception_header_arch_t,
1409 pub synth_code: zx_excp_policy_code_t,
1410 pub synth_data: u32,
1411}
1412
1413#[repr(C)]
1414#[derive(Debug, Copy, Clone, KnownLayout, FromBytes, Immutable)]
1415pub struct zx_exception_report_t {
1416 pub header: zx_exception_header_t,
1417 pub context: zx_exception_context_t,
1418}
1419
1420pub type zx_exception_state_t = u32;
1421
1422multiconst!(zx_exception_state_t, [
1423 ZX_EXCEPTION_STATE_TRY_NEXT = 0;
1424 ZX_EXCEPTION_STATE_HANDLED = 1;
1425 ZX_EXCEPTION_STATE_THREAD_EXIT = 2;
1426]);
1427
1428pub type zx_exception_strategy_t = u32;
1429
1430multiconst!(zx_exception_state_t, [
1431 ZX_EXCEPTION_STRATEGY_FIRST_CHANCE = 0;
1432 ZX_EXCEPTION_STRATEGY_SECOND_CHANCE = 1;
1433]);
1434
1435#[cfg(target_arch = "x86_64")]
1436#[repr(C)]
1437#[derive(Default, Copy, Clone, Eq, PartialEq, KnownLayout, FromBytes, Immutable)]
1438pub struct zx_thread_state_general_regs_t {
1439 pub rax: u64,
1440 pub rbx: u64,
1441 pub rcx: u64,
1442 pub rdx: u64,
1443 pub rsi: u64,
1444 pub rdi: u64,
1445 pub rbp: u64,
1446 pub rsp: u64,
1447 pub r8: u64,
1448 pub r9: u64,
1449 pub r10: u64,
1450 pub r11: u64,
1451 pub r12: u64,
1452 pub r13: u64,
1453 pub r14: u64,
1454 pub r15: u64,
1455 pub rip: u64,
1456 pub rflags: u64,
1457 pub fs_base: u64,
1458 pub gs_base: u64,
1459}
1460
1461#[cfg(target_arch = "x86_64")]
1462impl std::fmt::Debug for zx_thread_state_general_regs_t {
1463 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1464 f.debug_struct(std::any::type_name::<Self>())
1465 .field("rax", &format_args!("{:#x}", self.rax))
1466 .field("rbx", &format_args!("{:#x}", self.rbx))
1467 .field("rcx", &format_args!("{:#x}", self.rcx))
1468 .field("rdx", &format_args!("{:#x}", self.rdx))
1469 .field("rsi", &format_args!("{:#x}", self.rsi))
1470 .field("rdi", &format_args!("{:#x}", self.rdi))
1471 .field("rbp", &format_args!("{:#x}", self.rbp))
1472 .field("rsp", &format_args!("{:#x}", self.rsp))
1473 .field("r8", &format_args!("{:#x}", self.r8))
1474 .field("r9", &format_args!("{:#x}", self.r9))
1475 .field("r10", &format_args!("{:#x}", self.r10))
1476 .field("r11", &format_args!("{:#x}", self.r11))
1477 .field("r12", &format_args!("{:#x}", self.r12))
1478 .field("r13", &format_args!("{:#x}", self.r13))
1479 .field("r14", &format_args!("{:#x}", self.r14))
1480 .field("r15", &format_args!("{:#x}", self.r15))
1481 .field("rip", &format_args!("{:#x}", self.rip))
1482 .field("rflags", &format_args!("{:#x}", self.rflags))
1483 .field("fs_base", &format_args!("{:#x}", self.fs_base))
1484 .field("gs_base", &format_args!("{:#x}", self.gs_base))
1485 .finish()
1486 }
1487}
1488
1489#[cfg(target_arch = "x86_64")]
1490impl From<&zx_restricted_state_t> for zx_thread_state_general_regs_t {
1491 fn from(state: &zx_restricted_state_t) -> Self {
1492 Self {
1493 rdi: state.rdi,
1494 rsi: state.rsi,
1495 rbp: state.rbp,
1496 rbx: state.rbx,
1497 rdx: state.rdx,
1498 rcx: state.rcx,
1499 rax: state.rax,
1500 rsp: state.rsp,
1501 r8: state.r8,
1502 r9: state.r9,
1503 r10: state.r10,
1504 r11: state.r11,
1505 r12: state.r12,
1506 r13: state.r13,
1507 r14: state.r14,
1508 r15: state.r15,
1509 rip: state.ip,
1510 rflags: state.flags,
1511 fs_base: state.fs_base,
1512 gs_base: state.gs_base,
1513 }
1514 }
1515}
1516
1517#[cfg(target_arch = "aarch64")]
1518multiconst!(u64, [
1519 ZX_REG_CPSR_ARCH_32_MASK = 0x10;
1520 ZX_REG_CPSR_THUMB_MASK = 0x20;
1521]);
1522
1523#[cfg(target_arch = "aarch64")]
1524#[repr(C)]
1525#[derive(Default, Copy, Clone, Eq, PartialEq)]
1526pub struct zx_thread_state_general_regs_t {
1527 pub r: [u64; 30],
1528 pub lr: u64,
1529 pub sp: u64,
1530 pub pc: u64,
1531 pub cpsr: u64,
1532 pub tpidr: u64,
1533}
1534
1535#[cfg(target_arch = "aarch64")]
1536impl std::fmt::Debug for zx_thread_state_general_regs_t {
1537 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1538 struct RegisterAsHex(u64);
1539 impl std::fmt::Debug for RegisterAsHex {
1540 fn fmt(&self, f: &mut std::fmt::Formatter<'_>) -> std::fmt::Result {
1541 write!(f, "{:#x}", self.0)
1542 }
1543 }
1544
1545 f.debug_struct(std::any::type_name::<Self>())
1546 .field("r", &self.r.map(RegisterAsHex))
1547 .field("lr", &format_args!("{:#x}", self.lr))
1548 .field("sp", &format_args!("{:#x}", self.sp))
1549 .field("pc", &format_args!("{:#x}", self.pc))
1550 .field("cpsr", &format_args!("{:#x}", self.cpsr))
1551 .field("tpidr", &format_args!("{:#x}", self.tpidr))
1552 .finish()
1553 }
1554}
1555
1556#[cfg(target_arch = "aarch64")]
1557impl From<&zx_restricted_state_t> for zx_thread_state_general_regs_t {
1558 fn from(state: &zx_restricted_state_t) -> Self {
1559 if state.cpsr as u64 & ZX_REG_CPSR_ARCH_32_MASK == ZX_REG_CPSR_ARCH_32_MASK {
1560 Self {
1562 r: [
1563 state.r[0],
1564 state.r[1],
1565 state.r[2],
1566 state.r[3],
1567 state.r[4],
1568 state.r[5],
1569 state.r[6],
1570 state.r[7],
1571 state.r[8],
1572 state.r[9],
1573 state.r[10],
1574 state.r[11],
1575 state.r[12],
1576 state.r[13],
1577 state.r[14],
1578 state.pc, state.r[16],
1580 state.r[17],
1581 state.r[18],
1582 state.r[19],
1583 state.r[20],
1584 state.r[21],
1585 state.r[22],
1586 state.r[23],
1587 state.r[24],
1588 state.r[25],
1589 state.r[26],
1590 state.r[27],
1591 state.r[28],
1592 state.r[29],
1593 ],
1594 lr: state.r[14], sp: state.r[13], pc: state.pc, cpsr: state.cpsr as u64,
1600 tpidr: state.tpidr_el0,
1601 }
1602 } else {
1603 Self {
1604 r: [
1605 state.r[0],
1606 state.r[1],
1607 state.r[2],
1608 state.r[3],
1609 state.r[4],
1610 state.r[5],
1611 state.r[6],
1612 state.r[7],
1613 state.r[8],
1614 state.r[9],
1615 state.r[10],
1616 state.r[11],
1617 state.r[12],
1618 state.r[13],
1619 state.r[14],
1620 state.r[15],
1621 state.r[16],
1622 state.r[17],
1623 state.r[18],
1624 state.r[19],
1625 state.r[20],
1626 state.r[21],
1627 state.r[22],
1628 state.r[23],
1629 state.r[24],
1630 state.r[25],
1631 state.r[26],
1632 state.r[27],
1633 state.r[28],
1634 state.r[29],
1635 ],
1636 lr: state.r[30],
1637 sp: state.sp,
1638 pc: state.pc,
1639 cpsr: state.cpsr as u64,
1640 tpidr: state.tpidr_el0,
1641 }
1642 }
1643 }
1644}
1645
1646#[cfg(target_arch = "riscv64")]
1647#[repr(C)]
1648#[derive(Default, Copy, Clone, Eq, PartialEq)]
1649pub struct zx_thread_state_general_regs_t {
1650 pub pc: u64,
1651 pub ra: u64, pub sp: u64, pub gp: u64, pub tp: u64, pub t0: u64, pub t1: u64, pub t2: u64, pub s0: u64, pub s1: u64, pub a0: u64, pub a1: u64, pub a2: u64, pub a3: u64, pub a4: u64, pub a5: u64, pub a6: u64, pub a7: u64, pub s2: u64, pub s3: u64, pub s4: u64, pub s5: u64, pub s6: u64, pub s7: u64, pub s8: u64, pub s9: u64, pub s10: u64, pub s11: u64, pub t3: u64, pub t4: u64, pub t5: u64, pub t6: u64, }
1683
1684#[cfg(target_arch = "riscv64")]
1685impl std::fmt::Debug for zx_thread_state_general_regs_t {
1686 fn fmt(&self, f: &mut fmt::Formatter<'_>) -> fmt::Result {
1687 f.debug_struct(std::any::type_name::<Self>())
1688 .field("pc", &format_args!("{:#x}", self.pc))
1689 .field("ra", &format_args!("{:#x}", self.ra)) .field("sp", &format_args!("{:#x}", self.sp)) .field("gp", &format_args!("{:#x}", self.gp)) .field("tp", &format_args!("{:#x}", self.tp)) .field("t0", &format_args!("{:#x}", self.t0)) .field("t1", &format_args!("{:#x}", self.t1)) .field("t2", &format_args!("{:#x}", self.t2)) .field("s0", &format_args!("{:#x}", self.s0)) .field("s1", &format_args!("{:#x}", self.s1)) .field("a0", &format_args!("{:#x}", self.a0)) .field("a1", &format_args!("{:#x}", self.a1)) .field("a2", &format_args!("{:#x}", self.a2)) .field("a3", &format_args!("{:#x}", self.a3)) .field("a4", &format_args!("{:#x}", self.a4)) .field("a5", &format_args!("{:#x}", self.a5)) .field("a6", &format_args!("{:#x}", self.a6)) .field("a7", &format_args!("{:#x}", self.a7)) .field("s2", &format_args!("{:#x}", self.s2)) .field("s3", &format_args!("{:#x}", self.s3)) .field("s4", &format_args!("{:#x}", self.s4)) .field("s5", &format_args!("{:#x}", self.s5)) .field("s6", &format_args!("{:#x}", self.s6)) .field("s7", &format_args!("{:#x}", self.s7)) .field("s8", &format_args!("{:#x}", self.s8)) .field("s9", &format_args!("{:#x}", self.s9)) .field("s10", &format_args!("{:#x}", self.s10)) .field("s11", &format_args!("{:#x}", self.s11)) .field("t3", &format_args!("{:#x}", self.t3)) .field("t4", &format_args!("{:#x}", self.t4)) .field("t5", &format_args!("{:#x}", self.t5)) .field("t6", &format_args!("{:#x}", self.t6)) .finish()
1721 }
1722}
1723
1724multiconst!(zx_restricted_reason_t, [
1725 ZX_RESTRICTED_REASON_SYSCALL = 0;
1726 ZX_RESTRICTED_REASON_EXCEPTION = 1;
1727 ZX_RESTRICTED_REASON_KICK = 2;
1728]);
1729
1730#[cfg(target_arch = "x86_64")]
1731#[repr(C)]
1732#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1733pub struct zx_restricted_state_t {
1734 pub rdi: u64,
1735 pub rsi: u64,
1736 pub rbp: u64,
1737 pub rbx: u64,
1738 pub rdx: u64,
1739 pub rcx: u64,
1740 pub rax: u64,
1741 pub rsp: u64,
1742 pub r8: u64,
1743 pub r9: u64,
1744 pub r10: u64,
1745 pub r11: u64,
1746 pub r12: u64,
1747 pub r13: u64,
1748 pub r14: u64,
1749 pub r15: u64,
1750 pub ip: u64,
1751 pub flags: u64,
1752 pub fs_base: u64,
1753 pub gs_base: u64,
1754}
1755
1756#[cfg(target_arch = "x86_64")]
1757impl From<&zx_thread_state_general_regs_t> for zx_restricted_state_t {
1758 fn from(registers: &zx_thread_state_general_regs_t) -> Self {
1759 Self {
1760 rdi: registers.rdi,
1761 rsi: registers.rsi,
1762 rbp: registers.rbp,
1763 rbx: registers.rbx,
1764 rdx: registers.rdx,
1765 rcx: registers.rcx,
1766 rax: registers.rax,
1767 rsp: registers.rsp,
1768 r8: registers.r8,
1769 r9: registers.r9,
1770 r10: registers.r10,
1771 r11: registers.r11,
1772 r12: registers.r12,
1773 r13: registers.r13,
1774 r14: registers.r14,
1775 r15: registers.r15,
1776 ip: registers.rip,
1777 flags: registers.rflags,
1778 fs_base: registers.fs_base,
1779 gs_base: registers.gs_base,
1780 }
1781 }
1782}
1783
1784#[cfg(target_arch = "aarch64")]
1785#[repr(C)]
1786#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1787pub struct zx_restricted_state_t {
1788 pub r: [u64; 31], pub sp: u64,
1790 pub pc: u64,
1791 pub tpidr_el0: u64,
1792 pub cpsr: u32,
1794 padding1: [PadByte; 4],
1795}
1796
1797#[cfg(target_arch = "aarch64")]
1798impl From<&zx_thread_state_general_regs_t> for zx_restricted_state_t {
1799 fn from(registers: &zx_thread_state_general_regs_t) -> Self {
1800 Self {
1801 r: [
1802 registers.r[0],
1803 registers.r[1],
1804 registers.r[2],
1805 registers.r[3],
1806 registers.r[4],
1807 registers.r[5],
1808 registers.r[6],
1809 registers.r[7],
1810 registers.r[8],
1811 registers.r[9],
1812 registers.r[10],
1813 registers.r[11],
1814 registers.r[12],
1815 registers.r[13],
1816 registers.r[14],
1817 registers.r[15],
1818 registers.r[16],
1819 registers.r[17],
1820 registers.r[18],
1821 registers.r[19],
1822 registers.r[20],
1823 registers.r[21],
1824 registers.r[22],
1825 registers.r[23],
1826 registers.r[24],
1827 registers.r[25],
1828 registers.r[26],
1829 registers.r[27],
1830 registers.r[28],
1831 registers.r[29],
1832 registers.lr, ],
1834 pc: registers.pc,
1835 tpidr_el0: registers.tpidr,
1836 sp: registers.sp,
1837 cpsr: registers.cpsr as u32,
1838 padding1: Default::default(),
1839 }
1840 }
1841}
1842
1843#[cfg(target_arch = "riscv64")]
1844pub type zx_restricted_state_t = zx_thread_state_general_regs_t;
1845
1846#[cfg(target_arch = "riscv64")]
1847impl From<&zx_thread_state_general_regs_t> for zx_restricted_state_t {
1848 fn from(registers: &zx_thread_state_general_regs_t) -> Self {
1849 *registers
1850 }
1851}
1852
1853#[repr(C)]
1854#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1855#[cfg(any(target_arch = "aarch64", target_arch = "x86_64", target_arch = "riscv64"))]
1856pub struct zx_restricted_syscall_t {
1857 pub state: zx_restricted_state_t,
1858}
1859
1860#[repr(C)]
1861#[derive(Copy, Clone)]
1862#[cfg(any(target_arch = "aarch64", target_arch = "x86_64", target_arch = "riscv64"))]
1863pub struct zx_restricted_exception_t {
1864 pub state: zx_restricted_state_t,
1865 pub exception: zx_exception_report_t,
1866}
1867
1868#[cfg(target_arch = "x86_64")]
1869#[repr(C)]
1870#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1871pub struct zx_vcpu_state_t {
1872 pub rax: u64,
1873 pub rcx: u64,
1874 pub rdx: u64,
1875 pub rbx: u64,
1876 pub rsp: u64,
1877 pub rbp: u64,
1878 pub rsi: u64,
1879 pub rdi: u64,
1880 pub r8: u64,
1881 pub r9: u64,
1882 pub r10: u64,
1883 pub r11: u64,
1884 pub r12: u64,
1885 pub r13: u64,
1886 pub r14: u64,
1887 pub r15: u64,
1888 pub rflags: u64,
1890}
1891
1892#[cfg(target_arch = "aarch64")]
1893#[repr(C)]
1894#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1895pub struct zx_vcpu_state_t {
1896 pub x: [u64; 31],
1897 pub sp: u64,
1898 pub cpsr: u32,
1900 padding1: [PadByte; 4],
1901}
1902
1903#[cfg(target_arch = "riscv64")]
1904#[repr(C)]
1905#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1906pub struct zx_vcpu_state_t {
1907 pub empty: u32,
1908}
1909
1910#[repr(C)]
1911#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1912pub struct zx_vcpu_io_t {
1913 pub access_size: u8,
1914 padding1: [PadByte; 3],
1915 pub data: [u8; 4],
1916}
1917
1918#[cfg(target_arch = "aarch64")]
1919#[repr(C)]
1920#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1921pub struct zx_packet_guest_mem_t {
1922 pub addr: zx_gpaddr_t,
1923 pub access_size: u8,
1924 pub sign_extend: bool,
1925 pub xt: u8,
1926 pub read: bool,
1927 pub data: u64,
1928}
1929
1930#[cfg(target_arch = "riscv64")]
1931#[repr(C)]
1932#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1933pub struct zx_packet_guest_mem_t {
1934 pub addr: zx_gpaddr_t,
1935 padding1: [PadByte; 24],
1936}
1937
1938pub const X86_MAX_INST_LEN: usize = 15;
1939
1940#[cfg(target_arch = "x86_64")]
1941#[repr(C)]
1942#[derive(Debug, Copy, Clone, Eq, PartialEq)]
1943pub struct zx_packet_guest_mem_t {
1944 pub addr: zx_gpaddr_t,
1945 pub cr3: zx_gpaddr_t,
1946 pub rip: zx_vaddr_t,
1947 pub instruction_size: u8,
1948 pub default_operand_size: u8,
1949}
1950
1951#[repr(C)]
1952#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
1953pub struct zx_packet_interrupt_t {
1954 pub timestamp: zx_time_t,
1955 padding1: [PadByte; 24],
1956}
1957
1958const fn info_topic(topic: u32, version: u32) -> u32 {
1960 (version << 28) | topic
1961}
1962
1963multiconst!(zx_object_info_topic_t, [
1964 ZX_INFO_NONE = 0;
1965 ZX_INFO_HANDLE_VALID = 1;
1966 ZX_INFO_HANDLE_BASIC = 2; ZX_INFO_PROCESS = info_topic(3, 1); ZX_INFO_PROCESS_THREADS = 4; ZX_INFO_VMAR = 7; ZX_INFO_JOB_CHILDREN = 8; ZX_INFO_JOB_PROCESSES = 9; ZX_INFO_THREAD = 10; ZX_INFO_THREAD_EXCEPTION_REPORT = info_topic(11, 1); ZX_INFO_TASK_STATS = info_topic(12, 1); ZX_INFO_PROCESS_MAPS = info_topic(13, 2); ZX_INFO_PROCESS_VMOS = info_topic(14, 3); ZX_INFO_THREAD_STATS = 15; ZX_INFO_CPU_STATS = 16; ZX_INFO_KMEM_STATS = info_topic(17, 1); ZX_INFO_RESOURCE = 18; ZX_INFO_HANDLE_COUNT = 19; ZX_INFO_BTI = 20; ZX_INFO_PROCESS_HANDLE_STATS = 21; ZX_INFO_SOCKET = 22; ZX_INFO_VMO = info_topic(23, 3); ZX_INFO_JOB = 24; ZX_INFO_TIMER = 25; ZX_INFO_STREAM = 26; ZX_INFO_HANDLE_TABLE = 27; ZX_INFO_MSI = 28; ZX_INFO_GUEST_STATS = 29; ZX_INFO_TASK_RUNTIME = info_topic(30, 1); ZX_INFO_KMEM_STATS_EXTENDED = 31; ZX_INFO_VCPU = 32; ZX_INFO_KMEM_STATS_COMPRESSION = 33; ZX_INFO_IOB = 34; ZX_INFO_IOB_REGIONS = 35; ZX_INFO_VMAR_MAPS = 36; ZX_INFO_POWER_DOMAINS = 37; ZX_INFO_MEMORY_STALL = 38; ZX_INFO_CLOCK_MAPPED_SIZE = 40; ]);
2003
2004multiconst!(zx_system_memory_stall_type_t, [
2005 ZX_SYSTEM_MEMORY_STALL_SOME = 0;
2006 ZX_SYSTEM_MEMORY_STALL_FULL = 1;
2007]);
2008
2009macro_rules! struct_decl_macro {
2014 ( $(#[$attrs:meta])* $vis:vis struct <$macro_name:ident> $($any:tt)* ) => {
2015 #[macro_export]
2016 macro_rules! $macro_name {
2017 ($name:ident) => {
2018 $(#[$attrs])* $vis struct $name $($any)*
2019 }
2020 }
2021 }
2022}
2023
2024#[repr(C)]
2026#[derive(Default, Debug, Copy, Clone, Eq, KnownLayout, FromBytes, Immutable, PartialEq)]
2027pub struct zx_info_handle_basic_t {
2028 pub koid: zx_koid_t,
2029 pub rights: zx_rights_t,
2030 pub type_: zx_obj_type_t,
2031 pub related_koid: zx_koid_t,
2032 padding1: [PadByte; 4],
2033}
2034
2035struct_decl_macro! {
2036 #[repr(C)]
2037 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2038 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2039 pub struct <zx_info_handle_count_t> {
2040 pub handle_count: u32,
2041 }
2042}
2043
2044zx_info_handle_count_t!(zx_info_handle_count_t);
2045
2046#[repr(C)]
2048#[derive(Default, Debug, Copy, Clone, Eq, PartialEq, KnownLayout, FromBytes, Immutable)]
2049pub struct zx_info_socket_t {
2050 pub options: u32,
2051 pub rx_buf_max: usize,
2052 pub rx_buf_size: usize,
2053 pub rx_buf_available: usize,
2054 pub tx_buf_max: usize,
2055 pub tx_buf_size: usize,
2056}
2057
2058multiconst!(u32, [
2059 ZX_INFO_PROCESS_FLAG_STARTED = 1 << 0;
2060 ZX_INFO_PROCESS_FLAG_EXITED = 1 << 1;
2061 ZX_INFO_PROCESS_FLAG_DEBUGGER_ATTACHED = 1 << 2;
2062]);
2063
2064struct_decl_macro! {
2065 #[repr(C)]
2066 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2067 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2068 pub struct <zx_info_process_t> {
2069 pub return_code: i64,
2070 pub start_time: zx_time_t,
2071 pub flags: u32,
2072 }
2073}
2074
2075zx_info_process_t!(zx_info_process_t);
2076
2077struct_decl_macro! {
2078 #[repr(C)]
2079 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2080 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2081 pub struct <zx_info_job_t> {
2082 pub return_code: i64,
2083 pub exited: u8,
2084 pub kill_on_oom: u8,
2085 pub debugger_attached: u8,
2086 }
2087}
2088
2089zx_info_job_t!(zx_info_job_t);
2090
2091struct_decl_macro! {
2092 #[repr(C)]
2093 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2094 #[derive(zerocopy::FromBytes, zerocopy::IntoBytes, zerocopy::Immutable)]
2095 pub struct <zx_info_timer_t> {
2096 pub options: u32,
2097 pub clock_id: zx_clock_t,
2098 pub deadline: zx_time_t,
2099 pub slack: zx_duration_t,
2100 }
2101}
2102
2103zx_info_timer_t!(zx_info_timer_t);
2104
2105#[repr(C)]
2106#[derive(Debug, Copy, Clone, Eq, PartialEq)]
2107pub struct zx_policy_basic {
2108 pub condition: u32,
2109 pub policy: u32,
2110}
2111
2112#[repr(C)]
2113#[derive(Debug, Copy, Clone, Eq, PartialEq)]
2114pub struct zx_policy_timer_slack {
2115 pub min_slack: zx_duration_t,
2116 pub default_mode: u32,
2117}
2118
2119multiconst!(u32, [
2120 ZX_JOB_POL_RELATIVE = 0;
2122 ZX_JOB_POL_ABSOLUTE = 1;
2123
2124 ZX_JOB_POL_BASIC = 0;
2126 ZX_JOB_POL_TIMER_SLACK = 1;
2127
2128 ZX_POL_BAD_HANDLE = 0;
2130 ZX_POL_WRONG_OBJECT = 1;
2131 ZX_POL_VMAR_WX = 2;
2132 ZX_POL_NEW_ANY = 3;
2133 ZX_POL_NEW_VMO = 4;
2134 ZX_POL_NEW_CHANNEL = 5;
2135 ZX_POL_NEW_EVENT = 6;
2136 ZX_POL_NEW_EVENTPAIR = 7;
2137 ZX_POL_NEW_PORT = 8;
2138 ZX_POL_NEW_SOCKET = 9;
2139 ZX_POL_NEW_FIFO = 10;
2140 ZX_POL_NEW_TIMER = 11;
2141 ZX_POL_NEW_PROCESS = 12;
2142 ZX_POL_NEW_PROFILE = 13;
2143 ZX_POL_NEW_PAGER = 14;
2144 ZX_POL_AMBIENT_MARK_VMO_EXEC = 15;
2145
2146 ZX_POL_ACTION_ALLOW = 0;
2148 ZX_POL_ACTION_DENY = 1;
2149 ZX_POL_ACTION_ALLOW_EXCEPTION = 2;
2150 ZX_POL_ACTION_DENY_EXCEPTION = 3;
2151 ZX_POL_ACTION_KILL = 4;
2152
2153 ZX_TIMER_SLACK_CENTER = 0;
2155 ZX_TIMER_SLACK_EARLY = 1;
2156 ZX_TIMER_SLACK_LATE = 2;
2157]);
2158
2159multiconst!(u32, [
2160 ZX_JOB_CRITICAL_PROCESS_RETCODE_NONZERO = 1 << 0;
2162]);
2163
2164#[repr(C)]
2166#[derive(
2167 Default, Debug, Copy, Clone, Eq, PartialEq, KnownLayout, FromBytes, Immutable, IntoBytes,
2168)]
2169pub struct zx_info_vmo_t {
2170 pub koid: zx_koid_t,
2171 pub name: [u8; ZX_MAX_NAME_LEN],
2172 pub size_bytes: u64,
2173 pub parent_koid: zx_koid_t,
2174 pub num_children: usize,
2175 pub num_mappings: usize,
2176 pub share_count: usize,
2177 pub flags: u32,
2178 padding1: [PadByte; 4],
2179 pub committed_bytes: u64,
2180 pub handle_rights: zx_rights_t,
2181 pub cache_policy: u32,
2182 pub metadata_bytes: u64,
2183 pub committed_change_events: u64,
2184 pub populated_bytes: u64,
2185 pub committed_private_bytes: u64,
2186 pub populated_private_bytes: u64,
2187 pub committed_scaled_bytes: u64,
2188 pub populated_scaled_bytes: u64,
2189 pub committed_fractional_scaled_bytes: u64,
2190 pub populated_fractional_scaled_bytes: u64,
2191}
2192
2193struct_decl_macro! {
2194 #[repr(C)]
2195 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2196 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2197 pub struct <zx_info_cpu_stats_t> {
2198 pub cpu_number: u32,
2199 pub flags: u32,
2200 pub idle_time: zx_duration_t,
2201 pub normalized_busy_time: zx_duration_t,
2202 pub reschedules: u64,
2203 pub context_switches: u64,
2204 pub irq_preempts: u64,
2205 pub preempts: u64,
2206 pub yields: u64,
2207 pub ints: u64,
2208 pub timer_ints: u64,
2209 pub timers: u64,
2210 pub page_faults: u64,
2211 pub exceptions: u64,
2212 pub syscalls: u64,
2213 pub reschedule_ipis: u64,
2214 pub generic_ipis: u64,
2215 pub active_energy_consumption_nj: u64,
2216 pub idle_energy_consumption_nj: u64,
2217 }
2218}
2219
2220zx_info_cpu_stats_t!(zx_info_cpu_stats_t);
2221
2222struct_decl_macro! {
2223 #[repr(C)]
2224 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2225 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2226 pub struct <zx_info_kmem_stats_t> {
2227 pub total_bytes: u64,
2228 pub free_bytes: u64,
2229 pub free_loaned_bytes: u64,
2230 pub wired_bytes: u64,
2231 pub total_heap_bytes: u64,
2232 pub free_heap_bytes: u64,
2233 pub vmo_bytes: u64,
2234 pub mmu_overhead_bytes: u64,
2235 pub ipc_bytes: u64,
2236 pub cache_bytes: u64,
2237 pub slab_bytes: u64,
2238 pub zram_bytes: u64,
2239 pub other_bytes: u64,
2240 pub vmo_reclaim_total_bytes: u64,
2241 pub vmo_reclaim_newest_bytes: u64,
2242 pub vmo_reclaim_oldest_bytes: u64,
2243 pub vmo_reclaim_disabled_bytes: u64,
2244 pub vmo_discardable_locked_bytes: u64,
2245 pub vmo_discardable_unlocked_bytes: u64,
2246 }
2247}
2248
2249zx_info_kmem_stats_t!(zx_info_kmem_stats_t);
2250
2251struct_decl_macro! {
2252 #[repr(C)]
2253 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2254 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2255 pub struct <zx_info_kmem_stats_extended_t> {
2256 pub total_bytes: u64,
2257 pub free_bytes: u64,
2258 pub wired_bytes: u64,
2259 pub total_heap_bytes: u64,
2260 pub free_heap_bytes: u64,
2261 pub vmo_bytes: u64,
2262 pub vmo_pager_total_bytes: u64,
2263 pub vmo_pager_newest_bytes: u64,
2264 pub vmo_pager_oldest_bytes: u64,
2265 pub vmo_discardable_locked_bytes: u64,
2266 pub vmo_discardable_unlocked_bytes: u64,
2267 pub mmu_overhead_bytes: u64,
2268 pub ipc_bytes: u64,
2269 pub other_bytes: u64,
2270 pub vmo_reclaim_disable_bytes: u64,
2271 }
2272}
2273
2274zx_info_kmem_stats_extended_t!(zx_info_kmem_stats_extended_t);
2275
2276struct_decl_macro! {
2277 #[repr(C)]
2278 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2279 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2280 pub struct <zx_info_kmem_stats_compression_t> {
2281 pub uncompressed_storage_bytes: u64,
2282 pub compressed_storage_bytes: u64,
2283 pub compressed_fragmentation_bytes: u64,
2284 pub compression_time: zx_duration_t,
2285 pub decompression_time: zx_duration_t,
2286 pub total_page_compression_attempts: u64,
2287 pub failed_page_compression_attempts: u64,
2288 pub total_page_decompressions: u64,
2289 pub compressed_page_evictions: u64,
2290 pub eager_page_compressions: u64,
2291 pub memory_pressure_page_compressions: u64,
2292 pub critical_memory_page_compressions: u64,
2293 pub pages_decompressed_unit_ns: u64,
2294 pub pages_decompressed_within_log_time: [u64; 8],
2295 }
2296}
2297
2298zx_info_kmem_stats_compression_t!(zx_info_kmem_stats_compression_t);
2299
2300struct_decl_macro! {
2301 #[repr(C)]
2302 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2303 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2304 pub struct <zx_info_resource_t> {
2305 pub kind: u32,
2306 pub flags: u32,
2307 pub base: u64,
2308 pub size: usize,
2309 pub name: [u8; ZX_MAX_NAME_LEN],
2310 }
2311}
2312
2313struct_decl_macro! {
2314 #[repr(C)]
2315 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2316 #[derive(zerocopy::FromBytes, zerocopy::IntoBytes, zerocopy::Immutable)]
2317 pub struct <zx_info_bti_t> {
2318 pub minimum_contiguity: u64,
2319 pub aspace_size: u64,
2320 pub pmo_count: u64,
2321 pub quarantine_count: u64,
2322 }
2323}
2324
2325zx_info_bti_t!(zx_info_bti_t);
2326
2327pub type zx_thread_state_t = u32;
2328
2329multiconst!(zx_thread_state_t, [
2330 ZX_THREAD_STATE_NEW = 0x0000;
2331 ZX_THREAD_STATE_RUNNING = 0x0001;
2332 ZX_THREAD_STATE_SUSPENDED = 0x0002;
2333 ZX_THREAD_STATE_BLOCKED = 0x0003;
2334 ZX_THREAD_STATE_DYING = 0x0004;
2335 ZX_THREAD_STATE_DEAD = 0x0005;
2336 ZX_THREAD_STATE_BLOCKED_EXCEPTION = 0x0103;
2337 ZX_THREAD_STATE_BLOCKED_SLEEPING = 0x0203;
2338 ZX_THREAD_STATE_BLOCKED_FUTEX = 0x0303;
2339 ZX_THREAD_STATE_BLOCKED_PORT = 0x0403;
2340 ZX_THREAD_STATE_BLOCKED_CHANNEL = 0x0503;
2341 ZX_THREAD_STATE_BLOCKED_WAIT_ONE = 0x0603;
2342 ZX_THREAD_STATE_BLOCKED_WAIT_MANY = 0x0703;
2343 ZX_THREAD_STATE_BLOCKED_INTERRUPT = 0x0803;
2344 ZX_THREAD_STATE_BLOCKED_PAGER = 0x0903;
2345]);
2346
2347#[repr(C)]
2348#[derive(Default, Debug, Copy, Clone, Eq, PartialEq, zerocopy::FromBytes, zerocopy::Immutable)]
2349pub struct zx_info_thread_t {
2350 pub state: zx_thread_state_t,
2351 pub wait_exception_channel_type: u32,
2352 pub cpu_affinity_mask: zx_cpu_set_t,
2353}
2354
2355struct_decl_macro! {
2356 #[repr(C)]
2357 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2358 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2359 pub struct <zx_info_thread_stats_t> {
2360 pub total_runtime: zx_duration_t,
2361 pub last_scheduled_cpu: u32,
2362 }
2363}
2364
2365zx_info_thread_stats_t!(zx_info_thread_stats_t);
2366
2367zx_info_resource_t!(zx_info_resource_t);
2368
2369struct_decl_macro! {
2370 #[repr(C)]
2371 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2372 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2373 pub struct <zx_info_vmar_t> {
2374 pub base: usize,
2375 pub len: usize,
2376 }
2377}
2378
2379zx_info_vmar_t!(zx_info_vmar_t);
2380
2381struct_decl_macro! {
2382 #[repr(C)]
2383 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2384 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2385 pub struct <zx_info_task_stats_t> {
2386 pub mem_mapped_bytes: usize,
2387 pub mem_private_bytes: usize,
2388 pub mem_shared_bytes: usize,
2389 pub mem_scaled_shared_bytes: usize,
2390 pub mem_fractional_scaled_shared_bytes: u64,
2391 }
2392}
2393
2394zx_info_task_stats_t!(zx_info_task_stats_t);
2395
2396struct_decl_macro! {
2397 #[repr(C)]
2398 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2399 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2400 pub struct <zx_info_task_runtime_t> {
2401 pub cpu_time: zx_duration_t,
2402 pub queue_time: zx_duration_t,
2403 pub page_fault_time: zx_duration_t,
2404 pub lock_contention_time: zx_duration_t,
2405 }
2406}
2407
2408zx_info_task_runtime_t!(zx_info_task_runtime_t);
2409
2410multiconst!(zx_info_maps_type_t, [
2411 ZX_INFO_MAPS_TYPE_NONE = 0;
2412 ZX_INFO_MAPS_TYPE_ASPACE = 1;
2413 ZX_INFO_MAPS_TYPE_VMAR = 2;
2414 ZX_INFO_MAPS_TYPE_MAPPING = 3;
2415]);
2416
2417struct_decl_macro! {
2418 #[repr(C)]
2419 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2420 #[derive(zerocopy::FromBytes, zerocopy::Immutable, IntoBytes)]
2421 pub struct <zx_info_maps_mapping_t> {
2422 pub mmu_flags: zx_vm_option_t,
2423 padding1: [PadByte; 4],
2424 pub vmo_koid: zx_koid_t,
2425 pub vmo_offset: u64,
2426 pub committed_bytes: usize,
2427 pub populated_bytes: usize,
2428 pub committed_private_bytes: usize,
2429 pub populated_private_bytes: usize,
2430 pub committed_scaled_bytes: usize,
2431 pub populated_scaled_bytes: usize,
2432 pub committed_fractional_scaled_bytes: u64,
2433 pub populated_fractional_scaled_bytes: u64,
2434 }
2435}
2436
2437zx_info_maps_mapping_t!(zx_info_maps_mapping_t);
2438
2439#[repr(C)]
2440#[derive(Copy, Clone, KnownLayout, FromBytes, Immutable)]
2441pub union InfoMapsTypeUnion {
2442 pub mapping: zx_info_maps_mapping_t,
2443}
2444
2445struct_decl_macro! {
2446 #[repr(C)]
2447 #[derive(Copy, Clone)]
2448 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2449 pub struct <zx_info_maps_t> {
2450 pub name: [u8; ZX_MAX_NAME_LEN],
2451 pub base: zx_vaddr_t,
2452 pub size: usize,
2453 pub depth: usize,
2454 pub r#type: zx_info_maps_type_t,
2455 pub u: InfoMapsTypeUnion,
2456 }
2457}
2458
2459zx_info_maps_t!(zx_info_maps_t);
2460
2461struct_decl_macro! {
2462 #[repr(C)]
2463 #[derive(Debug, Copy, Clone, Eq, PartialEq)]
2464 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2465 pub struct <zx_info_process_handle_stats_t> {
2466 pub handle_count: [u32; ZX_OBJ_TYPE_UPPER_BOUND],
2467 }
2468}
2469
2470impl Default for zx_info_process_handle_stats_t {
2471 fn default() -> Self {
2472 Self { handle_count: [0; ZX_OBJ_TYPE_UPPER_BOUND] }
2473 }
2474}
2475
2476zx_info_process_handle_stats_t!(zx_info_process_handle_stats_t);
2477
2478struct_decl_macro! {
2479 #[repr(C)]
2480 #[derive(Default, Debug, Copy, Clone, Eq, PartialEq)]
2481 #[derive(zerocopy::FromBytes, zerocopy::Immutable, zerocopy::IntoBytes)]
2482 pub struct <zx_info_memory_stall_t> {
2483 pub stall_time_some: zx_duration_mono_t,
2484 pub stall_time_full: zx_duration_mono_t,
2485 }
2486}
2487
2488zx_info_memory_stall_t!(zx_info_memory_stall_t);
2489
2490multiconst!(zx_guest_trap_t, [
2492 ZX_GUEST_TRAP_BELL = 0;
2493 ZX_GUEST_TRAP_MEM = 1;
2494 ZX_GUEST_TRAP_IO = 2;
2495]);
2496
2497pub const ZX_LOG_RECORD_MAX: usize = 256;
2498pub const ZX_LOG_RECORD_DATA_MAX: usize = 216;
2499
2500pub const DEBUGLOG_TRACE: u8 = 0x10;
2501pub const DEBUGLOG_DEBUG: u8 = 0x20;
2502pub const DEBUGLOG_INFO: u8 = 0x30;
2503pub const DEBUGLOG_WARNING: u8 = 0x40;
2504pub const DEBUGLOG_ERROR: u8 = 0x50;
2505pub const DEBUGLOG_FATAL: u8 = 0x60;
2506
2507struct_decl_macro! {
2508 #[repr(C)]
2509 #[derive(Debug, Copy, Clone, Eq, PartialEq)]
2510 #[derive(zerocopy::FromBytes, zerocopy::Immutable)]
2511 pub struct <zx_log_record_t> {
2512 pub sequence: u64,
2513 padding1: [PadByte; 4],
2514 pub datalen: u16,
2515 pub severity: u8,
2516 pub flags: u8,
2517 pub timestamp: zx_instant_boot_t,
2518 pub pid: u64,
2519 pub tid: u64,
2520 pub data: [u8; ZX_LOG_RECORD_DATA_MAX],
2521 }
2522}
2523const_assert_eq!(std::mem::size_of::<zx_log_record_t>(), ZX_LOG_RECORD_MAX);
2524
2525zx_log_record_t!(zx_log_record_t);
2526
2527impl Default for zx_log_record_t {
2528 fn default() -> zx_log_record_t {
2529 zx_log_record_t {
2530 sequence: 0,
2531 padding1: Default::default(),
2532 datalen: 0,
2533 severity: 0,
2534 flags: 0,
2535 timestamp: 0,
2536 pid: 0,
2537 tid: 0,
2538 data: [0; ZX_LOG_RECORD_DATA_MAX],
2539 }
2540 }
2541}
2542
2543multiconst!(u32, [
2544 ZX_LOG_FLAG_READABLE = 0x40000000;
2545]);
2546
2547#[repr(C)]
2556pub struct zx_system_powerctl_arg_t {
2557 pub powerctl_internal: zx_powerctl_union,
2560}
2561
2562#[repr(C)]
2563#[derive(Copy, Clone)]
2564pub union zx_powerctl_union {
2565 acpi_transition_s_state: acpi_transition_s_state,
2566 x86_power_limit: x86_power_limit,
2567}
2568
2569#[repr(C)]
2570#[derive(Default, Debug, PartialEq, Copy, Clone)]
2571pub struct acpi_transition_s_state {
2572 target_s_state: u8, sleep_type_a: u8, sleep_type_b: u8, padding1: [PadByte; 9],
2576}
2577
2578#[repr(C)]
2579#[derive(Default, Debug, PartialEq, Copy, Clone)]
2580pub struct x86_power_limit {
2581 power_limit: u32, time_window: u32, clamp: u8, enable: u8, padding1: [PadByte; 2],
2586}
2587
2588pub type zx_pci_bar_types_t = u32;
2590
2591multiconst!(zx_pci_bar_types_t, [
2592 ZX_PCI_BAR_TYPE_UNUSED = 0;
2593 ZX_PCI_BAR_TYPE_MMIO = 1;
2594 ZX_PCI_BAR_TYPE_PIO = 2;
2595]);
2596
2597#[repr(C)]
2598pub struct zx_pci_bar_t {
2599 pub id: u32,
2600 pub ty: u32,
2601 pub size: usize,
2602 pub zx_pci_bar_union: zx_pci_bar_union,
2605}
2606
2607#[repr(C)]
2608#[derive(Copy, Clone)]
2609pub union zx_pci_bar_union {
2610 addr: usize,
2611 zx_pci_bar_union_struct: zx_pci_bar_union_struct,
2612}
2613
2614#[repr(C)]
2615#[derive(Default, Debug, PartialEq, Copy, Clone)]
2616pub struct zx_pci_bar_union_struct {
2617 handle: zx_handle_t,
2618 padding1: [PadByte; 4],
2619}
2620
2621#[repr(C)]
2623#[derive(Debug, Copy, Clone, Default, Eq, PartialEq)]
2624pub struct zx_smc_parameters_t {
2625 pub func_id: u32,
2626 padding1: [PadByte; 4],
2627 pub arg1: u64,
2628 pub arg2: u64,
2629 pub arg3: u64,
2630 pub arg4: u64,
2631 pub arg5: u64,
2632 pub arg6: u64,
2633 pub client_id: u16,
2634 pub secure_os_id: u16,
2635 padding2: [PadByte; 4],
2636}
2637
2638#[repr(C)]
2639#[derive(Debug, Copy, Clone, Eq, PartialEq)]
2640pub struct zx_smc_result_t {
2641 pub arg0: u64,
2642 pub arg1: u64,
2643 pub arg2: u64,
2644 pub arg3: u64,
2645 pub arg6: u64,
2646}
2647
2648pub const ZX_CPU_SET_MAX_CPUS: usize = 512;
2649pub const ZX_CPU_SET_BITS_PER_WORD: usize = 64;
2650
2651#[repr(C)]
2652#[derive(Debug, Default, Copy, Clone, Eq, PartialEq, zerocopy::FromBytes, zerocopy::Immutable)]
2653pub struct zx_cpu_set_t {
2654 pub mask: [u64; ZX_CPU_SET_MAX_CPUS / ZX_CPU_SET_BITS_PER_WORD],
2655}
2656
2657#[repr(C)]
2659#[derive(Copy, Clone)]
2660pub struct zx_profile_info_t {
2661 pub flags: u32,
2662 padding1: [PadByte; 4],
2663 pub zx_profile_info_union: zx_profile_info_union,
2664 pub cpu_affinity_mask: zx_cpu_set_t,
2665}
2666
2667#[cfg(feature = "zerocopy")]
2668impl Default for zx_profile_info_t {
2669 fn default() -> Self {
2670 Self {
2671 flags: Default::default(),
2672 padding1: Default::default(),
2673 zx_profile_info_union: FromZeros::new_zeroed(),
2674 cpu_affinity_mask: Default::default(),
2675 }
2676 }
2677}
2678
2679#[repr(C)]
2680#[derive(Copy, Clone)]
2681#[cfg_attr(feature = "zerocopy", derive(FromBytes, Immutable))]
2682pub struct priority_params {
2683 pub priority: i32,
2684 padding1: [PadByte; 20],
2685}
2686
2687#[repr(C)]
2688#[derive(Copy, Clone)]
2689#[cfg_attr(feature = "zerocopy", derive(FromBytes, Immutable))]
2690pub union zx_profile_info_union {
2691 pub priority_params: priority_params,
2692 pub deadline_params: zx_sched_deadline_params_t,
2693}
2694
2695#[repr(C)]
2696#[derive(Debug, Copy, Clone, Eq, PartialEq)]
2697#[cfg_attr(feature = "zerocopy", derive(FromBytes, Immutable, KnownLayout))]
2698pub struct zx_sched_deadline_params_t {
2699 pub capacity: zx_duration_t,
2700 pub relative_deadline: zx_duration_t,
2701 pub period: zx_duration_t,
2702}
2703
2704#[repr(C)]
2705#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
2706pub struct zx_cpu_performance_scale_t {
2707 pub integer_part: u32,
2708 pub fractional_part: u32,
2709}
2710
2711#[repr(C)]
2712#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
2713pub struct zx_cpu_performance_info_t {
2714 pub logical_cpu_number: u32,
2715 pub performance_scale: zx_cpu_performance_scale_t,
2716}
2717
2718#[repr(C)]
2719#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
2720pub struct zx_cpu_perf_limit_t {
2721 pub logical_cpu_number: u32,
2722 pub limit_type: u32,
2723 pub min: u64,
2724 pub max: u64,
2725}
2726
2727#[repr(C)]
2728#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
2729pub struct zx_iommu_desc_stub_t {
2730 padding1: PadByte,
2731}
2732
2733multiconst!(u32, [
2734 ZX_IOMMU_TYPE_STUB = 0;
2735 ZX_IOMMU_TYPE_INTEL = 1;
2736]);
2737
2738#[repr(C)]
2739#[derive(Debug, Copy, Clone)]
2740pub struct zx_sampler_config_t {
2741 pub period: zx_duration_t,
2742 pub buffer_size: usize,
2743 pub iobuffer_discipline: u64,
2744}
2745
2746multiconst!(zx_processor_power_level_options_t, [
2747 ZX_PROCESSOR_POWER_LEVEL_OPTIONS_DOMAIN_INDEPENDENT = 1 << 0;
2748]);
2749
2750multiconst!(zx_processor_power_control_t, [
2751 ZX_PROCESSOR_POWER_CONTROL_CPU_DRIVER = 0;
2752 ZX_PROCESSOR_POWER_CONTROL_ARM_PSCI = 1;
2753 ZX_PROCESSOR_POWER_CONTROL_ARM_WFI = 2;
2754 ZX_PROCESSOR_POWER_CONTROL_RISCV_SBI = 3;
2755 ZX_PROCESSOR_POWER_CONTROL_RISCV_WFI = 4;
2756]);
2757
2758#[repr(C)]
2759#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
2760pub struct zx_processor_power_level_t {
2761 pub options: zx_processor_power_level_options_t,
2762 pub processing_rate: u64,
2763 pub power_coefficient_nw: u64,
2764 pub control_interface: zx_processor_power_control_t,
2765 pub control_argument: u64,
2766 pub diagnostic_name: [u8; ZX_MAX_NAME_LEN],
2767 padding1: [PadByte; 32],
2768}
2769
2770#[repr(C)]
2771#[derive(Debug, Default, Copy, Clone, Eq, PartialEq)]
2772pub struct zx_processor_power_level_transition_t {
2773 pub latency: zx_duration_t,
2774 pub energy: u64,
2775 pub from: u8,
2776 pub to: u8,
2777 padding1: [PadByte; 6],
2778}
2779
2780#[repr(C)]
2781#[derive(Debug, Copy, Clone, Default, Eq, PartialEq)]
2782pub struct zx_packet_processor_power_level_transition_request_t {
2783 pub domain_id: u32,
2784 pub options: u32,
2785 pub control_interface: u64,
2786 pub control_argument: u64,
2787 padding1: [PadByte; 8],
2788}
2789
2790#[repr(C)]
2791#[derive(Debug, Copy, Clone, Eq, PartialEq)]
2792pub struct zx_processor_power_state_t {
2793 pub domain_id: u32,
2794 pub options: u32,
2795 pub control_interface: u64,
2796 pub control_argument: u64,
2797}
2798
2799#[repr(C)]
2800#[derive(Debug, Copy, Clone, Default, Eq, PartialEq)]
2801pub struct zx_processor_power_domain_t {
2802 pub cpus: zx_cpu_set_t,
2803 pub domain_id: u32,
2804 padding1: [PadByte; 4],
2805}
2806
2807#[repr(C)]
2808#[derive(Debug, Copy, Clone, Eq, PartialEq)]
2809pub struct zx_power_domain_info_t {
2810 pub cpus: zx_cpu_set_t,
2811 pub domain_id: u32,
2812 pub idle_power_levels: u8,
2813 pub active_power_levels: u8,
2814 padding1: [PadByte; 2],
2815}
2816
2817multiconst!(u32, [
2818 ZX_BTI_PERM_READ = 1 << 0;
2819 ZX_BTI_PERM_WRITE = 1 << 1;
2820 ZX_BTI_PERM_EXECUTE = 1 << 2;
2821 ZX_BTI_COMPRESS = 1 << 3;
2822 ZX_BTI_CONTIGUOUS = 1 << 4;
2823]);
2824
2825multiconst!(u32, [
2827 ZX_PORT_BIND_TO_INTERRUPT = 1 << 0;
2828]);
2829
2830multiconst!(u32, [
2832 ZX_INTERRUPT_VIRTUAL = 0x10;
2833 ZX_INTERRUPT_TIMESTAMP_MONO = 1 << 6;
2834]);
2835
2836multiconst!(u32, [
2838 ZX_INTERRUPT_BIND = 0;
2839 ZX_INTERRUPT_UNBIND = 1;
2840]);
2841
2842#[repr(C)]
2843pub struct zx_iob_region_t {
2844 pub r#type: zx_iob_region_type_t,
2845 pub access: zx_iob_access_t,
2846 pub size: u64,
2847 pub discipline: zx_iob_discipline_t,
2848 pub extension: zx_iob_region_extension_t,
2849}
2850
2851multiconst!(zx_iob_region_type_t, [
2852 ZX_IOB_REGION_TYPE_PRIVATE = 0;
2853 ZX_IOB_REGION_TYPE_SHARED = 1;
2854]);
2855
2856multiconst!(zx_iob_access_t, [
2857 ZX_IOB_ACCESS_EP0_CAN_MAP_READ = 1 << 0;
2858 ZX_IOB_ACCESS_EP0_CAN_MAP_WRITE = 1 << 1;
2859 ZX_IOB_ACCESS_EP0_CAN_MEDIATED_READ = 1 << 2;
2860 ZX_IOB_ACCESS_EP0_CAN_MEDIATED_WRITE = 1 << 3;
2861 ZX_IOB_ACCESS_EP1_CAN_MAP_READ = 1 << 4;
2862 ZX_IOB_ACCESS_EP1_CAN_MAP_WRITE = 1 << 5;
2863 ZX_IOB_ACCESS_EP1_CAN_MEDIATED_READ = 1 << 6;
2864 ZX_IOB_ACCESS_EP1_CAN_MEDIATED_WRITE = 1 << 7;
2865]);
2866
2867#[repr(C)]
2868#[derive(Copy, Clone)]
2869pub struct zx_iob_discipline_t {
2870 pub r#type: zx_iob_discipline_type_t,
2871 pub extension: zx_iob_discipline_extension_t,
2872}
2873
2874#[repr(C)]
2875#[derive(Copy, Clone)]
2876pub union zx_iob_discipline_extension_t {
2877 pub ring_buffer: zx_iob_discipline_mediated_write_ring_buffer_t,
2879 pub reserved: [PadByte; 64],
2880}
2881
2882#[repr(C)]
2883#[derive(Debug, Copy, Clone)]
2884pub struct zx_iob_discipline_mediated_write_ring_buffer_t {
2885 pub tag: u64,
2886 pub padding: [PadByte; 56],
2887}
2888
2889multiconst!(zx_iob_discipline_type_t, [
2890 ZX_IOB_DISCIPLINE_TYPE_NONE = 0;
2891 ZX_IOB_DISCIPLINE_TYPE_MEDIATED_WRITE_RING_BUFFER = 2;
2892]);
2893
2894#[repr(C)]
2895#[derive(Clone, Copy, Default)]
2896pub struct zx_iob_region_private_t {
2897 options: u32,
2898 padding: [PadByte; 28],
2899}
2900
2901#[repr(C)]
2902#[derive(Clone, Copy)]
2903pub struct zx_iob_region_shared_t {
2904 pub options: u32,
2905 pub shared_region: zx_handle_t,
2906 pub padding: [PadByte; 24],
2907}
2908
2909#[repr(C)]
2910pub union zx_iob_region_extension_t {
2911 pub private_region: zx_iob_region_private_t,
2912 pub shared_region: zx_iob_region_shared_t,
2913 pub max_extension: [u8; 32],
2914}
2915
2916#[repr(C)]
2917pub struct zx_wake_source_report_entry_t {
2918 pub koid: zx_koid_t,
2919 pub name: [u8; ZX_MAX_NAME_LEN],
2920 pub initial_signal_time: zx_instant_boot_t,
2921 pub last_signal_time: zx_instant_boot_t,
2922 pub last_ack_time: zx_instant_boot_t,
2923 pub signal_count: u32,
2924 pub flags: u32,
2925}
2926
2927#[repr(C)]
2928pub struct zx_wake_source_report_header_t {
2929 pub report_time: zx_instant_boot_t,
2930 pub suspend_start_time: zx_instant_boot_t,
2931 pub total_wake_sources: u32,
2932 pub unreported_wake_report_entries: u32,
2933}
2934
2935#[cfg(test)]
2936mod test {
2937 use super::*;
2938
2939 #[test]
2940 fn padded_struct_equality() {
2941 let test_struct = zx_clock_update_args_v1_t {
2942 rate_adjust: 222,
2943 padding1: Default::default(),
2944 value: 333,
2945 error_bound: 444,
2946 };
2947
2948 let different_data = zx_clock_update_args_v1_t { rate_adjust: 999, ..test_struct.clone() };
2949
2950 let different_padding = zx_clock_update_args_v1_t {
2951 padding1: [PadByte(0), PadByte(1), PadByte(2), PadByte(3)],
2952 ..test_struct.clone()
2953 };
2954
2955 assert_ne!(test_struct, different_data);
2957 assert_eq!(test_struct, different_padding);
2959 }
2960
2961 #[test]
2962 fn padded_struct_debug() {
2963 let test_struct = zx_clock_update_args_v1_t {
2964 rate_adjust: 222,
2965 padding1: Default::default(),
2966 value: 333,
2967 error_bound: 444,
2968 };
2969 let expectation = "zx_clock_update_args_v1_t { \
2970 rate_adjust: 222, \
2971 padding1: [-, -, -, -], \
2972 value: 333, \
2973 error_bound: 444 }";
2974 assert_eq!(format!("{:?}", test_struct), expectation);
2975 }
2976}