aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authornobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-11-13 02:31:16 +0000
committernobu <nobu@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-11-13 02:31:16 +0000
commit5136031055433d1eba6a77353fa842f5adfc3dc4 (patch)
treeff01030051ddb6d18d8fd24c9e4f1d171b974ef6
parent31f16d772933e0faaca29256b720e944fdf060d6 (diff)
downloadruby-5136031055433d1eba6a77353fa842f5adfc3dc4.tar.gz
* thread.c (rb_barrier_wait): gets rid of recursive deadlock.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@20230 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog4
-rw-r--r--thread.c3
2 files changed, 7 insertions, 0 deletions
diff --git a/ChangeLog b/ChangeLog
index a63ba63897..4431f73448 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,7 @@
+Thu Nov 13 11:31:13 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
+
+ * thread.c (rb_barrier_wait): gets rid of recursive deadlock.
+
Thu Nov 13 06:08:44 2008 Nobuyoshi Nakada <nobu@ruby-lang.org>
* thread.c (rb_barrier_{new,wait,release,destroy}): use Mutex so that
diff --git a/thread.c b/thread.c
index 55f749ed18..f49e2e2e4d 100644
--- a/thread.c
+++ b/thread.c
@@ -3050,8 +3050,11 @@ VALUE
rb_barrier_wait(VALUE self)
{
VALUE mutex = (VALUE)DATA_PTR(self);
+ mutex_t *m;
if (!mutex) return Qfalse;
+ GetMutexPtr(mutex, m);
+ if (m->th == GET_THREAD()) return Qfalse;
rb_mutex_lock(mutex);
if (DATA_PTR(self)) return Qtrue;
rb_mutex_unlock(mutex);