[Author Prev][Author Next][Thread Prev][Thread Next][Author Index][Thread Index]
[or-cvs] catch signals in a more portable way, so solaris can catch ...
- To: or-cvs@freehaven.net
- Subject: [or-cvs] catch signals in a more portable way, so solaris can catch ...
- From: arma@seul.org (Roger Dingledine)
- Date: Sat, 20 Mar 2004 18:27:24 -0500 (EST)
- Delivered-to: archiver@seul.org
- Delivered-to: or-cvs-outgoing@seul.org
- Delivered-to: or-cvs@seul.org
- Delivery-date: Sat, 20 Mar 2004 18:27:45 -0500
- Reply-to: or-dev@freehaven.net
- Sender: owner-or-cvs@freehaven.net
Update of /home/or/cvsroot/src/or
In directory moria.mit.edu:/home2/arma/work/onion/cvs/src/or
Modified Files:
main.c
Log Message:
catch signals in a more portable way, so solaris can catch them too
Index: main.c
===================================================================
RCS file: /home/or/cvsroot/src/or/main.c,v
retrieving revision 1.205
retrieving revision 1.206
diff -u -d -r1.205 -r1.206
--- main.c 20 Mar 2004 04:59:29 -0000 1.205
+++ main.c 20 Mar 2004 23:27:22 -0000 1.206
@@ -729,7 +729,7 @@
if(geteuid()==0)
log_fn(LOG_WARN,"You are running Tor as root. You don't need to, and you probably shouldn't.");
#endif
-
+
if(options.ORPort) { /* only spawn dns handlers if we're a router */
dns_init(); /* initialize the dns resolve tree, and spawn workers */
}
@@ -738,12 +738,19 @@
}
#ifndef MS_WINDOWS /* do signal stuff only on unix */
- signal (SIGINT, catch); /* catch kills so we can exit cleanly */
- signal (SIGTERM, catch);
- signal (SIGPIPE, catch);
- signal (SIGUSR1, catch); /* to dump stats */
- signal (SIGHUP, catch); /* to reload directory */
- signal (SIGCHLD, catch); /* for exiting dns/cpu workers */
+{
+ struct sigaction action;
+ action.sa_flags = 0;
+ sigemptyset(&action.sa_mask);
+
+ action.sa_handler = catch;
+ sigaction(SIGINT, &action, NULL);
+ sigaction(SIGTERM, &action, NULL);
+ sigaction(SIGPIPE, &action, NULL);
+ sigaction(SIGUSR1, &action, NULL);
+ sigaction(SIGHUP, &action, NULL); /* to reload config, retry conns, etc */
+ sigaction(SIGCHLD, &action, NULL); /* handle dns/cpu workers that exit */
+}
#endif /* signal stuff */
crypto_global_init();