diff options
author | Miod Vallat <miod@cvs.openbsd.org> | 2001-12-09 14:58:22 +0000 |
---|---|---|
committer | Miod Vallat <miod@cvs.openbsd.org> | 2001-12-09 14:58:22 +0000 |
commit | ff83671640be394b9b58a4610c775cdc6e99dffa (patch) | |
tree | 366461e59a53a0fda9c948333afb11903ebaecdb | |
parent | 558f149d745ecb762e07e0e08cf3151ef877b598 (diff) |
Do not use stdio functions after a successfull call to daemon(), use
syslog() instead.
Also, be sure to unlink the pid file and to restore screen when exiting
from outside a signal handler.
ok millert@
-rw-r--r-- | usr.sbin/screenblank/screenblank.c | 72 |
1 files changed, 48 insertions, 24 deletions
diff --git a/usr.sbin/screenblank/screenblank.c b/usr.sbin/screenblank/screenblank.c index 9a2275ab9b5..a62c236ddd5 100644 --- a/usr.sbin/screenblank/screenblank.c +++ b/usr.sbin/screenblank/screenblank.c @@ -1,4 +1,4 @@ -/* $OpenBSD: screenblank.c,v 1.10 2001/12/01 23:43:48 miod Exp $ */ +/* $OpenBSD: screenblank.c,v 1.11 2001/12/09 14:58:21 miod Exp $ */ /* $NetBSD: screenblank.c,v 1.2 1996/02/28 01:18:34 thorpej Exp $ */ /*- @@ -58,6 +58,7 @@ #include <string.h> #include <signal.h> #include <unistd.h> +#include <syslog.h> #include <machine/fbio.h> @@ -74,12 +75,13 @@ LIST_HEAD(ds_list, dev_stat) ds_list; extern char *__progname; -static void add_dev __P((char *, int)); -static void change_state __P((int, int)); -static void cvt_arg __P((char *, struct timeval *)); -static void logpid __P((void)); -static void sighandler __P((int)); -static void usage __P((void)); +void add_dev __P((char *, int)); +void change_state __P((int, int)); +void cvt_arg __P((char *, struct timeval *)); +void logpid __P((void)); +void sighandler __P((int)); +void usage __P((void)); +void cleanup __P((int)); int main(argc, argv) @@ -167,6 +169,7 @@ main(argc, argv) err(1, "sigaction"); /* Detach. */ + openlog(__progname, LOG_PID, LOG_DAEMON); if (daemon(0, 0)) err(1, "daemon"); logpid(); @@ -179,8 +182,12 @@ main(argc, argv) /* Don't check framebuffers. */ if (dsp->ds_isfb) continue; - if (stat(dsp->ds_path, &st) < 0) - err(1, "stat: %s", dsp->ds_path); + if (stat(dsp->ds_path, &st) < 0) { + syslog(LOG_ERR, "stat(%s): %m", + dsp->ds_path); + cleanup(0); + exit(1); + } if (st.st_atime > dsp->ds_atime) { change = 1; dsp->ds_atime = st.st_atime; @@ -209,13 +216,16 @@ main(argc, argv) break; } - if (select(0, NULL, NULL, NULL, tvp) < 0) - err(1, "select"); + if (select(0, NULL, NULL, NULL, tvp) < 0) { + syslog(LOG_ERR, "select: %m"); + cleanup(0); + exit(1); + } } /* NOTREACHED */ } -static void +void add_dev(path, isfb) char *path; int isfb; @@ -242,18 +252,26 @@ add_dev(path, isfb) } /* ARGSUSED */ -static void +void sighandler(sig) int sig; { - /* Kill the pid file and re-enable the framebuffer before exit. */ - (void)unlink(_PATH_SCREENBLANKPID); - change_state(FBVIDEO_ON, 1); + cleanup(1); _exit(0); } -static void +void +cleanup(sig) + int sig; +{ + + /* Kill the pid file and re-enable the framebuffer before exit. */ + unlink(_PATH_SCREENBLANKPID); + change_state(FBVIDEO_ON, sig); +} + +void change_state(state, sig) int state; int sig; @@ -269,19 +287,25 @@ change_state(state, sig) if (errno == ENXIO) { if (sig) _exit(1); - else + else { + syslog(LOG_ERR, "open(%s): %m", + dsp->ds_path); exit(1); + } } - warn("open: %s", dsp->ds_path); + if (!sig) + syslog(LOG_WARNING, "open: %s", dsp->ds_path); continue; } - if (ioctl(fd, FBIOSVIDEO, &state) < 0) - warn("ioctl: %s", dsp->ds_path); + if (ioctl(fd, FBIOSVIDEO, &state) < 0) { + if (!sig) + syslog(LOG_WARNING, "ioctl: %s", dsp->ds_path); + } (void)close(fd); } } -static void +void cvt_arg(arg, tvp) char *arg; struct timeval *tvp; @@ -312,7 +336,7 @@ cvt_arg(arg, tvp) tvp->tv_usec = (long)((seconds - tvp->tv_sec) * 1000000); } -static void +void logpid() { FILE *fp; @@ -323,7 +347,7 @@ logpid() } } -static void +void usage() { |