summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorFelix Fietkau <nbd@openwrt.org>2007-05-06 17:53:16 +0000
committerFelix Fietkau <nbd@openwrt.org>2007-05-06 17:53:16 +0000
commit7e7144602f634be53742828f965b6c58a8ee15f0 (patch)
tree2a1e8ffff793dfd5a749f12279165d0606263c5c
parent9cea5657af95db168a097ccfbc94bb1ae3374fec (diff)
downloadmaster-31e0f0ae-7e7144602f634be53742828f965b6c58a8ee15f0.tar.gz
master-31e0f0ae-7e7144602f634be53742828f965b6c58a8ee15f0.tar.bz2
master-31e0f0ae-7e7144602f634be53742828f965b6c58a8ee15f0.zip
prevent dropbear from closing the tty prematurely if the readfd closes
SVN-Revision: 7117
-rw-r--r--package/dropbear/patches/160-tty_close.patch19
1 files changed, 19 insertions, 0 deletions
diff --git a/package/dropbear/patches/160-tty_close.patch b/package/dropbear/patches/160-tty_close.patch
new file mode 100644
index 0000000000..01b6251b86
--- /dev/null
+++ b/package/dropbear/patches/160-tty_close.patch
@@ -0,0 +1,19 @@
+diff -ur db.old/common-channel.c db.dev/common-channel.c
+--- db.old/common-channel.c 2007-02-22 17:17:15.000000000 +0100
++++ db.dev/common-channel.c 2007-05-06 19:50:19.154943528 +0200
+@@ -309,15 +309,6 @@
+ && (ERRFD_IS_WRITE(channel) || channel->errfd == FD_CLOSED)) {
+ send_msg_channel_eof(channel);
+ }
+-
+- /* And if we can't receive any more data from them either, close up */
+- if (!channel->sent_close
+- && channel->readfd == FD_CLOSED
+- && (ERRFD_IS_WRITE(channel) || channel->errfd == FD_CLOSED)
+- && !write_pending(channel)) {
+- TRACE(("sending close, readfd is closed"))
+- send_msg_channel_close(channel);
+- }
+ }
+
+ /* Check whether a deferred (EINPROGRESS) connect() was successful, and