@@ -25,7 +25,7 @@ use windows_sys::Win32::Networking::WinSock::{
25
25
self , tcp_keepalive, FIONBIO , IN6_ADDR , IN6_ADDR_0 , INVALID_SOCKET , IN_ADDR , IN_ADDR_0 ,
26
26
POLLERR , POLLHUP , POLLRDNORM , POLLWRNORM , SD_BOTH , SD_RECEIVE , SD_SEND , SIO_KEEPALIVE_VALS ,
27
27
SOCKET_ERROR , WSABUF , WSAEMSGSIZE , WSAESHUTDOWN , WSAPOLLFD , WSAPROTOCOL_INFOW ,
28
- WSA_FLAG_NO_HANDLE_INHERIT , WSA_FLAG_OVERLAPPED ,
28
+ WSA_FLAG_NO_HANDLE_INHERIT , WSA_FLAG_OVERLAPPED , WSA_FLAG_REGISTERED_IO ,
29
29
} ;
30
30
#[ cfg( feature = "all" ) ]
31
31
use windows_sys:: Win32 :: Networking :: WinSock :: {
@@ -126,16 +126,28 @@ impl Type {
126
126
/// Our custom flag to set `WSA_FLAG_NO_HANDLE_INHERIT` on socket creation.
127
127
/// Trying to mimic `Type::cloexec` on windows.
128
128
const NO_INHERIT : c_int = 1 << ( ( size_of :: < c_int > ( ) * 8 ) - 1 ) ; // Last bit.
129
+ /// Our custom flag to set `WSA_FLAG_REGISTERED_IO` on socket creation.
130
+ const REGISTERED_IO : c_int = 1 << ( ( size_of :: < c_int > ( ) * 8 ) - 2 ) ; // Second last bit.
129
131
130
132
/// Set `WSA_FLAG_NO_HANDLE_INHERIT` on the socket.
131
133
#[ cfg( feature = "all" ) ]
132
134
pub const fn no_inherit ( self ) -> Type {
133
135
self . _no_inherit ( )
134
136
}
135
137
138
+ /// Set `WSA_FLAG_REGISTERED_IO` on the socket.
139
+ #[ cfg( feature = "all" ) ]
140
+ pub const fn registered_io ( self ) -> Type {
141
+ self . _registered_io ( )
142
+ }
143
+
136
144
pub ( crate ) const fn _no_inherit ( self ) -> Type {
137
145
Type ( self . 0 | Type :: NO_INHERIT )
138
146
}
147
+
148
+ pub ( crate ) const fn _registered_io ( self ) -> Type {
149
+ Type ( self . 0 | Type :: REGISTERED_IO )
150
+ }
139
151
}
140
152
141
153
impl_debug ! (
@@ -253,13 +265,19 @@ pub(crate) fn socket_into_raw(socket: Socket) -> RawSocket {
253
265
pub ( crate ) fn socket ( family : c_int , mut ty : c_int , protocol : c_int ) -> io:: Result < RawSocket > {
254
266
init ( ) ;
255
267
256
- // Check if we set our custom flag .
268
+ // Check if we set our custom flags .
257
269
let flags = if ty & Type :: NO_INHERIT != 0 {
258
270
ty = ty & !Type :: NO_INHERIT ;
259
271
WSA_FLAG_NO_HANDLE_INHERIT
260
272
} else {
261
273
0
262
274
} ;
275
+ let flags = if ty & Type :: REGISTERED_IO != 0 {
276
+ ty = ty & !Type :: REGISTERED_IO ;
277
+ flags | WSA_FLAG_REGISTERED_IO
278
+ } else {
279
+ flags
280
+ } ;
263
281
264
282
syscall ! (
265
283
WSASocketW (
0 commit comments