Documentation/watchdog: Fix the file descriptor leak when no cmdline arg given
authorDevendra Naga <devendra.aaru@gmail.com>
Thu, 17 May 2012 09:37:48 +0000 (15:07 +0530)
committerWim Van Sebroeck <wim@iguana.be>
Wed, 23 May 2012 14:27:48 +0000 (16:27 +0200)
we start a infinite loop when user gives ./watchdog-test, and when user
ctrl + c's the program, we just exit immeadiately with out closing the
filedescriptor of the watchdog device. a signal handler is used to
do the job of closing the filedescriptor and exiting the program.

Signed-off-by: Devendra Naga <devendra.aaru@gmail.com>
Signed-off-by: Wim Van Sebroeck <wim@iguana.be>
Documentation/watchdog/src/watchdog-test.c

index 23084f2..73ff5cc 100644 (file)
@@ -7,6 +7,7 @@
 #include <string.h>
 #include <unistd.h>
 #include <fcntl.h>
+#include <signal.h>
 #include <sys/ioctl.h>
 #include <linux/types.h>
 #include <linux/watchdog.h>
@@ -29,6 +30,14 @@ static void keep_alive(void)
  * The main program.  Run the program with "-d" to disable the card,
  * or "-e" to enable the card.
  */
+
+void term(int sig)
+{
+    close(fd);
+    fprintf(stderr, "Stopping watchdog ticks...\n");
+    exit(0);
+}
+
 int main(int argc, char *argv[])
 {
     int flags;
@@ -65,6 +74,8 @@ int main(int argc, char *argv[])
        fflush(stderr);
     }
 
+    signal(SIGINT, term);
+
     while(1) {
        keep_alive();
        sleep(1);