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;