xref: /csrg-svn/bin/ps/print.c (revision 66840)
146324Sbostic /*-
266641Spendry  * Copyright (c) 1990, 1993, 1994
360685Sbostic  *	The Regents of the University of California.  All rights reserved.
446324Sbostic  *
546324Sbostic  * %sccs.include.redist.c%
646324Sbostic  */
746324Sbostic 
846324Sbostic #ifndef lint
9*66840Sbostic static char sccsid[] = "@(#)print.c	8.6 (Berkeley) 04/16/94";
1046324Sbostic #endif /* not lint */
1146324Sbostic 
1246324Sbostic #include <sys/param.h>
1346324Sbostic #include <sys/time.h>
1446324Sbostic #include <sys/resource.h>
1546324Sbostic #include <sys/proc.h>
1646324Sbostic #include <sys/stat.h>
1746324Sbostic 
1864637Sbostic #ifdef P_PPWAIT
1947668Skarels #define NEWVM
2047668Skarels #endif
2147668Skarels 
2247668Skarels #ifdef NEWVM
2359507Sbostic #include <sys/ucred.h>
2459507Sbostic #include <sys/sysctl.h>
2547668Skarels #include <vm/vm.h>
2647668Skarels #else
2747668Skarels #include <machine/pte.h>
2847668Skarels #include <sys/vmparam.h>
2947668Skarels #include <sys/vm.h>
3047668Skarels #endif
3147668Skarels 
3259507Sbostic #include <err.h>
3359507Sbostic #include <math.h>
3459507Sbostic #include <nlist.h>
3559507Sbostic #include <stddef.h>
3659507Sbostic #include <stdio.h>
3759507Sbostic #include <stdlib.h>
3859507Sbostic #include <string.h>
39*66840Sbostic #include <vis.h>
4059507Sbostic #include <tzfile.h>
4159507Sbostic 
4259507Sbostic #include "ps.h"
4359507Sbostic 
4453939Sbostic void
printheader()4546324Sbostic printheader()
4646324Sbostic {
4766638Spendry 	VAR *v;
4866638Spendry 	struct varent *vent;
4946324Sbostic 
5047669Smarc 	for (vent = vhead; vent; vent = vent->next) {
5147669Smarc 		v = vent->var;
5246324Sbostic 		if (v->flag & LJUST) {
5347669Smarc 			if (vent->next == NULL)	/* last one */
5453939Sbostic 				(void)printf("%s", v->header);
5546324Sbostic 			else
5653939Sbostic 				(void)printf("%-*s", v->width, v->header);
5746324Sbostic 		} else
5853939Sbostic 			(void)printf("%*s", v->width, v->header);
5947669Smarc 		if (vent->next != NULL)
6053939Sbostic 			(void)putchar(' ');
6146324Sbostic 	}
6253939Sbostic 	(void)putchar('\n');
6346324Sbostic }
6446324Sbostic 
6553939Sbostic void
command(k,ve)6653939Sbostic command(k, ve)
6746324Sbostic 	KINFO *k;
6853939Sbostic 	VARENT *ve;
6946324Sbostic {
7053939Sbostic 	VAR *v;
71*66840Sbostic 	int left;
72*66840Sbostic 	char *cp, *vis_env, *vis_args;
7346324Sbostic 
74*66840Sbostic 	if ((vis_args = malloc(strlen(k->ki_args) * 4 + 1)) == NULL)
75*66840Sbostic 		err(1, NULL);
76*66840Sbostic 	strvis(vis_args, k->ki_args, VIS_TAB | VIS_NL | VIS_NOSLASH);
77*66840Sbostic 	if (k->ki_env) {
78*66840Sbostic 		if ((vis_env = malloc(strlen(k->ki_env) * 4 + 1)) == NULL)
79*66840Sbostic 			err(1, NULL);
80*66840Sbostic 		strvis(vis_env, k->ki_env, VIS_TAB | VIS_NL | VIS_NOSLASH);
81*66840Sbostic 	} else
82*66840Sbostic 		vis_env = NULL;
83*66840Sbostic 
8453939Sbostic 	v = ve->var;
8553939Sbostic 	if (ve->next == NULL) {
8646324Sbostic 		/* last field */
8753122Smckusick 		if (termwidth == UNLIMITED) {
88*66840Sbostic 			if (vis_env)
89*66840Sbostic 				(void)printf("%s ", vis_env);
90*66840Sbostic 			(void)printf("%s", vis_args);
9153122Smckusick 		} else {
92*66840Sbostic 			left = termwidth - (totwidth - v->width);
9346324Sbostic 			if (left < 1) /* already wrapped, just use std width */
9446324Sbostic 				left = v->width;
95*66840Sbostic 			if ((cp = vis_env) != NULL) {
9653122Smckusick 				while (--left >= 0 && *cp)
9753939Sbostic 					(void)putchar(*cp++);
9853122Smckusick 				if (--left >= 0)
9953122Smckusick 					putchar(' ');
10053122Smckusick 			}
101*66840Sbostic 			for (cp = vis_args; --left >= 0 && *cp != '\0';)
10253939Sbostic 				(void)putchar(*cp++);
10346324Sbostic 		}
10446324Sbostic 	} else
10553122Smckusick 		/* XXX env? */
106*66840Sbostic 		(void)printf("%-*.*s", v->width, v->width, vis_args);
107*66840Sbostic 	free(vis_args);
108*66840Sbostic 	if (vis_env != NULL)
109*66840Sbostic 		free(vis_env);
11046324Sbostic }
11146324Sbostic 
11253939Sbostic void
ucomm(k,ve)11353939Sbostic ucomm(k, ve)
11446324Sbostic 	KINFO *k;
11553939Sbostic 	VARENT *ve;
11653939Sbostic {
11746324Sbostic 	VAR *v;
11853939Sbostic 
11953939Sbostic 	v = ve->var;
12053939Sbostic 	(void)printf("%-*s", v->width, KI_PROC(k)->p_comm);
12146324Sbostic }
12246324Sbostic 
12353939Sbostic void
logname(k,ve)12453939Sbostic logname(k, ve)
12546324Sbostic 	KINFO *k;
12653939Sbostic 	VARENT *ve;
12753939Sbostic {
12846324Sbostic 	VAR *v;
12953939Sbostic 
13053939Sbostic 	v = ve->var;
13147668Skarels #ifndef NEWVM
13253939Sbostic 	(void)printf("%-*s", v->width, KI_PROC(k)->p_logname);
13364637Sbostic #else
13453939Sbostic 	(void)printf("%-*s", v->width, KI_EPROC(k)->e_login);
13564637Sbostic #endif
13646324Sbostic }
13746324Sbostic 
13853939Sbostic void
state(k,ve)13953939Sbostic state(k, ve)
14046324Sbostic 	KINFO *k;
14153939Sbostic 	VARENT *ve;
14253939Sbostic {
14366638Spendry 	struct proc *p;
14466638Spendry 	int flag;
14566638Spendry 	char *cp;
14646324Sbostic 	VAR *v;
14746324Sbostic 	char buf[16];
14846324Sbostic 
14953939Sbostic 	v = ve->var;
15053939Sbostic 	p = KI_PROC(k);
15153939Sbostic 	flag = p->p_flag;
15253939Sbostic 	cp = buf;
15353939Sbostic 
15446324Sbostic 	switch (p->p_stat) {
15546324Sbostic 
15646324Sbostic 	case SSTOP:
15746324Sbostic 		*cp = 'T';
15846324Sbostic 		break;
15946324Sbostic 
16046324Sbostic 	case SSLEEP:
16164637Sbostic 		if (flag & P_SINTR)	/* interuptable (long) */
16246324Sbostic 			*cp = p->p_slptime >= MAXSLP ? 'I' : 'S';
16346324Sbostic 		else
16454704Sbostic 			*cp = 'D';
16546324Sbostic 		break;
16646324Sbostic 
16746324Sbostic 	case SRUN:
16846324Sbostic 	case SIDL:
16946324Sbostic 		*cp = 'R';
17046324Sbostic 		break;
17146324Sbostic 
17246324Sbostic 	case SZOMB:
17346324Sbostic 		*cp = 'Z';
17446324Sbostic 		break;
17546324Sbostic 
17646324Sbostic 	default:
17746324Sbostic 		*cp = '?';
17846324Sbostic 	}
17946324Sbostic 	cp++;
18064637Sbostic 	if (flag & P_INMEM) {
18147668Skarels #ifndef NEWVM
18246324Sbostic 		if (p->p_rssize > p->p_maxrss)
18346324Sbostic 			*cp++ = '>';
18447668Skarels #endif
18546324Sbostic 	} else
18646324Sbostic 		*cp++ = 'W';
18746324Sbostic 	if (p->p_nice < NZERO)
18846324Sbostic 		*cp++ = '<';
18946324Sbostic 	else if (p->p_nice > NZERO)
19046324Sbostic 		*cp++ = 'N';
19149242Skarels #ifndef NEWVM
19246324Sbostic 	if (flag & SUANOM)
19346324Sbostic 		*cp++ = 'A';
19446324Sbostic 	else if (flag & SSEQL)
19546324Sbostic 		*cp++ = 'S';
19649242Skarels #endif
19764637Sbostic 	if (flag & P_TRACED)
19846324Sbostic 		*cp++ = 'X';
19964637Sbostic 	if (flag & P_WEXIT && p->p_stat != SZOMB)
20046324Sbostic 		*cp++ = 'E';
20147668Skarels #ifdef NEWVM
20264637Sbostic 	if (flag & P_PPWAIT)
20347668Skarels #else
20446324Sbostic 	if (flag & SVFORK)
20547668Skarels #endif
20646324Sbostic 		*cp++ = 'V';
20749242Skarels #ifdef NEWVM
20864637Sbostic 	if (flag & (P_SYSTEM | P_NOSWAP | P_PHYSIO))
20949242Skarels #else
21046324Sbostic 	if (flag & (SSYS|SLOCK|SULOCK|SKEEP|SPHYSIO))
21149242Skarels #endif
21246324Sbostic 		*cp++ = 'L';
21353122Smckusick 	if (KI_EPROC(k)->e_flag & EPROC_SLEADER)
21446324Sbostic 		*cp++ = 's';
21564637Sbostic 	if ((flag & P_CONTROLT) && KI_EPROC(k)->e_pgid == KI_EPROC(k)->e_tpgid)
21646324Sbostic 		*cp++ = '+';
21746324Sbostic 	*cp = '\0';
21853939Sbostic 	(void)printf("%-*s", v->width, buf);
21946324Sbostic }
22046324Sbostic 
22153939Sbostic void
pri(k,ve)22253939Sbostic pri(k, ve)
22346324Sbostic 	KINFO *k;
22453939Sbostic 	VARENT *ve;
22553939Sbostic {
22646324Sbostic 	VAR *v;
22753939Sbostic 
22853939Sbostic 	v = ve->var;
22964568Sbostic 	(void)printf("%*d", v->width, KI_PROC(k)->p_priority - PZERO);
23046324Sbostic }
23146324Sbostic 
23253939Sbostic void
uname(k,ve)23353939Sbostic uname(k, ve)
23446324Sbostic 	KINFO *k;
23553939Sbostic 	VARENT *ve;
23653939Sbostic {
23746324Sbostic 	VAR *v;
23853939Sbostic 
23953939Sbostic 	v = ve->var;
24047668Skarels #ifndef NEWVM
24159507Sbostic 	(void)printf("%-*s",
24259507Sbostic 	    (int)v->width, user_from_uid(KI_PROC(k)->p_uid, 0));
24359507Sbostic #else
24459507Sbostic 	(void)printf("%-*s",
24559507Sbostic 	    (int)v->width, user_from_uid(KI_EPROC(k)->e_ucred.cr_uid, 0));
24659507Sbostic #endif
24746324Sbostic }
24846324Sbostic 
24953939Sbostic void
runame(k,ve)25053939Sbostic runame(k, ve)
25146324Sbostic 	KINFO *k;
25253939Sbostic 	VARENT *ve;
25353939Sbostic {
25446324Sbostic 	VAR *v;
25553939Sbostic 
25653939Sbostic 	v = ve->var;
25747668Skarels #ifndef NEWVM
25859507Sbostic 	(void)printf("%-*s",
25959507Sbostic 	    (int)v->width, user_from_uid(KI_PROC(k)->p_ruid, 0));
26059507Sbostic #else
26159507Sbostic 	(void)printf("%-*s",
26259507Sbostic 	    (int)v->width, user_from_uid(KI_EPROC(k)->e_pcred.p_ruid, 0));
26359507Sbostic #endif
26446324Sbostic }
26546324Sbostic 
26653939Sbostic void
tdev(k,ve)26753939Sbostic tdev(k, ve)
26846324Sbostic 	KINFO *k;
26953939Sbostic 	VARENT *ve;
27053939Sbostic {
27146324Sbostic 	VAR *v;
27253939Sbostic 	dev_t dev;
27353939Sbostic 	char buff[16];
27446324Sbostic 
27553939Sbostic 	v = ve->var;
27653939Sbostic 	dev = KI_EPROC(k)->e_tdev;
27746324Sbostic 	if (dev == NODEV)
27853939Sbostic 		(void)printf("%*s", v->width, "??");
27946324Sbostic 	else {
28053939Sbostic 		(void)snprintf(buff, sizeof(buff),
28153939Sbostic 		    "%d/%d", major(dev), minor(dev));
28253939Sbostic 		(void)printf("%*s", v->width, buff);
28346324Sbostic 	}
28446324Sbostic }
28546324Sbostic 
28653939Sbostic void
tname(k,ve)28753939Sbostic tname(k, ve)
28846324Sbostic 	KINFO *k;
28953939Sbostic 	VARENT *ve;
29053939Sbostic {
29146324Sbostic 	VAR *v;
29246324Sbostic 	dev_t dev;
29353939Sbostic 	char *ttname;
29446324Sbostic 
29553939Sbostic 	v = ve->var;
29653122Smckusick 	dev = KI_EPROC(k)->e_tdev;
29746324Sbostic 	if (dev == NODEV || (ttname = devname(dev, S_IFCHR)) == NULL)
29853939Sbostic 		(void)printf("%-*s", v->width, "??");
29946324Sbostic 	else {
30046324Sbostic 		if (strncmp(ttname, "tty", 3) == 0)
30146324Sbostic 			ttname += 3;
30253939Sbostic 		(void)printf("%*.*s%c", v->width-1, v->width-1, ttname,
30353122Smckusick 			KI_EPROC(k)->e_flag & EPROC_CTTY ? ' ' : '-');
30446324Sbostic 	}
30546324Sbostic }
30646324Sbostic 
30753939Sbostic void
longtname(k,ve)30853939Sbostic longtname(k, ve)
30946324Sbostic 	KINFO *k;
31053939Sbostic 	VARENT *ve;
31153939Sbostic {
31246324Sbostic 	VAR *v;
31346324Sbostic 	dev_t dev;
31453939Sbostic 	char *ttname;
31546324Sbostic 
31653939Sbostic 	v = ve->var;
31753122Smckusick 	dev = KI_EPROC(k)->e_tdev;
31846324Sbostic 	if (dev == NODEV || (ttname = devname(dev, S_IFCHR)) == NULL)
31953939Sbostic 		(void)printf("%-*s", v->width, "??");
32046324Sbostic 	else
32153939Sbostic 		(void)printf("%-*s", v->width, ttname);
32246324Sbostic }
32346324Sbostic 
32453939Sbostic void
started(k,ve)32553939Sbostic started(k, ve)
32646324Sbostic 	KINFO *k;
32753939Sbostic 	VARENT *ve;
32853939Sbostic {
32946324Sbostic 	VAR *v;
33046324Sbostic 	static time_t now;
33146324Sbostic 	struct tm *tp;
33246324Sbostic 	char buf[100];
33346324Sbostic 
33453939Sbostic 	v = ve->var;
33553122Smckusick 	if (!k->ki_u.u_valid) {
33653939Sbostic 		(void)printf("%-*s", v->width, "-");
33746324Sbostic 		return;
33846324Sbostic 	}
33946324Sbostic 
34053122Smckusick 	tp = localtime(&k->ki_u.u_start.tv_sec);
34146324Sbostic 	if (!now)
34246324Sbostic 		(void)time(&now);
34353122Smckusick 	if (now - k->ki_u.u_start.tv_sec < 24 * SECSPERHOUR) {
34466638Spendry 		/* I *hate* SCCS... */
34566638Spendry 		static char fmt[] = __CONCAT("%l:%", "M%p");
34653939Sbostic 		(void)strftime(buf, sizeof(buf) - 1, fmt, tp);
34753122Smckusick 	} else if (now - k->ki_u.u_start.tv_sec < 7 * SECSPERDAY) {
34866638Spendry 		/* I *hate* SCCS... */
34966638Spendry 		static char fmt[] = __CONCAT("%a%", "I%p");
35053939Sbostic 		(void)strftime(buf, sizeof(buf) - 1, fmt, tp);
35146326Sbostic 	} else
35253939Sbostic 		(void)strftime(buf, sizeof(buf) - 1, "%e%b%y", tp);
35353939Sbostic 	(void)printf("%-*s", v->width, buf);
35446324Sbostic }
35546324Sbostic 
35653939Sbostic void
lstarted(k,ve)35753939Sbostic lstarted(k, ve)
35846324Sbostic 	KINFO *k;
35953939Sbostic 	VARENT *ve;
36053939Sbostic {
36146324Sbostic 	VAR *v;
36246324Sbostic 	char buf[100];
36346324Sbostic 
36453939Sbostic 	v = ve->var;
36553122Smckusick 	if (!k->ki_u.u_valid) {
36653939Sbostic 		(void)printf("%-*s", v->width, "-");
36746324Sbostic 		return;
36846324Sbostic 	}
36953939Sbostic 	(void)strftime(buf, sizeof(buf) -1, "%C",
37053122Smckusick 	    localtime(&k->ki_u.u_start.tv_sec));
37153939Sbostic 	(void)printf("%-*s", v->width, buf);
37246324Sbostic }
37346324Sbostic 
37453939Sbostic void
wchan(k,ve)37553939Sbostic wchan(k, ve)
37646324Sbostic 	KINFO *k;
37753939Sbostic 	VARENT *ve;
37853939Sbostic {
37946324Sbostic 	VAR *v;
38053939Sbostic 
38153939Sbostic 	v = ve->var;
38253122Smckusick 	if (KI_PROC(k)->p_wchan) {
38353122Smckusick 		if (KI_PROC(k)->p_wmesg)
38453939Sbostic 			(void)printf("%-*.*s", v->width, v->width,
38553122Smckusick 				      KI_EPROC(k)->e_wmesg);
38646324Sbostic 		else
38753939Sbostic 			(void)printf("%-*x", v->width,
38853122Smckusick 			    (int)KI_PROC(k)->p_wchan &~ KERNBASE);
38946324Sbostic 	} else
39053939Sbostic 		(void)printf("%-*s", v->width, "-");
39146324Sbostic }
39246324Sbostic 
39346324Sbostic #define pgtok(a)        (((a)*NBPG)/1024)
39446324Sbostic 
39553939Sbostic void
vsize(k,ve)39653939Sbostic vsize(k, ve)
39746324Sbostic 	KINFO *k;
39853939Sbostic 	VARENT *ve;
39953939Sbostic {
40046324Sbostic 	VAR *v;
40153939Sbostic 
40253939Sbostic 	v = ve->var;
40353939Sbostic 	(void)printf("%*d", v->width,
40447668Skarels #ifndef NEWVM
40564637Sbostic 	    pgtok(KI_PROC(k)->p_dsize +
40664637Sbostic 	        KI_PROC(k)->p_ssize + KI_EPROC(k)->e_xsize));
40764637Sbostic #else
40853122Smckusick 	    pgtok(KI_EPROC(k)->e_vm.vm_dsize + KI_EPROC(k)->e_vm.vm_ssize +
40953122Smckusick 		KI_EPROC(k)->e_vm.vm_tsize));
41064637Sbostic #endif
41146324Sbostic }
41246324Sbostic 
41353939Sbostic void
rssize(k,ve)41453939Sbostic rssize(k, ve)
41546324Sbostic 	KINFO *k;
41653939Sbostic 	VARENT *ve;
41753939Sbostic {
41846324Sbostic 	VAR *v;
41953939Sbostic 
42053939Sbostic 	v = ve->var;
42147668Skarels #ifndef NEWVM
42253939Sbostic 	(void)printf("%*d", v->width,
42353122Smckusick 	    pgtok(KI_PROC(k)->p_rssize + (KI_EPROC(k)->e_xccount ?
42453122Smckusick 	    (KI_EPROC(k)->e_xrssize / KI_EPROC(k)->e_xccount) : 0)));
42564637Sbostic #else
42647668Skarels 	/* XXX don't have info about shared */
42753939Sbostic 	(void)printf("%*d", v->width, pgtok(KI_EPROC(k)->e_vm.vm_rssize));
42864637Sbostic #endif
42946324Sbostic }
43046324Sbostic 
43153939Sbostic void
p_rssize(k,ve)43253939Sbostic p_rssize(k, ve)		/* doesn't account for text */
43346324Sbostic 	KINFO *k;
43453939Sbostic 	VARENT *ve;
43553939Sbostic {
43646324Sbostic 	VAR *v;
43753939Sbostic 
43853939Sbostic 	v = ve->var;
43947668Skarels #ifndef NEWVM
44053939Sbostic 	(void)printf("%*d", v->width, pgtok(KI_PROC(k)->p_rssize));
44164637Sbostic #else
44253939Sbostic 	(void)printf("%*d", v->width, pgtok(KI_EPROC(k)->e_vm.vm_rssize));
44364637Sbostic #endif
44446324Sbostic }
44546324Sbostic 
44653939Sbostic void
cputime(k,ve)44753939Sbostic cputime(k, ve)
44846324Sbostic 	KINFO *k;
44953939Sbostic 	VARENT *ve;
45046324Sbostic {
45153939Sbostic 	VAR *v;
45246324Sbostic 	long secs;
45346324Sbostic 	long psecs;	/* "parts" of a second. first micro, then centi */
45446324Sbostic 	char obuff[128];
45546324Sbostic 
45653939Sbostic 	v = ve->var;
45753122Smckusick 	if (KI_PROC(k)->p_stat == SZOMB || !k->ki_u.u_valid) {
45846324Sbostic 		secs = 0;
45946324Sbostic 		psecs = 0;
46046324Sbostic 	} else {
46154869Storek 		/*
46254869Storek 		 * This counts time spent handling interrupts.  We could
46354869Storek 		 * fix this, but it is not 100% trivial (and interrupt
46454869Storek 		 * time fractions only work on the sparc anyway).	XXX
46554869Storek 		 */
46654869Storek 		secs = KI_PROC(k)->p_rtime.tv_sec;
46754869Storek 		psecs = KI_PROC(k)->p_rtime.tv_usec;
46846324Sbostic 		if (sumrusage) {
46953122Smckusick 			secs += k->ki_u.u_cru.ru_utime.tv_sec +
47053122Smckusick 				k->ki_u.u_cru.ru_stime.tv_sec;
47153122Smckusick 			psecs += k->ki_u.u_cru.ru_utime.tv_usec +
47253122Smckusick 				k->ki_u.u_cru.ru_stime.tv_usec;
47346324Sbostic 		}
47446324Sbostic 		/*
47546324Sbostic 		 * round and scale to 100's
47646324Sbostic 		 */
47746324Sbostic 		psecs = (psecs + 5000) / 10000;
47847595Sbostic 		secs += psecs / 100;
47947595Sbostic 		psecs = psecs % 100;
48046324Sbostic 	}
48153939Sbostic 	(void)snprintf(obuff, sizeof(obuff),
48253939Sbostic 	    "%3ld:%02ld.%02ld", secs/60, secs%60, psecs);
48353939Sbostic 	(void)printf("%*s", v->width, obuff);
48446324Sbostic }
48546324Sbostic 
48646324Sbostic double
getpcpu(k)48746324Sbostic getpcpu(k)
48846324Sbostic 	KINFO *k;
48946324Sbostic {
49046324Sbostic 	struct proc *p;
49146324Sbostic 	static int failure;
49246324Sbostic 
49346324Sbostic 	if (!nlistread)
49446324Sbostic 		failure = donlist();
49546324Sbostic 	if (failure)
49646324Sbostic 		return (0.0);
49746324Sbostic 
49853122Smckusick 	p = KI_PROC(k);
49946324Sbostic #define	fxtofl(fixpt)	((double)(fixpt) / fscale)
50046324Sbostic 
50146324Sbostic 	/* XXX - I don't like this */
50264637Sbostic 	if (p->p_swtime == 0 || (p->p_flag & P_INMEM) == 0)
50346324Sbostic 		return (0.0);
50446324Sbostic 	if (rawcpu)
50546324Sbostic 		return (100.0 * fxtofl(p->p_pctcpu));
50646324Sbostic 	return (100.0 * fxtofl(p->p_pctcpu) /
50764568Sbostic 		(1.0 - exp(p->p_swtime * log(fxtofl(ccpu)))));
50846324Sbostic }
50946324Sbostic 
51053939Sbostic void
pcpu(k,ve)51153939Sbostic pcpu(k, ve)
51246324Sbostic 	KINFO *k;
51353939Sbostic 	VARENT *ve;
51453939Sbostic {
51546324Sbostic 	VAR *v;
51653939Sbostic 
51753939Sbostic 	v = ve->var;
51853939Sbostic 	(void)printf("%*.1f", v->width, getpcpu(k));
51946324Sbostic }
52046324Sbostic 
52146324Sbostic double
getpmem(k)52246324Sbostic getpmem(k)
52346324Sbostic 	KINFO *k;
52446324Sbostic {
52546324Sbostic 	static int failure;
52646324Sbostic 	struct proc *p;
52746324Sbostic 	struct eproc *e;
52846324Sbostic 	double fracmem;
52946324Sbostic 	int szptudot;
53046324Sbostic 
53146324Sbostic 	if (!nlistread)
53246324Sbostic 		failure = donlist();
53346324Sbostic 	if (failure)
53446324Sbostic 		return (0.0);
53546324Sbostic 
53653122Smckusick 	p = KI_PROC(k);
53753122Smckusick 	e = KI_EPROC(k);
53864637Sbostic 	if ((p->p_flag & P_INMEM) == 0)
53946324Sbostic 		return (0.0);
54047668Skarels #ifndef NEWVM
54146324Sbostic 	szptudot = UPAGES + clrnd(ctopt(p->p_dsize + p->p_ssize + e->e_xsize));
54250380Skarels 	fracmem = ((float)p->p_rssize + szptudot)/CLSIZE/mempages;
54346324Sbostic 	if (p->p_textp && e->e_xccount)
54450380Skarels 		fracmem += ((float)e->e_xrssize)/CLSIZE/e->e_xccount/mempages;
54564637Sbostic #else
54647668Skarels 	/* XXX want pmap ptpages, segtab, etc. (per architecture) */
54747668Skarels 	szptudot = UPAGES;
54847668Skarels 	/* XXX don't have info about shared */
54950380Skarels 	fracmem = ((float)e->e_vm.vm_rssize + szptudot)/CLSIZE/mempages;
55064637Sbostic #endif
55146324Sbostic 	return (100.0 * fracmem);
55246324Sbostic }
55346324Sbostic 
55453939Sbostic void
pmem(k,ve)55553939Sbostic pmem(k, ve)
55646324Sbostic 	KINFO *k;
55753939Sbostic 	VARENT *ve;
55853939Sbostic {
55946324Sbostic 	VAR *v;
56053939Sbostic 
56153939Sbostic 	v = ve->var;
56253939Sbostic 	(void)printf("%*.1f", v->width, getpmem(k));
56346324Sbostic }
56446324Sbostic 
56553939Sbostic void
pagein(k,ve)56653939Sbostic pagein(k, ve)
56746324Sbostic 	KINFO *k;
56853939Sbostic 	VARENT *ve;
56953939Sbostic {
57046324Sbostic 	VAR *v;
57153939Sbostic 
57253939Sbostic 	v = ve->var;
57353939Sbostic 	(void)printf("%*d", v->width,
57453939Sbostic 	    k->ki_u.u_valid ? k->ki_u.u_ru.ru_majflt : 0);
57546324Sbostic }
57646324Sbostic 
57753939Sbostic void
maxrss(k,ve)57853939Sbostic maxrss(k, ve)
57946324Sbostic 	KINFO *k;
58053939Sbostic 	VARENT *ve;
58153939Sbostic {
58246324Sbostic 	VAR *v;
58353939Sbostic 
58453939Sbostic 	v = ve->var;
58547668Skarels #ifndef NEWVM	/* not yet */
58653122Smckusick 	if (KI_PROC(k)->p_maxrss != (RLIM_INFINITY/NBPG))
58753939Sbostic 		(void)printf("%*d", v->width, pgtok(KI_PROC(k)->p_maxrss));
58846324Sbostic 	else
58964637Sbostic #endif
59053939Sbostic 		(void)printf("%*s", v->width, "-");
59146324Sbostic }
59246324Sbostic 
59353939Sbostic void
tsize(k,ve)59453939Sbostic tsize(k, ve)
59546324Sbostic 	KINFO *k;
59653939Sbostic 	VARENT *ve;
59753939Sbostic {
59846324Sbostic 	VAR *v;
59953939Sbostic 
60053939Sbostic 	v = ve->var;
60147668Skarels #ifndef NEWVM
60253939Sbostic 	(void)printf("%*d", v->width, pgtok(KI_EPROC(k)->e_xsize));
60364637Sbostic #else
60453939Sbostic 	(void)printf("%*d", v->width, pgtok(KI_EPROC(k)->e_vm.vm_tsize));
60564637Sbostic #endif
60646324Sbostic }
60746324Sbostic 
60847668Skarels #ifndef NEWVM
60953939Sbostic void
trss(k,ve)61053939Sbostic trss(k, ve)
61146324Sbostic 	KINFO *k;
61253939Sbostic 	VARENT *ve;
61353939Sbostic {
61446324Sbostic 	VAR *v;
61553939Sbostic 
61653939Sbostic 	v = ve->var;
61753939Sbostic 	(void)printf("%*d", v->width, pgtok(KI_EPROC(k)->e_xrssize));
61846324Sbostic }
61964637Sbostic #endif
62046324Sbostic 
62146324Sbostic /*
62246324Sbostic  * Generic output routines.  Print fields from various prototype
62346324Sbostic  * structures.
62446324Sbostic  */
62566638Spendry static void
printval(bp,v)62666638Spendry printval(bp, v)
62766638Spendry 	char *bp;
62866638Spendry 	VAR *v;
62966638Spendry {
63066638Spendry 	static char ofmt[32] = "%";
63166638Spendry 	char *fcp, *cp;
63266638Spendry 
63366638Spendry 	cp = ofmt + 1;
63466638Spendry 	fcp = v->fmt;
63566638Spendry 	if (v->flag & LJUST)
63666638Spendry 		*cp++ = '-';
63766638Spendry 	*cp++ = '*';
63866638Spendry 	while (*cp++ = *fcp++);
63966638Spendry 
64066638Spendry 	switch (v->type) {
64166638Spendry 	case CHAR:
64266638Spendry 		(void)printf(ofmt, v->width, *(char *)bp);
64366638Spendry 		break;
64466638Spendry 	case UCHAR:
64566638Spendry 		(void)printf(ofmt, v->width, *(u_char *)bp);
64666638Spendry 		break;
64766638Spendry 	case SHORT:
64866638Spendry 		(void)printf(ofmt, v->width, *(short *)bp);
64966638Spendry 		break;
65066638Spendry 	case USHORT:
65166638Spendry 		(void)printf(ofmt, v->width, *(u_short *)bp);
65266638Spendry 		break;
65366638Spendry 	case LONG:
65466638Spendry 		(void)printf(ofmt, v->width, *(long *)bp);
65566638Spendry 		break;
65666638Spendry 	case ULONG:
65766638Spendry 		(void)printf(ofmt, v->width, *(u_long *)bp);
65866638Spendry 		break;
65966638Spendry 	case KPTR:
66066638Spendry 		(void)printf(ofmt, v->width, *(u_long *)bp &~ KERNBASE);
66166638Spendry 		break;
66266638Spendry 	default:
66366638Spendry 		errx(1, "unknown type %d", v->type);
66466638Spendry 	}
66566638Spendry }
66666638Spendry 
66753939Sbostic void
pvar(k,ve)66853939Sbostic pvar(k, ve)
66946324Sbostic 	KINFO *k;
67053939Sbostic 	VARENT *ve;
67153939Sbostic {
67246324Sbostic 	VAR *v;
67353939Sbostic 
67453939Sbostic 	v = ve->var;
67553122Smckusick 	printval((char *)((char *)KI_PROC(k) + v->off), v);
67646324Sbostic }
67746324Sbostic 
67853939Sbostic void
evar(k,ve)67953939Sbostic evar(k, ve)
68046324Sbostic 	KINFO *k;
68153939Sbostic 	VARENT *ve;
68253939Sbostic {
68346324Sbostic 	VAR *v;
68453939Sbostic 
68553939Sbostic 	v = ve->var;
68653122Smckusick 	printval((char *)((char *)KI_EPROC(k) + v->off), v);
68746324Sbostic }
68846324Sbostic 
68953939Sbostic void
uvar(k,ve)69053939Sbostic uvar(k, ve)
69146324Sbostic 	KINFO *k;
69253939Sbostic 	VARENT *ve;
69353939Sbostic {
69446324Sbostic 	VAR *v;
69553939Sbostic 
69653939Sbostic 	v = ve->var;
69753122Smckusick 	if (k->ki_u.u_valid)
69853122Smckusick 		printval((char *)((char *)&k->ki_u + v->off), v);
69946324Sbostic 	else
70053939Sbostic 		(void)printf("%*s", v->width, "-");
70146324Sbostic }
70246324Sbostic 
70353939Sbostic void
rvar(k,ve)70453939Sbostic rvar(k, ve)
70546324Sbostic 	KINFO *k;
70653939Sbostic 	VARENT *ve;
70753939Sbostic {
70846324Sbostic 	VAR *v;
70953939Sbostic 
71053939Sbostic 	v = ve->var;
71153122Smckusick 	if (k->ki_u.u_valid)
71253122Smckusick 		printval((char *)((char *)(&k->ki_u.u_ru) + v->off), v);
71346324Sbostic 	else
71453939Sbostic 		(void)printf("%*s", v->width, "-");
71546324Sbostic }
716