1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
#[repr(C)]
pub struct io_uring_sqe {
pub opcode: IoRingOp,
pub flags: libc::__u8,
pub ioprio: libc::__u16,
pub fd: libc::__s32,
pub off_addr2: off_addr2,
pub addr_splice_off_in: addr_splice_off_in,
pub len: libc::__u32,
pub cmd_flags: cmd_flags,
pub user_data: libc::__u64,
pub buf_index: buf_index_padding,
}
#[repr(C)]
pub union off_addr2 {
pub off: libc::__u64,
pub addr2: libc::__u64,
}
#[repr(C)]
pub union addr_splice_off_in {
pub addr: libc::__u64,
pub splice_off_in: libc::__u64,
}
#[repr(C)]
pub union buf_index_padding {
pub buf_index: buf_index,
pub __pad2: [libc::__u64; 3],
}
#[repr(C)]
#[derive(Copy, Clone)]
pub struct buf_index {
pub index_or_group: libc::__u16,
pub personality: libc::__u16,
pub splice_fd_in: libc::__s32,
}
#[repr(C)]
pub union cmd_flags {
pub rw_flags: __kernel_rwf_t,
pub fsync_flags: libc::__u32,
pub poll_events: libc::__u16,
pub sync_range_flags: libc::__u32,
pub msg_flags: libc::__u32,
pub timeout_flags: libc::__u32,
pub accept_flags: libc::__u32,
pub cancel_flags: libc::__u32,
pub open_flags: libc::__u32,
pub statx_flags: libc::__u32,
pub fadvise_advice: libc::__u32,
pub splice_flags: libc::__u32,
pub rename_flags: libc::__u32,
pub unlink_flags: libc::__u32,
pub hardlink_flags: libc::__u32,
}
#[allow(non_camel_case_types)]
type __kernel_rwf_t = libc::c_int;
pub const IOSQE_FIXED_FILE: libc::__u8 = 1 << 0;
pub const IOSQE_IO_DRAIN: libc::__u8 = 1 << 1;
pub const IOSQE_IO_LINK: libc::__u8 = 1 << 2;
pub const IOSQE_IO_HARDLINK: libc::__u8 = 1 << 3;
pub const IOSQE_ASYNC: libc::__u8 = 1 << 4;
pub const IOSQE_BUFFER_SELECT: libc::__u8 = 1 << 5;
pub const IOSQE_CQE_SKIP_SUCCESS: libc::__u8 = 1 << 6;
pub const IORING_SETUP_IOPOLL: libc::c_uint = 1 << 0;
pub const IORING_SETUP_SQPOLL: libc::c_uint = 1 << 1;
pub const IORING_SETUP_SQ_AFF: libc::c_uint = 1 << 2;
pub const IORING_SETUP_CQSIZE: libc::c_uint = 1 << 3;
pub const IORING_SETUP_CLAMP: libc::c_uint = 1 << 4;
pub const IORING_SETUP_ATTACH_WQ: libc::c_uint = 1 << 5;
pub const IORING_SETUP_R_DISABLED: libc::c_uint = 1 << 6;
#[repr(u8)]
#[non_exhaustive]
#[allow(nonstandard_style)]
#[derive(Clone, Copy, Debug)]
pub enum IoRingOp {
IORING_OP_NOP = 0,
IORING_OP_READV,
IORING_OP_WRITEV,
IORING_OP_FSYNC,
IORING_OP_READ_FIXED,
IORING_OP_WRITE_FIXED,
IORING_OP_POLL_ADD,
IORING_OP_POLL_REMOVE,
IORING_OP_SYNC_FILE_RANGE,
IORING_OP_SENDMSG,
IORING_OP_RECVMSG,
IORING_OP_TIMEOUT,
IORING_OP_TIMEOUT_REMOVE,
IORING_OP_ACCEPT,
IORING_OP_ASYNC_CANCEL,
IORING_OP_LINK_TIMEOUT,
IORING_OP_CONNECT,
IORING_OP_FALLOCATE,
IORING_OP_OPENAT,
IORING_OP_CLOSE,
IORING_OP_FILES_UPDATE,
IORING_OP_STATX,
IORING_OP_READ,
IORING_OP_WRITE,
IORING_OP_FADVISE,
IORING_OP_MADVISE,
IORING_OP_SEND,
IORING_OP_RECV,
IORING_OP_OPENAT2,
IORING_OP_EPOLL_CTL,
IORING_OP_SPLICE,
IORING_OP_PROVIDE_BUFFERS,
IORING_OP_REMOVE_BUFFERS,
IORING_OP_TEE,
IORING_OP_SHUTDOWN,
IORING_OP_RENAMEAT,
IORING_OP_UNLINKAT,
IORING_OP_MKDIRAT,
IORING_OP_SYMLINKAT,
IORING_OP_LINKAT,
IORING_OP_LAST,
}
pub const IORING_FSYNC_DATASYNC: libc::__u32 = 1 << 0;
pub const IORING_TIMEOUT_ABS: libc::__u32 = 1 << 0;
pub const IORING_TIMEOUT_UPDATE: libc::__u32 = 1 << 1;
pub const IORING_TIMEOUT_BOOTTIME: libc::__u32 = 1 << 2;
pub const IORING_TIMEOUT_REALTIME: libc::__u32 = 1 << 3;
pub const IORING_LINK_TIMEOUT_UPDATE: libc::__u32 = 1 << 4;
pub const IORING_TIMEOUT_ETIME_SUCCESS: libc::__u32 = 1 << 5;
pub const IORING_TIMEOUT_CLOCK_MASK: libc::__u32 =
IORING_TIMEOUT_BOOTTIME | IORING_TIMEOUT_REALTIME;
pub const IORING_TIMEOUT_UPDATE_MASK: libc::__u32 =
IORING_TIMEOUT_UPDATE | IORING_LINK_TIMEOUT_UPDATE;
pub const SPLICE_F_FD_IN_FIXED: libc::__u32 = 1 << 31;
pub const IORING_POLL_ADD_MULTI: libc::__u32 = 1 << 0;
pub const IORING_POLL_UPDATE_EVENTS: libc::__u32 = 1 << 1;
pub const IORING_POLL_UPDATE_USER_DATA: libc::__u32 = 1 << 2;
#[repr(C)]
pub struct io_uring_cqe {
pub user_data: libc::__u64,
pub res: libc::__s32,
pub flags: libc::__u32,
}
pub const IORING_CQE_F_BUFFER: libc::__u32 = 1 << 0;
pub const IORING_CQE_F_MORE: libc::__u32 = 1 << 1;
pub const IORING_CQE_BUFFER_SHIFT: libc::c_int = 16;
pub const IORING_OFF_SQ_RING: libc::__u64 = 0;
pub const IORING_OFF_CQ_RING: libc::__u64 = 0x8000000;
pub const IORING_OFF_SQES: libc::__u64 = 0x10000000;
#[repr(C)]
pub struct io_sqring_offsets {
pub head: libc::__u32,
pub tail: libc::__u32,
pub ring_mask: libc::__u32,
pub ring_entries: libc::__u32,
pub flags: libc::__u32,
pub dropped: libc::__u32,
pub array: libc::__u32,
pub resv1: libc::__u32,
pub resv2: libc::__u64,
}
pub const IORING_SQ_NEED_WAKEUP: libc::c_uint = 1 << 0;
pub const IORING_SQ_CQ_OVERFLOW: libc::c_uint = 1 << 1;
#[repr(C)]
pub struct io_cqring_offsets {
pub head: libc::__u32,
pub tail: libc::__u32,
pub ring_mask: libc::__u32,
pub ring_entries: libc::__u32,
pub overflow: libc::__u32,
pub cqes: libc::__u32,
pub flags: libc::__u32,
pub resv1: libc::__u32,
pub resv2: libc::__u64,
}
pub const IORING_CQ_EVENTFD_DISABLED: libc::c_uint = 1 << 0;
pub const IORING_ENTER_GETEVENTS: libc::c_uint = 1 << 0;
pub const IORING_ENTER_SQ_WAKEUP: libc::c_uint = 1 << 1;
pub const IORING_ENTER_SQ_WAIT: libc::c_uint = 1 << 2;
pub const IORING_ENTER_EXT_ARG: libc::c_uint = 1 << 3;
#[repr(C)]
pub struct io_uring_params {
pub sq_entries: libc::__u32,
pub cq_entries: libc::__u32,
pub flags: libc::__u32,
pub sq_thread_cpu: libc::__u32,
pub sq_thread_idle: libc::__u32,
pub features: libc::__u32,
pub wq_fd: libc::__u32,
pub resv: [libc::__u32; 3],
pub sq_off: io_sqring_offsets,
pub cq_off: io_cqring_offsets,
}
pub const IORING_FEAT_SINGLE_MMAP: libc::__u32 = 1 << 0;
pub const IORING_FEAT_NODROP: libc::__u32 = 1 << 1;
pub const IORING_FEAT_SUBMIT_STABLE: libc::__u32 = 1 << 2;
pub const IORING_FEAT_RW_CUR_POS: libc::__u32 = 1 << 3;
pub const IORING_FEAT_CUR_PERSONALITY: libc::__u32 = 1 << 4;
pub const IORING_FEAT_FAST_POLL: libc::__u32 = 1 << 5;
pub const IORING_FEAT_POLL_32BITS: libc::__u32 = 1 << 6;
pub const IORING_FEAT_SQPOLL_NONFIXED: libc::__u32 = 1 << 7;
pub const IORING_FEAT_EXT_ARG: libc::__u32 = 1 << 8;
pub const IORING_FEAT_NATIVE_WORKERS: libc::__u32 = 1 << 9;
pub const IORING_FEAT_RSRC_TAGS: libc::__u32 = 1 << 10;
pub const IORING_FEAT_CQE_SKIP: libc::__u32 = 1 << 11;
pub const IORING_FEAT_LINKED_FILE: libc::__u32 = 1 << 12;
#[repr(C)]
#[non_exhaustive]
#[allow(nonstandard_style)]
#[derive(Clone, Copy, Debug)]
pub enum IoUringRegisterOp {
IORING_REGISTER_BUFFERS = 0,
IORING_UNREGISTER_BUFFERS = 1,
IORING_REGISTER_FILES = 2,
IORING_UNREGISTER_FILES = 3,
IORING_REGISTER_EVENTFD = 4,
IORING_UNREGISTER_EVENTFD = 5,
IORING_REGISTER_FILES_UPDATE = 6,
IORING_REGISTER_EVENTFD_ASYNC = 7,
IORING_REGISTER_PROBE = 8,
IORING_REGISTER_PERSONALITY = 9,
IORING_UNREGISTER_PERSONALITY = 10,
IORING_REGISTER_RESTRICTIONS = 11,
IORING_REGISTER_ENABLE_RINGS = 12,
IORING_REGISTER_FILES2 = 13,
IORING_REGISTER_FILES_UPDATE2 = 14,
IORING_REGISTER_BUFFERS2 = 15,
IORING_REGISTER_BUFFERS_UPDATE = 16,
IORING_REGISTER_IOWQ_AFF = 17,
IORING_UNREGISTER_IOWQ_AFF = 18,
IORING_REGISTER_IOWQ_MAX_WORKERS = 19,
IORING_REGISTER_LAST,
}
pub const IO_WQ_BOUND: usize = 0;
pub const IO_WQ_UNBOUND: usize = 1;
#[repr(C, align(8))]
pub struct io_uring_rsrc_register {
nr: libc::__u32,
resv: libc::__u32,
resv2: libc::__u64,
data: libc::__u64,
tags: libc::__u64,
}
#[repr(C, align(8))]
pub struct io_uring_rsrc_update {
offset: libc::__u32,
resv: libc::__u32,
data: libc::__u64,
}
#[repr(C, align(8))]
pub struct io_uring_rsrc_update2 {
offset: libc::__u32,
resv: libc::__u32,
data: libc::__u64,
tags: libc::__u64,
nr: libc::__u32,
resv2: libc::__u32,
}
pub const IORING_REGISTER_FILES_SKIP: libc::c_int = -2;
#[repr(C)]
pub struct io_uring_probe_op {
op: libc::__u8,
resv: libc::__u8,
flags: libc::__u16,
resv2: libc::__u32,
}
#[repr(C)]
pub struct io_uring_probe {
last_op: libc::__u8,
ops_len: libc::__u8,
resv: libc::__u16,
resv2: [libc::__u32; 3],
ops: [io_uring_probe_op; 0],
}
#[repr(C)]
pub struct io_uring_restriction {
opcode: libc::__u16,
op_flags: io_uring_restriction_op_flags,
resv: libc::__u8,
resv2: [libc::__u32; 3],
}
#[repr(C)]
pub union io_uring_restriction_op_flags {
register_op: libc::__u8,
sqe_op: libc::__u8,
sqe_flags: libc::__u8,
}
#[repr(u16)]
#[non_exhaustive]
#[allow(nonstandard_style)]
#[derive(Clone, Copy, Debug)]
pub enum IoUringRestrictionOpcode {
IORING_RESTRICTION_REGISTER_OP = 0,
IORING_RESTRICTION_SQE_OP = 1,
IORING_RESTRICTION_SQE_FLAGS_ALLOWED = 2,
IORING_RESTRICTION_SQE_FLAGS_REQUIRED = 3,
}
#[repr(C)]
pub struct io_uring_getevents_arg {
sigmask: libc::__u64,
sigmask_sz: libc::__u32,
pad: libc::__u32,
ts: libc::__u64,
}