[前][次][番号順一覧][スレッド一覧]

ruby-changes:20178

From: nagachika <ko1@a...>
Date: Sat, 25 Jun 2011 23:29:04 +0900 (JST)
Subject: [ruby-changes:20178] nagachika:r32226 (trunk): * thread.c (sleep_forever): now Kernel#sleep don't wakeup by

nagachika	2011-06-25 23:28:56 +0900 (Sat, 25 Jun 2011)

  New Revision: 32226

  http://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=rev&revision=32226

  Log:
    * thread.c (sleep_forever): now Kernel#sleep don't wakeup by
      signal handler execution. [Bug #4072]

  Modified files:
    trunk/ChangeLog
    trunk/thread.c

Index: ChangeLog
===================================================================
--- ChangeLog	(revision 32225)
+++ ChangeLog	(revision 32226)
@@ -1,3 +1,8 @@
+Sat Jun 25 23:23:14 2011  CHIKANAGA Tomoyuki  <nagachika00@g...>
+
+	* thread.c (sleep_forever): now Kernel#sleep don't wakeup by
+	  signal handler execution. [Bug #4072]
+
 Sat Jun 25 23:14:47 2011  CHIKANAGA Tomoyuki  <nagachika00@g...>
 
 	* thread.c (rb_threadptr_check_signal): remove unnecessary th->status
Index: thread.c
===================================================================
--- thread.c	(revision 32225)
+++ thread.c	(revision 32226)
@@ -834,8 +834,9 @@
 sleep_forever(rb_thread_t *th, int deadlockable)
 {
     enum rb_thread_status prev_status = th->status;
+    enum rb_thread_status status = deadlockable ? THREAD_STOPPED_FOREVER : THREAD_STOPPED;
 
-    th->status = deadlockable ? THREAD_STOPPED_FOREVER : THREAD_STOPPED;
+    th->status = status;
     do {
 	if (deadlockable) {
 	    th->vm->sleeper++;
@@ -846,7 +847,7 @@
 	    th->vm->sleeper--;
 	}
 	RUBY_VM_CHECK_INTS();
-    } while (th->status == THREAD_STOPPED_FOREVER);
+    } while (th->status == status);
     th->status = prev_status;
 }
 

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]