mirror of
https://github.com/openvswitch/ovs
synced 2025-10-17 14:28:02 +00:00
signals: New function signal_unregister().
Fixes a very minor memory leak in ovs-vswitchd reported by valgrind.
This commit is contained in:
@@ -20,6 +20,7 @@
|
|||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <limits.h>
|
#include <limits.h>
|
||||||
#include <signal.h>
|
#include <signal.h>
|
||||||
|
#include <stdlib.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
#include "poll-loop.h"
|
#include "poll-loop.h"
|
||||||
#include "socket-util.h"
|
#include "socket-util.h"
|
||||||
@@ -40,6 +41,7 @@ VLOG_DEFINE_THIS_MODULE(signals);
|
|||||||
#endif
|
#endif
|
||||||
|
|
||||||
struct signal {
|
struct signal {
|
||||||
|
struct sigaction saved_sa;
|
||||||
int signr;
|
int signr;
|
||||||
};
|
};
|
||||||
|
|
||||||
@@ -78,20 +80,31 @@ signal_register(int signr)
|
|||||||
|
|
||||||
signal_init();
|
signal_init();
|
||||||
|
|
||||||
|
s = xmalloc(sizeof *s);
|
||||||
|
s->signr = signr;
|
||||||
|
|
||||||
/* Set up signal handler. */
|
/* Set up signal handler. */
|
||||||
assert(signr >= 1 && signr < N_SIGNALS);
|
assert(signr >= 1 && signr < N_SIGNALS);
|
||||||
memset(&sa, 0, sizeof sa);
|
memset(&sa, 0, sizeof sa);
|
||||||
sa.sa_handler = signal_handler;
|
sa.sa_handler = signal_handler;
|
||||||
sigemptyset(&sa.sa_mask);
|
sigemptyset(&sa.sa_mask);
|
||||||
sa.sa_flags = SA_RESTART;
|
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;
|
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
|
/* Returns true if signal 's' has been received since the last call to this
|
||||||
* function with argument 's'. */
|
* function with argument 's'. */
|
||||||
bool
|
bool
|
||||||
|
@@ -21,7 +21,10 @@
|
|||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
|
|
||||||
void signal_init(void);
|
void signal_init(void);
|
||||||
|
|
||||||
struct signal *signal_register(int signr);
|
struct signal *signal_register(int signr);
|
||||||
|
void signal_unregister(struct signal *);
|
||||||
|
|
||||||
bool signal_poll(struct signal *);
|
bool signal_poll(struct signal *);
|
||||||
void signal_wait(struct signal *);
|
void signal_wait(struct signal *);
|
||||||
|
|
||||||
|
@@ -102,6 +102,7 @@ main(int argc, char *argv[])
|
|||||||
}
|
}
|
||||||
bridge_exit();
|
bridge_exit();
|
||||||
unixctl_server_destroy(unixctl);
|
unixctl_server_destroy(unixctl);
|
||||||
|
signal_unregister(sighup);
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
Reference in New Issue
Block a user