ruby-changes:51896
From: normal <ko1@a...>
Date: Mon, 30 Jul 2018 09:31:14 +0900 (JST)
Subject: [ruby-changes:51896] normal:r64110 (trunk): thread.c: move ppoll wrapper into thread_pthread.c
normal 2018-07-30 09:31:08 +0900 (Mon, 30 Jul 2018) New Revision: 64110 https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=64110 Log: thread.c: move ppoll wrapper into thread_pthread.c thread_pthread.c relies on ppoll for rb_sigwait_sleep, so ensure the compatibility wrapper is available for it. [Bug #14950] Reported-by: SHIBATA Hiroshi <hsbt@r...> Reported-by: Greg L <Greg.mpls@g...> Modified files: trunk/thread.c trunk/thread_pthread.c Index: thread.c =================================================================== --- thread.c (revision 64109) +++ thread.c (revision 64110) @@ -361,49 +361,6 @@ ubf_sigwait(void *ignore) https://github.com/ruby/ruby/blob/trunk/thread.c#L361 rb_thread_wakeup_timer_thread(0); } -#ifdef USE_POLL - -/* The same with linux kernel. TODO: make platform independent definition. */ -#define POLLIN_SET (POLLRDNORM | POLLRDBAND | POLLIN | POLLHUP | POLLERR) -#define POLLOUT_SET (POLLWRBAND | POLLWRNORM | POLLOUT | POLLERR) -#define POLLEX_SET (POLLPRI) - -#ifndef POLLERR_SET /* defined for FreeBSD for now */ -# define POLLERR_SET (0) -#endif - -#ifndef HAVE_PPOLL -/* TODO: don't ignore sigmask */ -static int -ruby_ppoll(struct pollfd *fds, nfds_t nfds, - const struct timespec *ts, const sigset_t *sigmask) -{ - int timeout_ms; - - if (ts) { - int tmp, tmp2; - - if (ts->tv_sec > INT_MAX/1000) - timeout_ms = INT_MAX; - else { - tmp = (int)(ts->tv_sec * 1000); - /* round up 1ns to 1ms to avoid excessive wakeups for <1ms sleep */ - tmp2 = (int)((ts->tv_nsec + 999999L) / (1000L * 1000L)); - if (INT_MAX - tmp < tmp2) - timeout_ms = INT_MAX; - else - timeout_ms = (int)(tmp + tmp2); - } - } - else - timeout_ms = -1; - - return poll(fds, nfds, timeout_ms); -} -# define ppoll(fds,nfds,ts,sigmask) ruby_ppoll((fds),(nfds),(ts),(sigmask)) -#endif - - #if defined(_WIN32) #include "thread_win32.c" @@ -4064,6 +4021,17 @@ rb_thread_fd_select(int max, rb_fdset_t https://github.com/ruby/ruby/blob/trunk/thread.c#L4021 return (int)rb_ensure(do_select, (VALUE)&set, select_set_free, (VALUE)&set); } +#ifdef USE_POLL + +/* The same with linux kernel. TODO: make platform independent definition. */ +#define POLLIN_SET (POLLRDNORM | POLLRDBAND | POLLIN | POLLHUP | POLLERR) +#define POLLOUT_SET (POLLWRBAND | POLLWRNORM | POLLOUT | POLLERR) +#define POLLEX_SET (POLLPRI) + +#ifndef POLLERR_SET /* defined for FreeBSD for now */ +# define POLLERR_SET (0) +#endif + /* * returns a mask of events */ Index: thread_pthread.c =================================================================== --- thread_pthread.c (revision 64109) +++ thread_pthread.c (revision 64110) @@ -1577,6 +1577,37 @@ rb_sigwait_fd_put(const rb_thread_t *th, https://github.com/ruby/ruby/blob/trunk/thread_pthread.c#L1577 if (old != th) assert(old == th); } +#ifndef HAVE_PPOLL +/* TODO: don't ignore sigmask */ +static int +ruby_ppoll(struct pollfd *fds, nfds_t nfds, + const struct timespec *ts, const sigset_t *sigmask) +{ + int timeout_ms; + + if (ts) { + int tmp, tmp2; + + if (ts->tv_sec > INT_MAX/1000) + timeout_ms = INT_MAX; + else { + tmp = (int)(ts->tv_sec * 1000); + /* round up 1ns to 1ms to avoid excessive wakeups for <1ms sleep */ + tmp2 = (int)((ts->tv_nsec + 999999L) / (1000L * 1000L)); + if (INT_MAX - tmp < tmp2) + timeout_ms = INT_MAX; + else + timeout_ms = (int)(tmp + tmp2); + } + } + else + timeout_ms = -1; + + return poll(fds, nfds, timeout_ms); +} +# define ppoll(fds,nfds,ts,sigmask) ruby_ppoll((fds),(nfds),(ts),(sigmask)) +#endif + void rb_sigwait_sleep(rb_thread_t *th, int sigwait_fd, const struct timespec *ts) { -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/