From: Ben Pfaff Date: Tue, 7 Jun 2011 20:17:57 +0000 (-0700) Subject: signals: New function signal_unregister(). X-Git-Url: https://pintos-os.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=5a08f9b04417ad1dc343861f3be3975a5cbd074c;p=openvswitch signals: New function signal_unregister(). Fixes a very minor memory leak in ovs-vswitchd reported by valgrind. --- diff --git a/lib/signals.c b/lib/signals.c index 37f06373..7650cb9b 100644 --- a/lib/signals.c +++ b/lib/signals.c @@ -20,6 +20,7 @@ #include #include #include +#include #include #include "poll-loop.h" #include "socket-util.h" @@ -40,6 +41,7 @@ VLOG_DEFINE_THIS_MODULE(signals); #endif struct signal { + struct sigaction saved_sa; int signr; }; @@ -78,20 +80,31 @@ signal_register(int signr) signal_init(); + s = xmalloc(sizeof *s); + s->signr = signr; + /* Set up signal handler. */ assert(signr >= 1 && signr < N_SIGNALS); memset(&sa, 0, sizeof sa); sa.sa_handler = signal_handler; sigemptyset(&sa.sa_mask); sa.sa_flags = SA_RESTART; - xsigaction(signr, &sa, NULL); + xsigaction(signr, &sa, &s->saved_sa); - /* Return structure. */ - s = xmalloc(sizeof *s); - s->signr = signr; return s; } +/* Unregisters the handler for 's', restores the signal handler that was in + * effect before signal_register() was called, and frees 's'. */ +void +signal_unregister(struct signal *s) +{ + if (s) { + xsigaction(s->signr, &s->saved_sa, NULL); + free(s); + } +} + /* Returns true if signal 's' has been received since the last call to this * function with argument 's'. */ bool diff --git a/lib/signals.h b/lib/signals.h index 12fb3113..e09b04a0 100644 --- a/lib/signals.h +++ b/lib/signals.h @@ -21,7 +21,10 @@ #include void signal_init(void); + struct signal *signal_register(int signr); +void signal_unregister(struct signal *); + bool signal_poll(struct signal *); void signal_wait(struct signal *); diff --git a/vswitchd/ovs-vswitchd.c b/vswitchd/ovs-vswitchd.c index d591e951..a71eeccc 100644 --- a/vswitchd/ovs-vswitchd.c +++ b/vswitchd/ovs-vswitchd.c @@ -102,6 +102,7 @@ main(int argc, char *argv[]) } bridge_exit(); unixctl_server_destroy(unixctl); + signal_unregister(sighup); return 0; }