summaryrefslogtreecommitdiff
path: root/eval.c
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2002-09-17 12:07:36 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2002-09-17 12:07:36 +0000
commit9d298253558e899e85e4363358a30f41db95aafb (patch)
treee08880f9327b981289e2024d33930f45dfb83c7f /eval.c
parentdd8e5a9d317ed06237c493edb3954487507ff431 (diff)
* eval.c (rb_thread_die): put thread dead state.
* eval.c (rb_thread_atfork): free stack buffer at fork too. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@2872 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'eval.c')
-rw-r--r--eval.c18
1 files changed, 12 insertions, 6 deletions
diff --git a/eval.c b/eval.c
index 14915d6..94067fc 100644
--- a/eval.c
+++ b/eval.c
@@ -7759,18 +7759,25 @@ rb_thread_ready(th)
}
static void
+rb_thread_die(th)
+ rb_thread_t th;
+{
+ th->gid = 0;
+ th->status = THREAD_KILLED;
+ if (th->stk_ptr) free(th->stk_ptr);
+ th->stk_ptr = 0;
+}
+
+static void
rb_thread_remove(th)
rb_thread_t th;
{
if (th->status == THREAD_KILLED) return;
rb_thread_ready(th);
- th->status = THREAD_KILLED;
- th->gid = 0;
+ rb_thread_die(th);
th->prev->next = th->next;
th->next->prev = th->prev;
- if (th->stk_ptr) free(th->stk_ptr);
- th->stk_ptr = 0;
}
static int
@@ -9186,8 +9193,7 @@ rb_thread_atfork()
if (rb_thread_alone()) return;
FOREACH_THREAD(th) {
if (th != curr_thread) {
- th->gid = 0;
- th->status = THREAD_KILLED;
+ rb_thread_die(th);
}
}
END_FOREACH(th);