[tor-commits] [tor/master] Remove casting of void pointers when handling signals.

nickm at torproject.org nickm at torproject.org
Tue Jul 21 18:09:07 UTC 2015


commit 2d3f88f6b9c4db7a4f65f1dcebae296f662cbeb7
Author: cypherpunks <cypherpunks at torproject.org>
Date:   Thu Jul 2 09:43:20 2015 +0200

    Remove casting of void pointers when handling signals.
---
 src/or/main.c |   12 +++++++-----
 src/or/main.h |    2 +-
 2 files changed, 8 insertions(+), 6 deletions(-)

diff --git a/src/or/main.c b/src/or/main.c
index fe93cdc..5bff82b 100644
--- a/src/or/main.c
+++ b/src/or/main.c
@@ -2227,7 +2227,8 @@ run_main_loop_until_done(void)
 static void
 signal_callback(int fd, short events, void *arg)
 {
-  uintptr_t sig = (uintptr_t)arg;
+  const int *sigptr = arg;
+  const int sig = *sigptr;
   (void)fd;
   (void)events;
 
@@ -2237,7 +2238,7 @@ signal_callback(int fd, short events, void *arg)
 
 /** Do the work of acting on a signal received in <b>sig</b> */
 void
-process_signal(uintptr_t sig)
+process_signal(int sig)
 {
   switch (sig)
     {
@@ -2482,9 +2483,10 @@ handle_signals(int is_parent)
   static struct event *signal_events[16]; /* bigger than it has to be. */
   if (is_parent) {
     for (i = 0; signals[i] >= 0; ++i) {
-      signal_events[i] = tor_evsignal_new(
-                       tor_libevent_get_base(), signals[i], signal_callback,
-                       (void*)(uintptr_t)signals[i]);
+      signal_events[i] = tor_evsignal_new(tor_libevent_get_base(), signals[i],
+                                          signal_callback,
+                                          /* Cast away const */
+                                          (int*)&signals[i]);
       if (event_add(signal_events[i], NULL))
         log_warn(LD_BUG, "Error from libevent when adding event for signal %d",
                  signals[i]);
diff --git a/src/or/main.h b/src/or/main.h
index 542eab6..be0bd64 100644
--- a/src/or/main.h
+++ b/src/or/main.h
@@ -60,7 +60,7 @@ MOCK_DECL(long,get_uptime,(void));
 unsigned get_signewnym_epoch(void);
 
 void handle_signals(int is_parent);
-void process_signal(uintptr_t sig);
+void process_signal(int sig);
 
 int try_locking(const or_options_t *options, int err_if_locked);
 int have_lockfile(void);



More information about the tor-commits mailing list