From 61d510cde274a975161159d14e5b6f30cd8bd2cf Mon Sep 17 00:00:00 2001 From: Max Inden Date: Thu, 23 Nov 2023 16:13:00 +0100 Subject: [PATCH 1/2] chore: deprecate `WindowUpdateMode::OnReceive` Continuation of https://github.com/libp2p/rust-yamux/pull/120. Preparation for https://github.com/libp2p/rust-yamux/issues/175. Also removes dead-lock warning for `WindowUpdateMode::OnRead`. With the restructuring of `Connection::poll`, one reads from the socket when writing is blocked. Thus the deadlock can not occur. --- CHANGELOG.md | 7 +++++++ yamux/Cargo.toml | 3 ++- yamux/src/connection.rs | 2 ++ yamux/src/connection/stream.rs | 2 ++ yamux/src/lib.rs | 11 ++--------- 5 files changed, 15 insertions(+), 10 deletions(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 7c60beba..3bcb39c4 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -1,3 +1,10 @@ +# 0.12.1 + +- Deprecate `WindowUpdateMode::OnReceive`. + It does not enforce flow-control, i.e. breaks backpressure. + Use `WindowUpdateMode::OnRead` instead. + See [PR #XXX](https://github.com/libp2p/rust-yamux/pull/XXX). + # 0.12.0 - Remove `Control` and `ControlledConnection`. diff --git a/yamux/Cargo.toml b/yamux/Cargo.toml index 431bd6c7..3c83a856 100644 --- a/yamux/Cargo.toml +++ b/yamux/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "yamux" -version = "0.12.0" +version = "0.12.1" authors = ["Parity Technologies "] license = "Apache-2.0 OR MIT" description = "Multiplexer over reliable, ordered connections" @@ -20,3 +20,4 @@ pin-project = "1.1.0" [dev-dependencies] quickcheck = "1.0" +futures = { version = "0.3.12", default-features = false, features = ["executor"] } diff --git a/yamux/src/connection.rs b/yamux/src/connection.rs index 52004d04..43e1fdbf 100644 --- a/yamux/src/connection.rs +++ b/yamux/src/connection.rs @@ -650,6 +650,7 @@ impl Active { shared.window = shared.window.saturating_sub(frame.body_len()); shared.buffer.push(frame.into_body()); + #[allow(deprecated)] if matches!(self.config.window_update_mode, WindowUpdateMode::OnReceive) { if let Some(credit) = shared.next_window_update() { shared.window += credit; @@ -695,6 +696,7 @@ impl Active { if let Some(w) = shared.reader.take() { w.wake() } + #[allow(deprecated)] if matches!(self.config.window_update_mode, WindowUpdateMode::OnReceive) { if let Some(credit) = shared.next_window_update() { shared.window += credit; diff --git a/yamux/src/connection/stream.rs b/yamux/src/connection/stream.rs index c2d8396c..fca448e1 100644 --- a/yamux/src/connection/stream.rs +++ b/yamux/src/connection/stream.rs @@ -202,6 +202,7 @@ impl Stream { fn send_window_update(&mut self, cx: &mut Context) -> Poll> { // When using [`WindowUpdateMode::OnReceive`] window update messages are // send early on data receival (see [`crate::Connection::on_frame`]). + #[allow(deprecated)] if matches!(self.config.window_update_mode, WindowUpdateMode::OnReceive) { return Poll::Ready(Ok(())); } @@ -500,6 +501,7 @@ impl Shared { } let new_credit = match self.config.window_update_mode { + #[allow(deprecated)] WindowUpdateMode::OnReceive => { debug_assert!(self.config.receive_window >= self.window); diff --git a/yamux/src/lib.rs b/yamux/src/lib.rs index 3ee8c1ad..556ffeb2 100644 --- a/yamux/src/lib.rs +++ b/yamux/src/lib.rs @@ -73,20 +73,13 @@ pub enum WindowUpdateMode { /// data in its buffer which may reach its limit (see `set_max_buffer_size`). /// In this mode, window updates merely prevent head of line blocking but do not /// effectively exercise back pressure on senders. + #[deprecated(note = "Use `WindowUpdateMode::OnRead` instead.")] OnReceive, /// Send window updates only when data is read on the receiving end. /// /// This ensures that senders do not overwhelm receivers and keeps buffer usage - /// low. However, depending on the protocol, there is a risk of deadlock, namely - /// if both endpoints want to send data larger than the receivers window and they - /// do not read before finishing their writes. Use this mode only if you are sure - /// that this will never happen, i.e. if - /// - /// - Endpoints *A* and *B* never write at the same time, *or* - /// - Endpoints *A* and *B* write at most *n* frames concurrently such that the sum - /// of the frame lengths is less or equal to the available credit of *A* and *B* - /// respectively. + /// low. OnRead, } From 70cad4dfba106964149662aa1927f0a08990eae2 Mon Sep 17 00:00:00 2001 From: Max Inden Date: Thu, 23 Nov 2023 16:16:37 +0100 Subject: [PATCH 2/2] Update CHANGELOG.md --- CHANGELOG.md | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/CHANGELOG.md b/CHANGELOG.md index 3bcb39c4..54a23602 100644 --- a/CHANGELOG.md +++ b/CHANGELOG.md @@ -3,7 +3,7 @@ - Deprecate `WindowUpdateMode::OnReceive`. It does not enforce flow-control, i.e. breaks backpressure. Use `WindowUpdateMode::OnRead` instead. - See [PR #XXX](https://github.com/libp2p/rust-yamux/pull/XXX). + See [PR #177](https://github.com/libp2p/rust-yamux/pull/177). # 0.12.0