summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog7
-rw-r--r--thread.c4
-rw-r--r--vm_core.h1
3 files changed, 8 insertions, 4 deletions
diff --git a/ChangeLog b/ChangeLog
index 26a415078b..b6926cae01 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+Wed Nov 28 13:39:54 2012 KOSAKI Motohiro <kosaki.motohiro@gmail.com>
+
+ * thread.c (thread_s_new): uses main_thread->status instead of
+ th->inhibit_thread_creation for preventing thread creation.
+ * vm_core.h (rb_vm_struct): remove inhibit_thread_creation field.
+ * thread.c (rb_thread_terminate_all): ditto.
+
Wed Nov 28 13:27:29 2012 Aaron Patterson <aaron@tenderlovemaking.com>
* ext/psych/extconf.rb: use embedded libyaml if no system libyaml is
diff --git a/thread.c b/thread.c
index 473713f862..b57e539444 100644
--- a/thread.c
+++ b/thread.c
@@ -378,8 +378,6 @@ rb_thread_terminate_all(void)
/* unlock all locking mutexes */
rb_threadptr_unlock_all_locking_mutexes(th);
- vm->inhibit_thread_creation = 1;
-
retry:
thread_debug("rb_thread_terminate_all (main thread: %p)\n", (void *)th);
st_foreach(vm->living_threads, terminate_i, (st_data_t)th);
@@ -611,7 +609,7 @@ thread_s_new(int argc, VALUE *argv, VALUE klass)
rb_thread_t *th;
VALUE thread = rb_thread_alloc(klass);
- if (GET_VM()->inhibit_thread_creation)
+ if (GET_VM()->main_thread->status == THREAD_KILLED)
rb_raise(rb_eThreadError, "can't alloc thread");
rb_obj_call_init(thread, argc, argv);
diff --git a/vm_core.h b/vm_core.h
index 60f34cdc02..a3059e8c53 100644
--- a/vm_core.h
+++ b/vm_core.h
@@ -341,7 +341,6 @@ typedef struct rb_vm_struct {
VALUE thgroup_default;
int running;
- int inhibit_thread_creation;
int thread_abort_on_exception;
int trace_running;
volatile int sleeper;