Fix uninitialized sigaction.sa_flags valgrind error

Valgrind warns that the sometimes uninitialized sigaction.sa_flags field
is sometimes used when passed to the signal handler.

This patch explicitly zeros out the sigaction.sa_flags field at creation
time.
This commit is contained in:
Mahmoud Al-Qudsi 2017-08-26 19:11:39 -05:00
parent 99d2a344c7
commit e656654456

View file

@ -267,6 +267,8 @@ void signal_reset_handlers() {
static void set_interactive_handlers() { static void set_interactive_handlers() {
struct sigaction act, oact; struct sigaction act, oact;
act.sa_flags = 0;
oact.sa_flags = 0;
sigemptyset(&act.sa_mask); sigemptyset(&act.sa_mask);
// Interactive mode. Ignore interactive signals. We are a shell, we know what is best for // Interactive mode. Ignore interactive signals. We are a shell, we know what is best for
@ -312,6 +314,7 @@ static void set_interactive_handlers() {
static void set_non_interactive_handlers() { static void set_non_interactive_handlers() {
struct sigaction act; struct sigaction act;
act.sa_flags = 0;
sigemptyset(&act.sa_mask); sigemptyset(&act.sa_mask);
// Non-interactive. Ignore interrupt, check exit status of processes to determine result // Non-interactive. Ignore interrupt, check exit status of processes to determine result
@ -324,6 +327,7 @@ static void set_non_interactive_handlers() {
/// Sets up appropriate signal handlers. /// Sets up appropriate signal handlers.
void signal_set_handlers() { void signal_set_handlers() {
struct sigaction act; struct sigaction act;
act.sa_flags = 0;
sigemptyset(&act.sa_mask); sigemptyset(&act.sa_mask);
// Ignore SIGPIPE. We'll detect failed writes and deal with them appropriately. We don't want // Ignore SIGPIPE. We'll detect failed writes and deal with them appropriately. We don't want
@ -355,6 +359,7 @@ void signal_handle(int sig, int do_handle) {
(sig == SIGTTOU) || (sig == SIGCHLD)) (sig == SIGTTOU) || (sig == SIGCHLD))
return; return;
act.sa_flags = 0;
sigemptyset(&act.sa_mask); sigemptyset(&act.sa_mask);
if (do_handle) { if (do_handle) {
act.sa_flags = SA_SIGINFO; act.sa_flags = SA_SIGINFO;