[project @ 2002-02-15 14:53:32 by simonmar]
authorsimonmar <unknown>
Fri, 15 Feb 2002 14:53:32 +0000 (14:53 +0000)
committersimonmar <unknown>
Fri, 15 Feb 2002 14:53:32 +0000 (14:53 +0000)
Ensure that async exceptions are blocked during the raising of an
async exception - we're about to block them anyway on entry to the
handler, but we don't want any further exceptions being raised in the
meantime.

ghc/rts/Schedule.c

index ba6920b..63e06fa 100644 (file)
@@ -1,5 +1,5 @@
 /* ---------------------------------------------------------------------------
- * $Id: Schedule.c,v 1.125 2002/02/15 14:49:08 simonmar Exp $
+ * $Id: Schedule.c,v 1.126 2002/02/15 14:53:32 simonmar Exp $
  *
  * (c) The GHC Team, 1998-2000
  *
@@ -3090,6 +3090,14 @@ raiseAsync(StgTSO *tso, StgClosure *exception)
        */
       sp = (P_)su - 1;
 
+      /* Ensure that async excpetions are blocked now, so we don't get
+       * a surprise exception before we get around to executing the
+       * handler.
+       */
+      if (tso->blocked_exceptions == NULL) {
+         tso->blocked_exceptions = END_TSO_QUEUE;
+      }
+
       /* Put the newly-built THUNK on top of the stack, ready to execute
        * when the thread restarts.
        */