diff options
author | naruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2019-01-29 05:31:00 +0000 |
---|---|---|
committer | naruse <naruse@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2019-01-29 05:31:00 +0000 |
commit | fbad5b97e8a42304b73b6141b57fb8ac45565ec2 (patch) | |
tree | b9adfb254da0a4b31ef2ef5280088d9cd95c54cc /thread.c | |
parent | bf8cc37b467e1d372e1b01b4d25e9ef6f8cc927f (diff) |
merge revision(s) 66708: [Backport #15499]
thread.c (call_without_gvl): spawn thread for UBF iff single-threaded
We need another native thread to call some unblocking functions
which aren't RUBY_UBF_IO or RUBY_UBF_PROCESS. Instead of a
permanent thread in <= 2.5, we can now rely on the thread cache
feature to perform interrupts.
[ruby-core:90865] [Bug #15499]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_6@66940 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'thread.c')
-rw-r--r-- | thread.c | 8 |
1 files changed, 8 insertions, 0 deletions
@@ -1429,11 +1429,15 @@ call_without_gvl(void *(*func)(void *), void *data1, rb_execution_context_t *ec = GET_EC(); rb_thread_t *th = rb_ec_thread_ptr(ec); int saved_errno = 0; + VALUE ubf_th = Qfalse; if (ubf == RUBY_UBF_IO || ubf == RUBY_UBF_PROCESS) { ubf = ubf_select; data2 = th; } + else if (ubf && vm_living_thread_num(th->vm) == 1) { + ubf_th = rb_thread_start_unblock_thread(); + } BLOCKING_REGION(th, { val = func(data1); @@ -1444,6 +1448,10 @@ call_without_gvl(void *(*func)(void *), void *data1, RUBY_VM_CHECK_INTS_BLOCKING(ec); } + if (ubf_th != Qfalse) { + thread_value(rb_thread_kill(ubf_th)); + } + errno = saved_errno; return val; |