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
mod squeue;
mod cqueue;
use std::io;
use parking_lot::Mutex;
pub use squeue::SubmissionQueue;
pub use cqueue::CompletionQueue;
pub struct IoUring {
ring: crate::IoUring,
push_lock: Mutex<()>
}
unsafe impl Send for IoUring {}
unsafe impl Sync for IoUring {}
impl IoUring {
pub(crate) fn new(ring: crate::IoUring) -> IoUring {
IoUring {
ring,
push_lock: Mutex::new(())
}
}
#[inline]
pub unsafe fn enter(&self, to_submit: u32, min_complete: u32, flag: u32, sig: Option<&libc::sigset_t>)
-> io::Result<usize>
{
self.ring.enter(to_submit, min_complete, flag, sig)
}
#[inline]
pub fn submit(&self) -> io::Result<usize> {
self.ring.submit()
}
#[inline]
pub fn submit_and_wait(&self, want: usize) -> io::Result<usize> {
self.ring.submit_and_wait(want)
}
pub fn submission(&self) -> SubmissionQueue<'_> {
unsafe {
SubmissionQueue {
queue: &self.ring.sq,
push_lock: &self.push_lock,
ring_mask: self.ring.sq.ring_mask.read(),
ring_entries: self.ring.sq.ring_entries.read(),
}
}
}
pub fn completion(&self) -> CompletionQueue<'_> {
unsafe {
CompletionQueue {
queue: &self.ring.cq,
ring_mask: self.ring.cq.ring_mask.read(),
ring_entries: self.ring.cq.ring_entries.read()
}
}
}
pub fn into_inner(self) -> crate::IoUring {
self.ring
}
}