[前][次][番号順一覧][スレッド一覧]

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/

[前][次][番号順一覧][スレッド一覧]