mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
fix ractor-locking around rb_ractor_thread_list()
With locking a ractor, rb_ary_push() can call RB_VM_LOCK_ENTER() and it violates an assertion: should not acquire ractor-lock.
This commit is contained in:
parent
458d5175b9
commit
7fcb6b3dbe
1 changed files with 21 additions and 9 deletions
30
ractor.c
30
ractor.c
|
@ -1672,21 +1672,33 @@ rb_ractor_living_thread_num(const rb_ractor_t *r)
|
|||
VALUE
|
||||
rb_ractor_thread_list(rb_ractor_t *r)
|
||||
{
|
||||
VALUE ary = rb_ary_new();
|
||||
rb_thread_t *th = 0;
|
||||
VALUE *ts;
|
||||
int ts_cnt;
|
||||
|
||||
RACTOR_LOCK(r);
|
||||
list_for_each(&r->threads.set, th, lt_node) {
|
||||
switch (th->status) {
|
||||
case THREAD_RUNNABLE:
|
||||
case THREAD_STOPPED:
|
||||
case THREAD_STOPPED_FOREVER:
|
||||
rb_ary_push(ary, th->self);
|
||||
default:
|
||||
break;
|
||||
{
|
||||
ts = ALLOCA_N(VALUE, r->threads.cnt);
|
||||
ts_cnt = 0;
|
||||
|
||||
list_for_each(&r->threads.set, th, lt_node) {
|
||||
switch (th->status) {
|
||||
case THREAD_RUNNABLE:
|
||||
case THREAD_STOPPED:
|
||||
case THREAD_STOPPED_FOREVER:
|
||||
ts[ts_cnt++] = th->self;
|
||||
default:
|
||||
break;
|
||||
}
|
||||
}
|
||||
}
|
||||
RACTOR_UNLOCK(r);
|
||||
|
||||
VALUE ary = rb_ary_new();
|
||||
for (int i=0; i<ts_cnt; i++) {
|
||||
rb_ary_push(ary, ts[i]);
|
||||
}
|
||||
|
||||
return ary;
|
||||
}
|
||||
|
||||
|
|
Loading…
Add table
Reference in a new issue