From 27b8ef7ff78f3a7e189c90c641bed4e61c11b76c Mon Sep 17 00:00:00 2001 From: normal Date: Wed, 7 Jun 2017 00:32:02 +0000 Subject: thread.c: avoid busy looping on rb_thread_fd_close We no longer use it this function, but extensions do, and we need to ensure it continues to work for them. * thread.c (rb_thread_fd_close): schedule other threads in loop * ext/-test-/thread_fd_close/thread_fd_close.c: new file * ext/-test-/thread_fd_close/depend: ditto * ext/-test-/thread_fd_close/extconf.rb: ditto * test/-ext-/thread_fd_close/test_thread_fd_close.rb: new test git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@59030 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ext/-test-/thread_fd_close/depend | 16 ++++++++++++++++ ext/-test-/thread_fd_close/extconf.rb | 2 ++ ext/-test-/thread_fd_close/thread_fd_close.c | 14 ++++++++++++++ 3 files changed, 32 insertions(+) create mode 100644 ext/-test-/thread_fd_close/depend create mode 100644 ext/-test-/thread_fd_close/extconf.rb create mode 100644 ext/-test-/thread_fd_close/thread_fd_close.c (limited to 'ext') diff --git a/ext/-test-/thread_fd_close/depend b/ext/-test-/thread_fd_close/depend new file mode 100644 index 0000000000..7bc04c3db3 --- /dev/null +++ b/ext/-test-/thread_fd_close/depend @@ -0,0 +1,16 @@ +# AUTOGENERATED DEPENDENCIES START +thread_fd_close.o: $(RUBY_EXTCONF_H) +thread_fd_close.o: $(arch_hdrdir)/ruby/config.h +thread_fd_close.o: $(hdrdir)/ruby/backward.h +thread_fd_close.o: $(hdrdir)/ruby/defines.h +thread_fd_close.o: $(hdrdir)/ruby/encoding.h +thread_fd_close.o: $(hdrdir)/ruby/intern.h +thread_fd_close.o: $(hdrdir)/ruby/io.h +thread_fd_close.o: $(hdrdir)/ruby/missing.h +thread_fd_close.o: $(hdrdir)/ruby/onigmo.h +thread_fd_close.o: $(hdrdir)/ruby/oniguruma.h +thread_fd_close.o: $(hdrdir)/ruby/ruby.h +thread_fd_close.o: $(hdrdir)/ruby/st.h +thread_fd_close.o: $(hdrdir)/ruby/subst.h +thread_fd_close.o: thread_fd_close.c +# AUTOGENERATED DEPENDENCIES END diff --git a/ext/-test-/thread_fd_close/extconf.rb b/ext/-test-/thread_fd_close/extconf.rb new file mode 100644 index 0000000000..0d9694539c --- /dev/null +++ b/ext/-test-/thread_fd_close/extconf.rb @@ -0,0 +1,2 @@ +# frozen_string_literal: true +create_makefile('-test-/thread_fd_close') diff --git a/ext/-test-/thread_fd_close/thread_fd_close.c b/ext/-test-/thread_fd_close/thread_fd_close.c new file mode 100644 index 0000000000..4fd967c5b3 --- /dev/null +++ b/ext/-test-/thread_fd_close/thread_fd_close.c @@ -0,0 +1,14 @@ +#include "ruby/ruby.h" + +static VALUE +thread_fd_close(VALUE ign, VALUE fd) +{ + rb_thread_fd_close(NUM2INT(fd)); + return Qnil; +} + +void +Init_thread_fd_close(void) +{ + rb_define_singleton_method(rb_cIO, "thread_fd_close", thread_fd_close, 1); +} -- cgit v1.2.3