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