diff options
author | Theo de Raadt <deraadt@cvs.openbsd.org> | 2002-06-18 00:46:38 +0000 |
---|---|---|
committer | Theo de Raadt <deraadt@cvs.openbsd.org> | 2002-06-18 00:46:38 +0000 |
commit | d39bc90d27eef3318f55538824f355c44d0c247e (patch) | |
tree | 4d60bdbac32e24dc42b790cae1e20a02efc6066e | |
parent | d0ee2243ee1a21d455802c3bd65f842102e51d32 (diff) |
revoke privs after kvm_openfiles
-rw-r--r-- | usr.bin/systat/main.c | 32 |
1 files changed, 15 insertions, 17 deletions
diff --git a/usr.bin/systat/main.c b/usr.bin/systat/main.c index 0e17cf0fe66..5db59f39e8e 100644 --- a/usr.bin/systat/main.c +++ b/usr.bin/systat/main.c @@ -1,4 +1,4 @@ -/* $OpenBSD: main.c,v 1.23 2002/02/19 19:39:39 millert Exp $ */ +/* $OpenBSD: main.c,v 1.24 2002/06/18 00:46:37 deraadt Exp $ */ /* $NetBSD: main.c,v 1.8 1996/05/10 23:16:36 thorpej Exp $ */ /*- @@ -44,7 +44,7 @@ static char copyright[] = #if 0 static char sccsid[] = "@(#)main.c 8.1 (Berkeley) 6/6/93"; #endif -static char rcsid[] = "$OpenBSD: main.c,v 1.23 2002/02/19 19:39:39 millert Exp $"; +static char rcsid[] = "$OpenBSD: main.c,v 1.24 2002/06/18 00:46:37 deraadt Exp $"; #endif /* not lint */ #include <sys/param.h> @@ -86,15 +86,13 @@ WINDOW *wload; /* one line window for load average */ static void usage(void); int -main(argc, argv) - int argc; - char **argv; +main(int argc, char *argv[]) { int ch; char errbuf[_POSIX2_LINE_MAX]; while ((ch = getopt(argc, argv, "w:")) != -1) - switch(ch) { + switch (ch) { case 'w': if ((naptime = atoi(optarg)) <= 0) errx(1, "interval <= 0."); @@ -129,6 +127,9 @@ main(argc, argv) exit(1); } + setegid(getgid()); + setgid(getgid()); + signal(SIGINT, sigdie); siginterrupt(SIGINT, 1); signal(SIGQUIT, sigdie); @@ -142,8 +143,7 @@ main(argc, argv) * an overlapping sub-window of stdscr configured by the display * routines to minimize update work by curses. */ - if (initscr() == NULL) - { + if (initscr() == NULL) { warnx("couldn't initialize screen"); exit(0); } @@ -179,7 +179,7 @@ main(argc, argv) } void -gethz() +gethz(void) { struct clockinfo cinf; size_t size = sizeof(cinf); @@ -194,7 +194,7 @@ gethz() } static void -usage() +usage(void) { fprintf(stderr, "usage: systat [-M core] [-N system] [-w wait]\n"); fprintf(stderr, @@ -204,7 +204,7 @@ usage() void -labels() +labels(void) { if (curcmd->c_flags & CF_LOADAV) { mvaddstr(2, 20, @@ -262,7 +262,7 @@ display(void) } void -load() +load(void) { (void) getloadavg(avenrun, sizeof(avenrun)/sizeof(avenrun[0])); @@ -283,7 +283,7 @@ sigdie(signo) } void -die() +die(void) { if (wnd) { move(CMDLINE, 0); @@ -295,8 +295,7 @@ die() } void -sigwinch(signo) - int signo; +sigwinch(int signo) { gotwinch = 1; } @@ -326,8 +325,7 @@ error(const char *fmt, ...) } void -nlisterr(namelist) - struct nlist namelist[]; +nlisterr(struct nlist namelist[]) { int i, n; |