|
1 | | -use std::io::{IoSlice, IoSliceMut}; |
2 | | - |
3 | 1 | use io_uring::{ |
4 | 2 | opcode, |
5 | 3 | squeue::Entry, |
6 | 4 | types::{Fd, FsyncFlags}, |
7 | 5 | }; |
8 | | -use libc::{sockaddr_storage, socklen_t}; |
9 | | -use socket2::SockAddr; |
| 6 | +use libc::sockaddr_storage; |
10 | 7 |
|
| 8 | +pub use crate::driver::unix::op::*; |
11 | 9 | use crate::{ |
12 | | - buf::{AsIoSlices, AsIoSlicesMut, IntoInner, IoBuf, IoBufMut, OneOrVec}, |
13 | | - driver::{OpCode, RawFd}, |
| 10 | + buf::{AsIoSlices, AsIoSlicesMut, IoBuf, IoBufMut}, |
| 11 | + driver::OpCode, |
14 | 12 | op::*, |
15 | 13 | }; |
16 | 14 |
|
@@ -44,29 +42,6 @@ impl OpCode for Sync { |
44 | 42 | } |
45 | 43 | } |
46 | 44 |
|
47 | | -/// Accept a connection. |
48 | | -pub struct Accept { |
49 | | - pub(crate) fd: RawFd, |
50 | | - pub(crate) buffer: sockaddr_storage, |
51 | | - pub(crate) addr_len: socklen_t, |
52 | | -} |
53 | | - |
54 | | -impl Accept { |
55 | | - /// Create [`Accept`]. |
56 | | - pub fn new(fd: RawFd) -> Self { |
57 | | - Self { |
58 | | - fd, |
59 | | - buffer: unsafe { std::mem::zeroed() }, |
60 | | - addr_len: std::mem::size_of::<sockaddr_storage>() as _, |
61 | | - } |
62 | | - } |
63 | | - |
64 | | - /// Get the remote address from the inner buffer. |
65 | | - pub fn into_addr(self) -> SockAddr { |
66 | | - unsafe { SockAddr::new(self.buffer, self.addr_len) } |
67 | | - } |
68 | | -} |
69 | | - |
70 | 45 | impl OpCode for Accept { |
71 | 46 | fn create_entry(&mut self) -> Entry { |
72 | 47 | opcode::Accept::new( |
@@ -108,96 +83,18 @@ impl<T: AsIoSlices> OpCode for SendImpl<T> { |
108 | 83 | } |
109 | 84 | } |
110 | 85 |
|
111 | | -/// Receive data and source address. |
112 | | -pub struct RecvFromImpl<T: AsIoSlicesMut> { |
113 | | - pub(crate) fd: RawFd, |
114 | | - pub(crate) buffer: T, |
115 | | - pub(crate) addr: sockaddr_storage, |
116 | | - pub(crate) slices: OneOrVec<IoSliceMut<'static>>, |
117 | | - msg: libc::msghdr, |
118 | | -} |
119 | | - |
120 | | -impl<T: AsIoSlicesMut> RecvFromImpl<T> { |
121 | | - /// Create [`RecvFrom`] or [`RecvFromVectored`]. |
122 | | - pub fn new(fd: RawFd, buffer: T::Inner) -> Self { |
123 | | - Self { |
124 | | - fd, |
125 | | - buffer: T::new(buffer), |
126 | | - addr: unsafe { std::mem::zeroed() }, |
127 | | - slices: OneOrVec::One(IoSliceMut::new(&mut [])), |
128 | | - msg: unsafe { std::mem::zeroed() }, |
129 | | - } |
130 | | - } |
131 | | -} |
132 | | - |
133 | | -impl<T: AsIoSlicesMut> IntoInner for RecvFromImpl<T> { |
134 | | - type Inner = (T, sockaddr_storage, socklen_t); |
135 | | - |
136 | | - fn into_inner(self) -> Self::Inner { |
137 | | - (self.buffer, self.addr, self.msg.msg_namelen) |
138 | | - } |
139 | | -} |
140 | | - |
141 | 86 | impl<T: AsIoSlicesMut> OpCode for RecvFromImpl<T> { |
142 | 87 | #[allow(clippy::no_effect)] |
143 | 88 | fn create_entry(&mut self) -> Entry { |
144 | | - self.slices = unsafe { self.buffer.as_io_slices_mut() }; |
145 | | - self.msg = libc::msghdr { |
146 | | - msg_name: &mut self.addr as *mut _ as _, |
147 | | - msg_namelen: 128, |
148 | | - msg_iov: self.slices.as_mut_ptr() as _, |
149 | | - msg_iovlen: self.slices.len(), |
150 | | - msg_control: std::ptr::null_mut(), |
151 | | - msg_controllen: 0, |
152 | | - msg_flags: 0, |
153 | | - }; |
| 89 | + self.set_msg(); |
154 | 90 | opcode::RecvMsg::new(Fd(self.fd), &mut self.msg).build() |
155 | 91 | } |
156 | 92 | } |
157 | 93 |
|
158 | | -/// Send data to specified address. |
159 | | -pub struct SendToImpl<T: AsIoSlices> { |
160 | | - pub(crate) fd: RawFd, |
161 | | - pub(crate) buffer: T, |
162 | | - pub(crate) addr: SockAddr, |
163 | | - pub(crate) slices: OneOrVec<IoSlice<'static>>, |
164 | | - msg: libc::msghdr, |
165 | | -} |
166 | | - |
167 | | -impl<T: AsIoSlices> SendToImpl<T> { |
168 | | - /// Create [`SendTo`] or [`SendToVectored`]. |
169 | | - pub fn new(fd: RawFd, buffer: T::Inner, addr: SockAddr) -> Self { |
170 | | - Self { |
171 | | - fd, |
172 | | - buffer: T::new(buffer), |
173 | | - addr, |
174 | | - slices: OneOrVec::One(IoSlice::new(&[])), |
175 | | - msg: unsafe { std::mem::zeroed() }, |
176 | | - } |
177 | | - } |
178 | | -} |
179 | | - |
180 | | -impl<T: AsIoSlices> IntoInner for SendToImpl<T> { |
181 | | - type Inner = T; |
182 | | - |
183 | | - fn into_inner(self) -> Self::Inner { |
184 | | - self.buffer |
185 | | - } |
186 | | -} |
187 | | - |
188 | 94 | impl<T: AsIoSlices> OpCode for SendToImpl<T> { |
189 | 95 | #[allow(clippy::no_effect)] |
190 | 96 | fn create_entry(&mut self) -> Entry { |
191 | | - self.slices = unsafe { self.buffer.as_io_slices() }; |
192 | | - self.msg = libc::msghdr { |
193 | | - msg_name: self.addr.as_ptr() as _, |
194 | | - msg_namelen: self.addr.len(), |
195 | | - msg_iov: self.slices.as_mut_ptr() as _, |
196 | | - msg_iovlen: self.slices.len(), |
197 | | - msg_control: std::ptr::null_mut(), |
198 | | - msg_controllen: 0, |
199 | | - msg_flags: 0, |
200 | | - }; |
| 97 | + self.set_msg(); |
201 | 98 | opcode::SendMsg::new(Fd(self.fd), &self.msg).build() |
202 | 99 | } |
203 | 100 | } |
0 commit comments