浏览代码

Merge pull request #917 from copy/main

fix(tcp): only reset remote_last_ts if some data is enqueued
Dario Nieuwenhuis 1 年之前
父节点
当前提交
114939aa99
共有 1 个文件被更改,包括 9 次插入9 次删除
  1. 9 9
      src/socket/tcp.rs

+ 9 - 9
src/socket/tcp.rs

@@ -1123,21 +1123,21 @@ impl<'a> Socket<'a> {
             return Err(SendError::InvalidState);
         }
 
-        // The connection might have been idle for a long time, and so remote_last_ts
-        // would be far in the past. Unless we clear it here, we'll abort the connection
-        // down over in dispatch() by erroneously detecting it as timed out.
-        if self.tx_buffer.is_empty() {
-            self.remote_last_ts = None
-        }
-
-        let _old_length = self.tx_buffer.len();
+        let old_length = self.tx_buffer.len();
         let (size, result) = f(&mut self.tx_buffer);
         if size > 0 {
+            // The connection might have been idle for a long time, and so remote_last_ts
+            // would be far in the past. Unless we clear it here, we'll abort the connection
+            // down over in dispatch() by erroneously detecting it as timed out.
+            if old_length == 0 {
+                self.remote_last_ts = None
+            }
+
             #[cfg(any(test, feature = "verbose"))]
             tcp_trace!(
                 "tx buffer: enqueueing {} octets (now {})",
                 size,
-                _old_length + size
+                old_length + size
             );
         }
         Ok(result)