winbindd: vars for signals must be volatile sig_atomic_t
authorSATOH Fumiyasu <fumiyas@osstech.co.jp>
Fri, 12 Dec 2008 16:43:51 +0000 (17:43 +0100)
committerVolker Lendecke <vl@samba.org>
Fri, 12 Dec 2008 17:04:03 +0000 (18:04 +0100)
source3/winbindd/winbindd.c

index 1dcc70adaebde105493e9bed698bd1266ae1597d..0ecf11d0e5e3f236428b5bbfcfd2b1ae73376b38 100644 (file)
@@ -173,35 +173,35 @@ static void terminate(bool is_parent)
        exit(0);
 }
 
        exit(0);
 }
 
-static bool do_sigterm;
+static SIG_ATOMIC_T do_sigterm = 0;
 
 static void termination_handler(int signum)
 {
 
 static void termination_handler(int signum)
 {
-       do_sigterm = True;
+       do_sigterm = 1;
        sys_select_signal(signum);
 }
 
        sys_select_signal(signum);
 }
 
-static bool do_sigusr2;
+static SIG_ATOMIC_T do_sigusr2 = 0;
 
 static void sigusr2_handler(int signum)
 {
 
 static void sigusr2_handler(int signum)
 {
-       do_sigusr2 = True;
+       do_sigusr2 = 1;
        sys_select_signal(SIGUSR2);
 }
 
        sys_select_signal(SIGUSR2);
 }
 
-static bool do_sighup;
+static SIG_ATOMIC_T do_sighup = 0;
 
 static void sighup_handler(int signum)
 {
 
 static void sighup_handler(int signum)
 {
-       do_sighup = True;
+       do_sighup = 1;
        sys_select_signal(SIGHUP);
 }
 
        sys_select_signal(SIGHUP);
 }
 
-static bool do_sigchld;
+static SIG_ATOMIC_T do_sigchld = 0;
 
 static void sigchld_handler(int signum)
 {
 
 static void sigchld_handler(int signum)
 {
-       do_sigchld = True;
+       do_sigchld = 1;
        sys_select_signal(SIGCHLD);
 }
 
        sys_select_signal(SIGCHLD);
 }
 
@@ -224,7 +224,7 @@ static void msg_shutdown(struct messaging_context *msg,
                         struct server_id server_id,
                         DATA_BLOB *data)
 {
                         struct server_id server_id,
                         DATA_BLOB *data)
 {
-       do_sigterm = True;
+       do_sigterm = 1;
 }
 
 
 }
 
 
@@ -802,7 +802,7 @@ void winbind_check_sighup(const char *lfile)
                flush_caches();
                reload_services_file(lfile);
 
                flush_caches();
                reload_services_file(lfile);
 
-               do_sighup = False;
+               do_sighup = 0;
        }
 }
 
        }
 }
 
@@ -977,13 +977,13 @@ static void process_loop(void)
 
        if (do_sigusr2) {
                print_winbindd_status();
 
        if (do_sigusr2) {
                print_winbindd_status();
-               do_sigusr2 = False;
+               do_sigusr2 = 0;
        }
 
        if (do_sigchld) {
                pid_t pid;
 
        }
 
        if (do_sigchld) {
                pid_t pid;
 
-               do_sigchld = False;
+               do_sigchld = 0;
 
                while ((pid = sys_waitpid(-1, NULL, WNOHANG)) > 0) {
                        winbind_child_died(pid);
 
                while ((pid = sys_waitpid(-1, NULL, WNOHANG)) > 0) {
                        winbind_child_died(pid);