public inbox for cygwin-cvs@sourceware.org
help / color / mirror / Atom feed
* [newlib-cygwin/cygwin-3_4-branch] Cygwin: pty: Fix reading CONIN$ when stdin is not a pty.
@ 2023-04-14  3:37 Takashi Yano
  0 siblings, 0 replies; only message in thread
From: Takashi Yano @ 2023-04-14  3:37 UTC (permalink / raw)
  To: cygwin-cvs

https://sourceware.org/git/gitweb.cgi?p=newlib-cygwin.git;h=595fcb21ffc01b3469dad6484c11ebfd263d7f3c

commit 595fcb21ffc01b3469dad6484c11ebfd263d7f3c
Author: Takashi Yano <takashi.yano@nifty.ne.jp>
Date:   Fri Apr 14 10:52:08 2023 +0900

    Cygwin: pty: Fix reading CONIN$ when stdin is not a pty.
    
    Previously, the pty master sends inputs to the pipe for cygwin app
    even when pseudo console is activated if stdin is not the pty.
    This causes the problem that key input is not sent to non cygwin
    app even if the app opens CONIN$. This patch sets switch_to_nat_pipe
    to true regardless whether stdin is the pty or not to allow that case.
    
    https://cygwin.com/pipermail/cygwin/2023-April/253424.html
    
    Reported-by: Wladislav Artsimovich <cygwin@frost.kiwi>
    Signed-off-by: Takashi Yano <takashi.yano@nifty.ne.jp>

Diff:
---
 winsup/cygwin/fhandler/pty.cc | 6 ++++++
 winsup/cygwin/release/3.4.7   | 3 +++
 2 files changed, 9 insertions(+)

diff --git a/winsup/cygwin/fhandler/pty.cc b/winsup/cygwin/fhandler/pty.cc
index e9a379b1c..aa7ceb0ba 100644
--- a/winsup/cygwin/fhandler/pty.cc
+++ b/winsup/cygwin/fhandler/pty.cc
@@ -3274,6 +3274,11 @@ fhandler_pty_slave::setup_pseudoconsole ()
       return false;
     }
 
+  /* Set switch_to_nat_pipe regardless whether stdin is the pty or not
+     so that the non-cygwin app can work when it opens CONIN$. */
+  bool switch_to_nat_pipe_orig = get_ttyp ()->switch_to_nat_pipe;
+  get_ttyp ()->switch_to_nat_pipe = true;
+
   HANDLE hpConIn, hpConOut;
   if (get_ttyp ()->pcon_activated)
     { /* The pseudo console is already activated. */
@@ -3551,6 +3556,7 @@ cleanup_pseudo_console:
       CloseHandle (tmp);
     }
 fallback:
+  get_ttyp ()->switch_to_nat_pipe = switch_to_nat_pipe_orig;
   return false;
 }
 
diff --git a/winsup/cygwin/release/3.4.7 b/winsup/cygwin/release/3.4.7
index 2c305ec5f..941519ebc 100644
--- a/winsup/cygwin/release/3.4.7
+++ b/winsup/cygwin/release/3.4.7
@@ -9,3 +9,6 @@ Bug Fixes
 
 - Align behaviour of dirname in terms of leading slashes to POSIX:
   https://pubs.opengroup.org/onlinepubs/9699919799/basedefs/V1_chap04.html
+
+- Fix reading CONIN$ in non cygwin apps when stdin is not a pty.
+  Addresses https://cygwin.com/pipermail/cygwin/2023-April/253424.html

^ permalink raw reply	[flat|nested] only message in thread

only message in thread, other threads:[~2023-04-14  3:37 UTC | newest]

Thread overview: (only message) (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2023-04-14  3:37 [newlib-cygwin/cygwin-3_4-branch] Cygwin: pty: Fix reading CONIN$ when stdin is not a pty Takashi Yano

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for read-only IMAP folder(s) and NNTP newsgroup(s).