Skip to content

Commit

Permalink
* thread.c (thread_cleanup_func_before_exec): extracted from
Browse files Browse the repository at this point in the history
  thread_cleanup_func not to touch pthread data.
  pthread_cond_destroy in forked process may cause deadlock on
  Debian GNU/Linux Etch on x86, x86-64 and IA64.
  this doesn't cause resource leak because the process will exec soon.
  (terminate_atfork_before_exec_i): defined.
  (rb_thread_atfork_before_exec): defined.

* include/ruby/intern.h (rb_thread_atfork_before_exec): declared.

* process.c (rb_exec_atfork): call rb_thread_atfork_before_exec
  instead of rb_thread_atfork.

* io.c (popen_exec): call rb_thread_atfork_before_exec instead of
  rb_thread_atfork.



git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@16355 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
  • Loading branch information
akr committed May 11, 2008
1 parent 4273476 commit 14a97fd
Show file tree
Hide file tree
Showing 5 changed files with 55 additions and 3 deletions.
18 changes: 18 additions & 0 deletions ChangeLog
Original file line number Diff line number Diff line change
@@ -1,3 +1,21 @@
Sun May 11 13:14:09 2008 Tanaka Akira <akr@fsij.org>

* thread.c (thread_cleanup_func_before_exec): extracted from
thread_cleanup_func not to touch pthread data.
pthread_cond_destroy in forked process may cause deadlock on
Debian GNU/Linux Etch on x86, x86-64 and IA64.
this doesn't cause resource leak because the process will exec soon.
(terminate_atfork_before_exec_i): defined.
(rb_thread_atfork_before_exec): defined.

* include/ruby/intern.h (rb_thread_atfork_before_exec): declared.

* process.c (rb_exec_atfork): call rb_thread_atfork_before_exec
instead of rb_thread_atfork.

* io.c (popen_exec): call rb_thread_atfork_before_exec instead of
rb_thread_atfork.

Sat May 10 22:14:03 2008 Yukihiro Matsumoto <matz@ruby-lang.org>

* string.c (tr_trans): single '^' does not mean negation.
Expand Down
1 change: 1 addition & 0 deletions include/ruby/intern.h
Original file line number Diff line number Diff line change
Expand Up @@ -308,6 +308,7 @@ VALUE rb_thread_main(void);
VALUE rb_thread_local_aref(VALUE, ID);
VALUE rb_thread_local_aset(VALUE, ID, VALUE);
void rb_thread_atfork(void);
void rb_thread_atfork_before_exec(void);
VALUE rb_exec_recursive(VALUE(*)(VALUE, VALUE, int),VALUE,VALUE);
/* file.c */
VALUE rb_file_s_expand_path(int, VALUE *);
Expand Down
2 changes: 1 addition & 1 deletion io.c
Original file line number Diff line number Diff line change
Expand Up @@ -3671,7 +3671,7 @@ popen_exec(void *pp)
{
struct popen_arg *p = (struct popen_arg*)pp;

rb_thread_atfork();
rb_thread_atfork_before_exec();
return rb_exec(p->execp);
}
#endif
Expand Down
2 changes: 1 addition & 1 deletion process.c
Original file line number Diff line number Diff line change
Expand Up @@ -2103,7 +2103,7 @@ rb_exec(const struct rb_exec_arg *e)
static int
rb_exec_atfork(void* arg)
{
rb_thread_atfork();
rb_thread_atfork_before_exec();
return rb_exec(arg);
}
#endif
Expand Down
35 changes: 34 additions & 1 deletion thread.c
Original file line number Diff line number Diff line change
Expand Up @@ -273,14 +273,21 @@ rb_thread_terminate_all(void)
}

static void
thread_cleanup_func(void *th_ptr)
thread_cleanup_func_before_exec(void *th_ptr)
{
rb_thread_t *th = th_ptr;
th->status = THREAD_KILLED;
th->machine_stack_start = th->machine_stack_end = 0;
#ifdef __ia64
th->machine_register_stack_start = th->machine_register_stack_end = 0;
#endif
}

static void
thread_cleanup_func(void *th_ptr)
{
rb_thread_t *th = th_ptr;
thread_cleanup_func_before_exec(th_ptr);
native_thread_destroy(th);
}

Expand Down Expand Up @@ -2064,6 +2071,32 @@ rb_thread_atfork(void)
st_insert(vm->living_threads, thval, (st_data_t) th->thread_id);
}

static int
terminate_atfork_before_exec_i(st_data_t key, st_data_t val, rb_thread_t *current_th)
{
VALUE thval = key;
rb_thread_t *th;
GetThreadPtr(thval, th);

if (th != current_th) {
thread_cleanup_func_before_exec(th);
}
return ST_CONTINUE;
}

void
rb_thread_atfork_before_exec(void)
{
rb_thread_t *th = GET_THREAD();
rb_vm_t *vm = th->vm;
VALUE thval = th->self;
vm->main_thread = th;

st_foreach(vm->living_threads, terminate_atfork_before_exec_i, (st_data_t)th);
st_clear(vm->living_threads);
st_insert(vm->living_threads, thval, (st_data_t) th->thread_id);
}

struct thgroup {
int enclosed;
VALUE group;
Expand Down

0 comments on commit 14a97fd

Please sign in to comment.