Module Name: src
Committed By: wiz
Date: Tue Jan 4 23:48:45 UTC 2011
Modified Files:
src/sbin/wdogctl: wdogctl.c
Log Message:
Fix fd leaks. Found by cppcheck.
To generate a diff of this commit:
cvs rdiff -u -r1.18 -r1.19 src/sbin/wdogctl/wdogctl.c
Please note that diffs are not public domain; they are subject to the
copyright notices on the relevant files.
Modified files:
Index: src/sbin/wdogctl/wdogctl.c
diff -u src/sbin/wdogctl/wdogctl.c:1.18 src/sbin/wdogctl/wdogctl.c:1.19
--- src/sbin/wdogctl/wdogctl.c:1.18 Mon Mar 16 13:37:45 2009
+++ src/sbin/wdogctl/wdogctl.c Tue Jan 4 23:48:44 2011
@@ -1,4 +1,4 @@
-/* $NetBSD: wdogctl.c,v 1.18 2009/03/16 13:37:45 lukem Exp $ */
+/* $NetBSD: wdogctl.c,v 1.19 2011/01/04 23:48:44 wiz Exp $ */
/*-
* Copyright (c) 2000 Zembu Labs, Inc.
@@ -35,7 +35,7 @@
#include <sys/cdefs.h>
#ifndef lint
-__RCSID("$NetBSD: wdogctl.c,v 1.18 2009/03/16 13:37:45 lukem Exp $");
+__RCSID("$NetBSD: wdogctl.c,v 1.19 2011/01/04 23:48:44 wiz Exp $");
#endif
@@ -200,6 +200,8 @@
if (ioctl(fd, WDOGIOC_SMODE, &wm) == -1)
err(EXIT_FAILURE, "WDOGIOC_SMODE");
+
+ (void)close(fd);
}
void
@@ -219,6 +221,8 @@
if (ioctl(fd, WDOGIOC_TICKLE) == -1)
syslog(LOG_EMERG, "unable to tickle watchdog timer %s: %m",
wm.wm_name);
+
+ (void)close(fd);
return;
}
@@ -316,6 +320,8 @@
err(EXIT_FAILURE, "open %s", _PATH_WATCHDOG);
if (ioctl(fd, WDOGIOC_TICKLE) == -1)
fprintf(stderr, "Cannot tickle timer\n");
+
+ (void)close(fd);
}
void
@@ -331,6 +337,7 @@
if (ioctl(fd, WDOGIOC_WHICH, &wm) == -1) {
printf("No watchdog timer running.\n");
+ (void)close(fd);
return;
}
mode = wm.wm_mode & WDOG_MODE_MASK;