diff options
| author | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-12-24 08:59:31 +0000 |
|---|---|---|
| committer | nobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2007-12-24 08:59:31 +0000 |
| commit | 0f171b400c6183ac5ff207d470e9a05891969350 (patch) | |
| tree | cfcc2932a3999bf25a6ac7289fb91685857e1504 | |
| parent | 3a0577041c836fd4547a3046dbbb16b6cf91155c (diff) | |
| download | ruby-0f171b400c6183ac5ff207d470e9a05891969350.tar.gz ruby-0f171b400c6183ac5ff207d470e9a05891969350.tar.xz ruby-0f171b400c6183ac5ff207d470e9a05891969350.zip | |
* load.c (load_lock): reverted.
* thread.c (rb_barrier_wait): check for recursive wait.
git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@14593 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 6 | ||||
| -rw-r--r-- | load.c | 3 | ||||
| -rw-r--r-- | thread.c | 3 |
3 files changed, 10 insertions, 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> * eval.c (function_call_may_return_twice_jmp_buf): removed. @@ -345,8 +345,7 @@ load_lock(const char *ftptr) st_insert(loading_tbl, (st_data_t)ftptr, data); return (char *)ftptr; } - rb_barrier_wait((VALUE)data); - return 0; + return RTEST(rb_barrier_wait((VALUE)data)) ? (char *)ftptr : 0; } static void @@ -2555,6 +2555,9 @@ rb_barrier_wait(VALUE self) if (thlist_signal(&barrier->waiting, 1, &barrier->owner)) return Qfalse; return Qtrue; } + else if (barrier->owner == GET_THREAD()) { + return Qfalse; + } else { *barrier->tail = q = ALLOC(rb_thread_list_t); q->th = GET_THREAD(); |
