opnsense-src/release/picobsd/tinyware/sps/sps.c

123 lines
3.2 KiB
C
Raw Normal View History

1998-08-27 13:38:45 -04:00
/*-
* Copyright (c) 1998 Andrzej Bialecki
* All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
* ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
* ARE DISCLAIMED. IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
* FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
* DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
* OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
* HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
* LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
* OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
* SUCH DAMAGE.
*
1999-08-27 21:35:59 -04:00
* $FreeBSD$
1998-08-27 13:38:45 -04:00
*/
/*
* Small replacement for ps(1) - uses only sysctl(3) to retrieve info
*/
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/param.h>
#include <sys/sysctl.h>
#include <sys/stat.h>
#include <sys/user.h>
char p_stat[] = "?iRSTZWM";
1998-08-27 13:38:45 -04:00
int
main(int argc, char *argv[])
{
int mib[4], i, num, len, j, plen;
char buf[MAXPATHLEN], vty[5], pst[5], wmesg[10];
struct kinfo_proc *ki;
2000-11-11 11:12:39 -05:00
char *t;
int ma, mi;
1998-08-27 13:38:45 -04:00
mib[0] = CTL_KERN;
mib[1] = KERN_PROC;
mib[2] = KERN_PROC_ALL;
if (sysctl(mib, 3, NULL, &len, NULL, 0) != 0) {
1998-08-27 13:38:45 -04:00
perror("sysctl sizing");
exit(1);
}
t = (char *)malloc(len);
if (sysctl(mib, 3, t, &len, NULL, 0) != 0) {
1998-08-27 13:38:45 -04:00
perror("sysctl info");
exit(1);
}
mib[2] = KERN_PROC_ARGS;
num = len / KINFO_PROC_SIZE;
i = 0;
2000-11-11 11:12:39 -05:00
printf("USERNAME PID PPID PRI NICE TTY STAT WCHAN COMMAND\n");
while(i < num) {
ki = (struct kinfo_proc *)(t + (num - i - 1) * KINFO_PROC_SIZE);
mib[3] = ki->ki_pid;
2000-11-11 11:12:39 -05:00
plen = MAXPATHLEN;
if (sysctl(mib, 4, buf, &plen, NULL, 0) != 0) {
perror("sysctl cmd info");
2000-11-11 11:12:39 -05:00
exit(1);
}
if (plen == 0) {
sprintf(buf, "(%s)", ki->ki_comm);
2000-11-11 11:12:39 -05:00
} else {
for (j = 0; j < plen - 1; j++) {
if (buf[j] == '\0') buf[j] = ' ';
2000-11-11 11:12:39 -05:00
}
}
if (strcmp(ki->ki_wmesg, "") == 0) {
2000-11-11 11:12:39 -05:00
sprintf(wmesg, "-");
} else {
strcpy(wmesg, ki->ki_wmesg);
2000-11-11 11:12:39 -05:00
}
ma = major(ki->ki_tdev);
mi = minor(ki->ki_tdev);
1998-08-27 13:38:45 -04:00
switch(ma) {
case 255:
strcpy(vty, "??");
1998-08-27 13:38:45 -04:00
break;
case 12:
if(mi != 255) {
sprintf(vty, "v%d", mi);
1998-08-27 13:38:45 -04:00
break;
}
/* FALLTHROUGH */
case 0:
strcpy(vty, "con");
1998-08-27 13:38:45 -04:00
break;
case 5:
sprintf(vty, "p%d", mi);
1998-08-27 13:38:45 -04:00
break;
}
sprintf(pst, "%c", p_stat[ki->ki_stat]);
2000-11-11 11:12:39 -05:00
printf("%8s %5u %5u %3d %4d %3s %-4s %-7s %s\n",
ki->ki_login,
ki->ki_pid,
ki->ki_ppid,
ki->ki_pri.pri_level, /* XXX check this */
ki->ki_nice,
1998-08-27 13:38:45 -04:00
vty,
pst,
2000-11-11 11:12:39 -05:00
wmesg,
buf);
1998-08-27 13:38:45 -04:00
i++;
}
2000-11-11 11:12:39 -05:00
free((void *)t);
1998-08-27 13:38:45 -04:00
exit(0);
}