feat(embassy-net): Implement wait_send_ready() + wait_recv_ready() for Raw sockets.
				
					
				
			This commit is contained in:
		
							parent
							
								
									70214fc2c2
								
							
						
					
					
						commit
						acaba50704
					
				| @ -62,6 +62,14 @@ impl<'a> RawSocket<'a> { | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     /// Wait until the socket becomes readable.
 | ||||
|     ///
 | ||||
|     /// A socket is readable when a packet has been received, or when there are queued packets in
 | ||||
|     /// the buffer.
 | ||||
|     pub async fn wait_recv_ready(&self) { | ||||
|         poll_fn(move |cx| self.poll_recv_ready(cx)).await | ||||
|     } | ||||
| 
 | ||||
|     /// Receive a datagram.
 | ||||
|     ///
 | ||||
|     /// This method will wait until a datagram is received.
 | ||||
| @ -69,6 +77,24 @@ impl<'a> RawSocket<'a> { | ||||
|         poll_fn(move |cx| self.poll_recv(buf, cx)).await | ||||
|     } | ||||
| 
 | ||||
|     /// Wait until a datagram can be read.
 | ||||
|     ///
 | ||||
|     /// When no datagram is readable, this method will return `Poll::Pending` and
 | ||||
|     /// register the current task to be notified when a datagram is received.
 | ||||
|     ///
 | ||||
|     /// When a datagram is received, this method will return `Poll::Ready`.
 | ||||
|     pub fn poll_recv_ready(&self, cx: &mut Context<'_>) -> Poll<()> { | ||||
|         self.with_mut(|s, _| { | ||||
|             if s.can_recv() { | ||||
|                 Poll::Ready(()) | ||||
|             } else { | ||||
|                 // socket buffer is empty wait until at least one byte has arrived
 | ||||
|                 s.register_recv_waker(cx.waker()); | ||||
|                 Poll::Pending | ||||
|             } | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     /// Receive a datagram.
 | ||||
|     ///
 | ||||
|     /// When no datagram is available, this method will return `Poll::Pending` and
 | ||||
| @ -85,6 +111,33 @@ impl<'a> RawSocket<'a> { | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     /// Wait until the socket becomes writable.
 | ||||
|     ///
 | ||||
|     /// A socket becomes writable when there is space in the buffer, from initial memory or after
 | ||||
|     /// dispatching datagrams on a full buffer.
 | ||||
|     pub async fn wait_send_ready(&self) { | ||||
|         poll_fn(move |cx| self.poll_send_ready(cx)).await | ||||
|     } | ||||
| 
 | ||||
|     /// Wait until a datagram can be sent.
 | ||||
|     ///
 | ||||
|     /// When no datagram can be sent (i.e. the buffer is full), this method will return
 | ||||
|     /// `Poll::Pending` and register the current task to be notified when
 | ||||
|     /// space is freed in the buffer after a datagram has been dispatched.
 | ||||
|     ///
 | ||||
|     /// When a datagram can be sent, this method will return `Poll::Ready`.
 | ||||
|     pub fn poll_send_ready(&self, cx: &mut Context<'_>) -> Poll<()> { | ||||
|         self.with_mut(|s, _| { | ||||
|             if s.can_send() { | ||||
|                 Poll::Ready(()) | ||||
|             } else { | ||||
|                 // socket buffer is full wait until a datagram has been dispatched
 | ||||
|                 s.register_send_waker(cx.waker()); | ||||
|                 Poll::Pending | ||||
|             } | ||||
|         }) | ||||
|     } | ||||
| 
 | ||||
|     /// Send a datagram.
 | ||||
|     ///
 | ||||
|     /// This method will wait until the datagram has been sent.`
 | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user