summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-21 08:27:14 +0000
committerko1 <ko1@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2007-12-21 08:27:14 +0000
commit962f40ae4e01a3a90b281b41bd7093ebabeda039 (patch)
tree6ad5d66650b294806b34bf103ad6f12b11603345
parent5efe7738428d1f272eca8399c3f9b5ebef34ef9f (diff)
downloadruby-962f40ae4e01a3a90b281b41bd7093ebabeda039.tar.gz
ruby-962f40ae4e01a3a90b281b41bd7093ebabeda039.tar.xz
ruby-962f40ae4e01a3a90b281b41bd7093ebabeda039.zip
* thread.c (rb_thread_atfork): fix to mark thread object.
[ruby-dev:32404] * bootstraptest/test_knownbug.rb, test_fork.rb: move a fixed test. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@14420 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r--ChangeLog7
-rw-r--r--bootstraptest/test_fork.rb6
-rw-r--r--bootstraptest/test_knownbug.rb7
-rw-r--r--thread.c3
4 files changed, 15 insertions, 8 deletions
diff --git a/ChangeLog b/ChangeLog
index 2343db1dd..3c5ba875c 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,10 @@
+Fri Dec 21 17:25:22 2007 Koichi Sasada <ko1@atdot.net>
+
+ * thread.c (rb_thread_atfork): fix to mark thread object.
+ [ruby-dev:32404]
+
+ * bootstraptest/test_knownbug.rb, test_fork.rb: move a fixed test.
+
Fri Dec 21 17:07:13 2007 Koichi Sasada <ko1@atdot.net>
* gc.h: extern variable should not be initialized.
diff --git a/bootstraptest/test_fork.rb b/bootstraptest/test_fork.rb
new file mode 100644
index 000000000..4632ca269
--- /dev/null
+++ b/bootstraptest/test_fork.rb
@@ -0,0 +1,6 @@
+assert_equal '0', %q{
+ GC.stress = true
+ pid = fork {}
+ Process.wait pid
+ $?.to_i
+}, '[ruby-dev:32404]'
diff --git a/bootstraptest/test_knownbug.rb b/bootstraptest/test_knownbug.rb
index d52d86e6d..8b53798c2 100644
--- a/bootstraptest/test_knownbug.rb
+++ b/bootstraptest/test_knownbug.rb
@@ -3,13 +3,6 @@
# So all tests will cause failure.
#
-assert_equal '0', %q{
- GC.stress = true
- pid = fork {}
- Process.wait pid
- $?.to_i
-}, '[ruby-dev:32404]'
-
assert_equal 'ok', %q{
1.times{
eval("break")
diff --git a/thread.c b/thread.c
index 936360d5b..d4916016c 100644
--- a/thread.c
+++ b/thread.c
@@ -1974,11 +1974,12 @@ rb_thread_atfork(void)
{
rb_thread_t *th = GET_THREAD();
rb_vm_t *vm = th->vm;
+ volatile VALUE thval = th->self;
vm->main_thread = th;
st_free_table(vm->living_threads);
vm->living_threads = st_init_numtable();
- st_insert(vm->living_threads, th->self, (st_data_t) th->thread_id);
+ st_insert(vm->living_threads, thval, (st_data_t) th->thread_id);
}
struct thgroup {