aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorChristopher Faylor <me@cgf.cx>2003-08-22 01:07:01 +0000
committerChristopher Faylor <me@cgf.cx>2003-08-22 01:07:01 +0000
commita9f7754462b24b80c88c9c8fb634c28838e46753 (patch)
tree7d3e7085304eca83e38d0f9ec95fae07b856105f
parent346c0bf9fc80a920c376063ef0c255847e630d06 (diff)
downloadnewlib-a9f7754462b24b80c88c9c8fb634c28838e46753.zip
newlib-a9f7754462b24b80c88c9c8fb634c28838e46753.tar.gz
newlib-a9f7754462b24b80c88c9c8fb634c28838e46753.tar.bz2
* sigproc.cc (wait_sig): Avoid infinite loop.
-rw-r--r--winsup/cygwin/ChangeLog4
-rw-r--r--winsup/cygwin/sigproc.cc6
2 files changed, 7 insertions, 3 deletions
diff --git a/winsup/cygwin/ChangeLog b/winsup/cygwin/ChangeLog
index e1226cf..e3a3d97 100644
--- a/winsup/cygwin/ChangeLog
+++ b/winsup/cygwin/ChangeLog
@@ -1,3 +1,7 @@
+2003-08-21 Christopher Faylor <cgf@redhat.com>
+
+ * sigproc.cc (wait_sig): Avoid infinite loop.
+
2003-08-20 Christopher Faylor <cgf@redhat.com>
* speclib: Reenable removal of temp files.
diff --git a/winsup/cygwin/sigproc.cc b/winsup/cygwin/sigproc.cc
index fe1441d..02af13a 100644
--- a/winsup/cygwin/sigproc.cc
+++ b/winsup/cygwin/sigproc.cc
@@ -1166,10 +1166,10 @@ wait_sig (VOID *self)
* array looking for any unprocessed signals.
*/
pending_signals = false;
- bool saw_failed_interrupt = false;
bool more_signals = false;
+ bool saw_failed_interrupt = false;
do
- for (int sig = -__SIGOFFSET; sig < NSIG; sig++)
+ for (int sig = -__SIGOFFSET, more_signals = false; sig < NSIG; sig++)
{
LONG x = InterlockedDecrement (todo + sig);
if (x < 0)
@@ -1232,7 +1232,7 @@ wait_sig (VOID *self)
goto out;
}
}
- while (more_signals);
+ while (more_signals && !saw_failed_interrupt);
out:
/* Signal completion of signal handling depending on which semaphore