summaryrefslogtreecommitdiff
path: root/process.c
diff options
context:
space:
mode:
authoryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-30 10:32:51 +0000
committeryugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-12-30 10:32:51 +0000
commit7010dcef9bafada7d1f47c5bd98d3fbb2fb0ae9d (patch)
treec93edba94b9297f95acc7e14c91f065625ea1538 /process.c
parente8f6d8493678a828ae345f86c680601d2661442a (diff)
merges r21181 from trunk into ruby_1_9_1.
* process.c (rb_waitpid): retries waitpid when EINTR. [ruby-core:19744]. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@21196 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'process.c')
-rw-r--r--process.c9
1 files changed, 4 insertions, 5 deletions
diff --git a/process.c b/process.c
index 584f005620..11c7c23144 100644
--- a/process.c
+++ b/process.c
@@ -624,18 +624,17 @@ rb_waitpid(rb_pid_t pid, int *st, int flags)
#ifndef NO_WAITPID
struct waitpid_arg arg;
+retry:
arg.pid = pid;
arg.st = st;
arg.flags = flags;
result = (rb_pid_t)rb_thread_blocking_region(rb_waitpid_blocking, &arg,
RUBY_UBF_PROCESS, 0);
if (result < 0) {
-#if 0
if (errno == EINTR) {
- rb_thread_polling();
- goto retry;
- }
-#endif
+ RUBY_VM_CHECK_INTS();
+ goto retry;
+ }
return -1;
}
#else /* NO_WAITPID */