mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* load.c (load_lock): reverted.
* thread.c (rb_barrier_wait): check for recursive wait. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@14593 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
162cc94d15
commit
97cdb5ac25
3 changed files with 10 additions and 2 deletions
|
@ -1,3 +1,9 @@
|
||||||
|
Mon Dec 24 17:59:29 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||||
|
|
||||||
|
* load.c (load_lock): reverted.
|
||||||
|
|
||||||
|
* thread.c (rb_barrier_wait): check for recursive wait.
|
||||||
|
|
||||||
Mon Dec 24 17:50:54 2007 Tanaka Akira <akr@fsij.org>
|
Mon Dec 24 17:50:54 2007 Tanaka Akira <akr@fsij.org>
|
||||||
|
|
||||||
* eval.c (function_call_may_return_twice_jmp_buf): removed.
|
* eval.c (function_call_may_return_twice_jmp_buf): removed.
|
||||||
|
|
3
load.c
3
load.c
|
@ -345,8 +345,7 @@ load_lock(const char *ftptr)
|
||||||
st_insert(loading_tbl, (st_data_t)ftptr, data);
|
st_insert(loading_tbl, (st_data_t)ftptr, data);
|
||||||
return (char *)ftptr;
|
return (char *)ftptr;
|
||||||
}
|
}
|
||||||
rb_barrier_wait((VALUE)data);
|
return RTEST(rb_barrier_wait((VALUE)data)) ? (char *)ftptr : 0;
|
||||||
return 0;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
|
|
3
thread.c
3
thread.c
|
@ -2555,6 +2555,9 @@ rb_barrier_wait(VALUE self)
|
||||||
if (thlist_signal(&barrier->waiting, 1, &barrier->owner)) return Qfalse;
|
if (thlist_signal(&barrier->waiting, 1, &barrier->owner)) return Qfalse;
|
||||||
return Qtrue;
|
return Qtrue;
|
||||||
}
|
}
|
||||||
|
else if (barrier->owner == GET_THREAD()) {
|
||||||
|
return Qfalse;
|
||||||
|
}
|
||||||
else {
|
else {
|
||||||
*barrier->tail = q = ALLOC(rb_thread_list_t);
|
*barrier->tail = q = ALLOC(rb_thread_list_t);
|
||||||
q->th = GET_THREAD();
|
q->th = GET_THREAD();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue