* cygwait.cc (cygwait): Remove lock around sig retrieval since this code is

essentially guarded by thread-specific signal_arrived.
* exceptions.cc (_cygtls::handle_SIGCONT): Simplify.  Eliminate lock/unlock
since code is guarded by signal_arrived.
This commit is contained in:
Christopher Faylor 2013-06-08 14:38:20 +00:00
parent ebf488e1ab
commit 5d35299e51
5 changed files with 35 additions and 39 deletions

View File

@ -1,3 +1,10 @@
2013-06-08 Christopher Faylor <me.cygwin2013@cgf.cx>
* cygwait.cc (cygwait): Remove lock around sig retrieval since this
code is essentially guarded by thread-specific signal_arrived.
* exceptions.cc (_cygtls::handle_SIGCONT): Simplify. Eliminate
lock/unlock since code is guarded by signal_arrived.
2013-06-07 Corinna Vinschen <corinna@vinschen.de> 2013-06-07 Corinna Vinschen <corinna@vinschen.de>
* winver.rc (LegalCopyright): Belatedly bump to 2013. * winver.rc (LegalCopyright): Belatedly bump to 2013.

View File

@ -81,11 +81,9 @@ cygwait (HANDLE object, PLARGE_INTEGER timeout, unsigned mask)
/* all set */; /* all set */;
else else
{ {
_my_tls.lock ();
int sig = _my_tls.sig; int sig = _my_tls.sig;
if (is_cw_sig_cont && sig == SIGCONT) if (is_cw_sig_cont && sig == SIGCONT)
_my_tls.sig = 0; _my_tls.sig = 0;
_my_tls.unlock ();
if (!sig) if (!sig)
continue; continue;
if (is_cw_sig_eintr || (is_cw_sig_cont && sig == SIGCONT)) if (is_cw_sig_eintr || (is_cw_sig_cont && sig == SIGCONT))

View File

@ -1252,38 +1252,28 @@ signal_exit (int sig, siginfo_t *si)
void void
_cygtls::handle_SIGCONT () _cygtls::handle_SIGCONT ()
{ {
if (ISSTATE (myself, PID_STOPPED)) if (NOTSTATE (myself, PID_STOPPED))
{ return;
myself->stopsig = 0;
myself->process_state &= ~PID_STOPPED; myself->stopsig = 0;
int state = 0; myself->process_state &= ~PID_STOPPED;
/* Carefully tell sig_handle_tty_stop to wake up. /* Carefully tell sig_handle_tty_stop to wake up.
Make sure that any pending signal is handled before trying to Make sure that any pending signal is handled before trying to
send a new one. Then make sure that SIGCONT has been recognized send a new one. Then make sure that SIGCONT has been recognized
before exiting the loop. */ before exiting the loop. */
while (state < 2) bool sigsent = false;
{ while (1)
lock (); if (sig) /* Assume that it's ok to just test sig outside of a
bool do_yield = !!sig; lock since setup_handler does it this way. */
if (do_yield) yield (); /* Attempt to schedule another thread. */
/* signal still being processed */; else if (sigsent)
else if (state) break; /* SIGCONT has been recognized by other thread */
state++; /* state == 2: signal no longer being processed */ else
else {
{ sig = SIGCONT;
sig = SIGCONT; SetEvent (signal_arrived); /* alert sig_handle_tty_stop */
SetEvent (signal_arrived); sigsent = true;
state++; /* state == 1: alert sig_handle_tty_stop */ }
do_yield = true; /* wake up other thread */
}
unlock ();
if (do_yield)
yield ();
}
/* Tell wait_sig to handle any queued signals now that we're alive
again. */
sig_dispatch_pending (false);
}
/* Clear pending stop signals */ /* Clear pending stop signals */
sig_clear (SIGSTOP); sig_clear (SIGSTOP);
sig_clear (SIGTSTP); sig_clear (SIGTSTP);

View File

@ -96,7 +96,7 @@ fhandler_pty_common::__acquire_output_mutex (const char *fn, int ln,
{ {
if (strace.active ()) if (strace.active ())
strace.prntf (_STRACE_TERMIOS, fn, "(%d): pty output_mutex (%p): waiting %d ms", ln, output_mutex, ms); strace.prntf (_STRACE_TERMIOS, fn, "(%d): pty output_mutex (%p): waiting %d ms", ln, output_mutex, ms);
if (ms == INFINITE) if (0 && ms == INFINITE)
ms = 100; ms = 100;
DWORD res = WaitForSingleObject (output_mutex, ms); DWORD res = WaitForSingleObject (output_mutex, ms);
if (res == WAIT_OBJECT_0) if (res == WAIT_OBJECT_0)
@ -145,6 +145,9 @@ fhandler_pty_common::__release_output_mutex (const char *fn, int ln)
void void
fhandler_pty_master::doecho (const void *str, DWORD len) fhandler_pty_master::doecho (const void *str, DWORD len)
{ {
static char buf[128 * 1024];
int buflen = process_slave_output (buf, sizeof (buf), false);
puts_readahead (buf, buflen);
acquire_output_mutex (INFINITE); acquire_output_mutex (INFINITE);
if (!WriteFile (to_master, str, len, &len, NULL)) if (!WriteFile (to_master, str, len, &len, NULL))
termios_printf ("Write to %p failed, %E", to_master); termios_printf ("Write to %p failed, %E", to_master);

View File

@ -251,10 +251,8 @@ yield ()
/* MSDN implies that SleepEx will force scheduling of other threads. /* MSDN implies that SleepEx will force scheduling of other threads.
Unlike SwitchToThread() the documentation does not mention other Unlike SwitchToThread() the documentation does not mention other
cpus so, presumably (hah!), this + using a lower priority will cpus so, presumably (hah!), this + using a lower priority will
stall this thread temporarily and cause another to run. stall this thread temporarily and cause another to run. */
Note: Don't use 0 timeout. This takes a lot of CPU if something SleepEx (0L, false);
goes wrong. */
SleepEx (1L, false);
} }
SetThreadPriority (GetCurrentThread (), prio); SetThreadPriority (GetCurrentThread (), prio);
} }