* 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
This commit is contained in:
parent
dd8e5a9d31
commit
9d29825355
@ -1,3 +1,9 @@
|
|||||||
|
Tue Sep 17 21:06:04 2002 Nobuyoshi Nakada <nobu.nokada@softhome.net>
|
||||||
|
|
||||||
|
* eval.c (rb_thread_die): put thread dead state.
|
||||||
|
|
||||||
|
* eval.c (rb_thread_atfork): free stack buffer at fork too.
|
||||||
|
|
||||||
Tue Sep 17 01:13:31 2002 Yukihiro Matsumoto <matz@ruby-lang.org>
|
Tue Sep 17 01:13:31 2002 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||||
|
|
||||||
* eval.c (rb_mod_nesting): load wrapping module should appear in
|
* eval.c (rb_mod_nesting): load wrapping module should appear in
|
||||||
|
18
eval.c
18
eval.c
@ -7758,6 +7758,16 @@ 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
|
static void
|
||||||
rb_thread_remove(th)
|
rb_thread_remove(th)
|
||||||
rb_thread_t th;
|
rb_thread_t th;
|
||||||
@ -7765,12 +7775,9 @@ rb_thread_remove(th)
|
|||||||
if (th->status == THREAD_KILLED) return;
|
if (th->status == THREAD_KILLED) return;
|
||||||
|
|
||||||
rb_thread_ready(th);
|
rb_thread_ready(th);
|
||||||
th->status = THREAD_KILLED;
|
rb_thread_die(th);
|
||||||
th->gid = 0;
|
|
||||||
th->prev->next = th->next;
|
th->prev->next = th->next;
|
||||||
th->next->prev = th->prev;
|
th->next->prev = th->prev;
|
||||||
if (th->stk_ptr) free(th->stk_ptr);
|
|
||||||
th->stk_ptr = 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int
|
static int
|
||||||
@ -9186,8 +9193,7 @@ rb_thread_atfork()
|
|||||||
if (rb_thread_alone()) return;
|
if (rb_thread_alone()) return;
|
||||||
FOREACH_THREAD(th) {
|
FOREACH_THREAD(th) {
|
||||||
if (th != curr_thread) {
|
if (th != curr_thread) {
|
||||||
th->gid = 0;
|
rb_thread_die(th);
|
||||||
th->status = THREAD_KILLED;
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
END_FOREACH(th);
|
END_FOREACH(th);
|
||||||
|
Loading…
x
Reference in New Issue
Block a user