aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorTakashi Yano <takashi.yano@nifty.ne.jp>2020-03-02 10:12:55 +0900
committerCorinna Vinschen <corinna@vinschen.de>2020-03-02 19:46:40 +0100
commit10d8c2782d79dd5744027e93831dd77aeab452fc (patch)
treee1fec9f1e805d16f982061fc5aca42243ea2a7be
parent7f5051d76662838103666492a33505e0801c1ee7 (diff)
downloadnewlib-10d8c2782d79dd5744027e93831dd77aeab452fc.zip
newlib-10d8c2782d79dd5744027e93831dd77aeab452fc.tar.gz
newlib-10d8c2782d79dd5744027e93831dd77aeab452fc.tar.bz2
Cygwin: console: Fix setting/unsetting xterm mode for input.
- This patch fixes the issue that xterm compatible mode for input is not correctly set/unset in some situation such as: 1) cat is stopped by ctrl-c. 2) The window size is changed in less. In case 1), request_xterm_mode_input(true) is called in read(), however, cat is stopped without request_xterm_mode_input(false). In case 2), less uses longjmp in signal handler, therefore, corresponding request_xterm_mode_input(false) is not called if the SIGWINCH signal is sent within read(). With this patch, InterlockedExchange() is used instead of InterlockedIncrement/ Decrement().
-rw-r--r--winsup/cygwin/fhandler_console.cc5
1 files changed, 3 insertions, 2 deletions
diff --git a/winsup/cygwin/fhandler_console.cc b/winsup/cygwin/fhandler_console.cc
index 7c97a78..9c5b801 100644
--- a/winsup/cygwin/fhandler_console.cc
+++ b/winsup/cygwin/fhandler_console.cc
@@ -267,7 +267,7 @@ fhandler_console::request_xterm_mode_input (bool req)
return;
if (req)
{
- if (InterlockedIncrement (&con.xterm_mode_input) == 1)
+ if (InterlockedExchange (&con.xterm_mode_input, 1) == 0)
{
DWORD dwMode;
GetConsoleMode (get_handle (), &dwMode);
@@ -277,7 +277,7 @@ fhandler_console::request_xterm_mode_input (bool req)
}
else
{
- if (InterlockedDecrement (&con.xterm_mode_input) == 0)
+ if (InterlockedExchange (&con.xterm_mode_input, 0) == 1)
{
DWORD dwMode;
GetConsoleMode (get_handle (), &dwMode);
@@ -1171,6 +1171,7 @@ fhandler_console::close ()
if ((NT_SUCCESS (status) && obi.HandleCount == 1)
|| myself->pid == con.owner)
request_xterm_mode_output (false);
+ request_xterm_mode_input (false);
}
release_output_mutex ();