- width = twidth - cmdstart - 2;
- if (width < 0)
- width = 0;
- qsort((char *) savcom, npr, sizeof(savcom[0]), pscomp);
- for (i=0; i<npr; i++) {
- register struct savcom *sp = &savcom[i];
- if (lflg)
- lpr(sp);
- else if (vflg)
- vpr(sp);
- else if (uflg)
- upr(sp);
- else
- spr(sp);
- if (sp->ap->a_stat == SZOMB)
- printf(" <defunct>");
- else if (sp->ap->a_flag & SWEXIT)
- printf(" <exiting>");
- else if (sp->ap->a_pid == 0)
- printf(" swapper");
- else if (sp->ap->a_pid == 2)
- printf(" pagedaemon");
- else
- printf(" %.*s", twidth - cmdstart - 2, sp->ap->a_cmdp);
- printf("\n");
- }
- exit(npr == 0);
-}
-
-getw(loc)
- unsigned long loc;
-{
- int word;
-
- klseek(kmem, (long)loc, 0);
- if (read(kmem, (char *)&word, sizeof (word)) != sizeof (word))
- printf("error reading kmem at %x\n", loc);
- return (word);
-}
-
-klseek(fd, loc, off)
- int fd;
- long loc;
- int off;
-{
- if (kflg) {
- if ((loc = vtophys(loc)) == -1)
- return;
- }
- (void) lseek(fd, (long)loc, off);
-}
-
-writepsdb(unixname)
- char *unixname;
-{
- register FILE *fp;
- struct lttys *lt;
-
- setgid(getgid());
- setuid(getuid());
- if ((fp = fopen(psdb, "w")) == NULL) {
- perror(psdb);
- exit(1);
- } else
- fchmod(fileno(fp), 0644);
- fwrite((char *) &nllen, sizeof nllen, 1, fp);
- fwrite((char *) nl, sizeof (struct nlist), nllen, fp);
- fwrite((char *) cand, sizeof (cand), 1, fp);
- fwrite((char *) &nttys, sizeof nttys, 1, fp);
- for (lt = lallttys ; lt ; lt = lt->next)
- fwrite((char *)<->ttys, sizeof (struct ttys), 1, fp);
- fwrite((char *) &nchans, sizeof nchans, 1, fp);
- fwrite((char *) wchanhd, sizeof (struct wchan), nchans, fp);
- fwrite((char *) wchan_index, sizeof (caddr_t), NWCINDEX, fp);
- fwrite(unixname, strlen(unixname) + 1, 1, fp);
- fclose(fp);
-}
-
-readpsdb(unixname)
- char *unixname;
-{
- register i;
- register FILE *fp;
- char unamebuf[BUFSIZ];
- char *p = unamebuf;
- extern int errno;
-
- if ((fp = fopen(psdb, "r")) == NULL) {
- if (errno == ENOENT)
- return (0);
- perror(psdb);
- exit(1);
- }
-
- fread((char *) &nllen, sizeof nllen, 1, fp);
- nl = (struct nlist *) malloc (nllen * sizeof (struct nlist));
- fread((char *) nl, sizeof (struct nlist), nllen, fp);
- fread((char *) cand, sizeof (cand), 1, fp);
- fread((char *) &nttys, sizeof nttys, 1, fp);
- allttys = (struct ttys *)malloc(sizeof(struct ttys)*nttys);
- if (allttys == NULL) {
- fprintf(stderr, "ps: Can't malloc space for tty table\n");
- exit(1);
- }
- fread((char *) allttys, sizeof (struct ttys), nttys, fp);
- fread((char *) &nchans, sizeof nchans, 1, fp);
- wchanhd = (struct wchan *) malloc(nchans * sizeof (struct wchan));
- if (wchanhd == NULL) {
- fprintf(stderr, "ps: Can't malloc space for wait channels\n");
- nflg++;
- fseek(fp, (long) nchans * sizeof (struct wchan), 1);
- } else
- fread((char *) wchanhd, sizeof (struct wchan), nchans, fp);
- fread((char *) wchan_index, sizeof (caddr_t), NWCINDEX, fp);
- while ((*p = getc(fp)) != '\0')
- p++;
- return (strcmp(unixname, unamebuf) == 0);
-}
-
-openfiles(argc, argv)
- char **argv;
-{
-
- kmemf = "/dev/kmem";
- if (kflg)
- kmemf = argc > 2 ? argv[2] : "/vmcore";
- kmem = open(kmemf, 0);
- if (kmem < 0) {
- perror(kmemf);
- exit(1);
- }
- if (kflg) {
- mem = kmem;
- memf = kmemf;
- } else {
- memf = "/dev/mem";
- mem = open(memf, 0);
- if (mem < 0) {
- perror(memf);
- exit(1);
- }
- }
- if (kflg == 0 || argc > 3) {
- swapf = argc>3 ? argv[3]: "/dev/drum";
- swap = open(swapf, 0);
- if (swap < 0) {
- perror(swapf);
- exit(1);
- }
- }
-}
-
-getkvars(argc, argv)
- char **argv;
-{
- int faildb = 0; /* true if psdatabase init failed */
-
- nlistf = argc > 1 ? argv[1] : "/vmunix";
- if (Uflg) {
- init_nlist();
- nlist(nlistf, nl);
- getvchans();
- getdev();
- writepsdb(nlistf);
- exit (0);
- } else if (!readpsdb(nlistf)) {
- init_nlist();
- if (!kflg)
- nl[X_SYSMAP].n_un.n_name = "";
- faildb = 1;
- nlist(nlistf, nl);
- nttys = 0;
- getdev();
- }
-
- if (nl[0].n_type == 0) {
- fprintf(stderr, "%s: No namelist\n", nlistf);
- exit(1);
- }
- if (kflg) {
- /* We must do the sys map first because klseek uses it */
- long addr;
-
- Syssize = nl[X_SYSSIZE].n_value;
- Sysmap = (struct pte *)
- calloc((unsigned) Syssize, sizeof (struct pte));
- if (Sysmap == NULL) {
- fprintf(stderr, "Out of space for Sysmap\n");
- exit(1);
- }
- addr = (long) nl[X_SYSMAP].n_value;
- addr &= ~0x80000000;
- (void) lseek(kmem, addr, 0);
- read(kmem, (char *) Sysmap, Syssize * sizeof (struct pte));
- }
- if (faildb)
- getvchans();
- usrpt = (struct pte *)nl[X_USRPT].n_value;
- Usrptmap = (struct pte *)nl[X_USRPTMAP].n_value;
- klseek(kmem, (long)nl[X_NSWAP].n_value, 0);
- if (read(kmem, (char *)&nswap, sizeof (nswap)) != sizeof (nswap)) {
- cantread("nswap", kmemf);
- exit(1);
- }
- klseek(kmem, (long)nl[X_MAXSLP].n_value, 0);
- if (read(kmem, (char *)&maxslp, sizeof (maxslp)) != sizeof (maxslp)) {
- cantread("maxslp", kmemf);
- exit(1);
- }
- klseek(kmem, (long)nl[X_CCPU].n_value, 0);
- if (read(kmem, (char *)&ccpu, sizeof (ccpu)) != sizeof (ccpu)) {
- cantread("ccpu", kmemf);
- exit(1);
- }
- klseek(kmem, (long)nl[X_ECMX].n_value, 0);
- if (read(kmem, (char *)&ecmx, sizeof (ecmx)) != sizeof (ecmx)) {
- cantread("ecmx", kmemf);
- exit(1);
- }
- if (uflg || vflg) {
- ntext = getw(nl[X_NTEXT].n_value);
- text = (struct text *)
- calloc((unsigned) ntext, sizeof (struct text));
- if (text == 0) {
- fprintf(stderr, "no room for text table\n");
- exit(1);
- }
- atext = (struct text *)getw(nl[X_TEXT].n_value);
- klseek(kmem, (long)atext, 0);
- if (read(kmem, (char *)text, ntext * sizeof (struct text))
- != ntext * sizeof (struct text)) {
- cantread("text table", kmemf);
- exit(1);
- }
- }
- dmmin = getw(nl[X_DMMIN].n_value);
- dmmax = getw(nl[X_DMMAX].n_value);
-}
-
-/*
- * get the valloc'ed kernel variables for symbolic wait channels
- */
-getvchans()
-{
- int i, tmp;
-
- if (nflg)
- return;
-
-#define addv(i) addchan(&nl[i].n_un.n_name[1], getw(nl[i].n_value))
- addv(X_INODE);
- addv(X_FILE);
- addv(X_PROC);
- addv(X_TEXT);
- addv(X_CFREE);
- addv(X_CALLOUT);
- addv(X_SWAPMAP);
- addv(X_ARGMAP);
- addv(X_KERNELMAP);
- addv(X_MBMAP);
- addv(X_NCH);
- if (nl[X_QUOTA].n_value != 0) { /* these are #ifdef QUOTA */
- addv(X_QUOTA);
- addv(X_DQUOT);
- }
- addv(X_SWBUF);
- addv(X_BUF);
- addv(X_CMAP);
- addv(X_BUFFERS);
- qsort(wchanhd, nchans, sizeof (struct wchan), wchancomp);
- for (i = 0; i < NWCINDEX; i++) {
- tmp = i * nchans;
- wchan_index[i] = wchanhd[tmp / NWCINDEX].wc_caddr;
- }
-#undef addv
-}
-printhdr()
-{
- char *hdr;
-
- if (sflg+lflg+vflg+uflg > 1) {
- fprintf(stderr, "ps: specify only one of s,l,v and u\n");
- exit(1);
- }
- if (lflg) {
- if (nflg)
- wcwidth = 6;
- else if (twidth > WTSIZ)
- wcwidth = -WNAMESIZ;
- else
- wcwidth = -WSNAMESIZ;
- if ((hdr = malloc(strlen(lhdr) + WNAMESIZ)) == NULL) {
- fprintf(stderr, "ps: out of memory\n");
- exit(1);
- }
- sprintf(hdr, lhdr, wcwidth, "WCHAN");
- } else if (vflg)
- hdr = vhdr;
- else if (uflg) {
- /* add enough on so that it can hold the sprintf below */
- if ((hdr = malloc(strlen(uhdr) + 10)) == NULL) {
- fprintf(stderr, "ps: out of memory\n");
- exit(1);
- }
- sprintf(hdr, uhdr, nflg ? " UID" : "USER ");
- } else
- hdr = shdr;
- if (lflg+vflg+uflg+sflg == 0)
- hdr += strlen("SSIZ ");
- cmdstart = strlen(hdr);
- printf("%s COMMAND\n", hdr);
- (void) fflush(stdout);
-}
-
-cantread(what, fromwhat)
- char *what, *fromwhat;
-{
-
- fprintf(stderr, "ps: error reading %s from %s\n", what, fromwhat);
-}
-
-struct direct *dbuf;
-int dialbase;
-
-getdev()
-{
- register DIR *df;
- struct ttys *t;
- struct lttys *lt;
-
- if (chdir("/dev") < 0) {
- perror("/dev");
- exit(1);
- }
- dialbase = -1;
- if ((df = opendir(".")) == NULL) {
- fprintf(stderr, "Can't open . in /dev\n");
- exit(1);
- }
- while ((dbuf = readdir(df)) != NULL)
- maybetty();
- closedir(df);
- allttys = (struct ttys *)malloc(sizeof(struct ttys)*nttys);
- if (allttys == NULL) {
- fprintf(stderr, "ps: Can't malloc space for tty table\n");
- exit(1);
- }
- for (lt = lallttys, t = allttys; lt ; lt = lt->next, t++)
- *t = lt->ttys;
-}
-
-/*
- * Attempt to avoid stats by guessing minor device
- * numbers from tty names. Console is known,
- * know that r(hp|up|mt) are unlikely as are different mem's,
- * floppy, null, tty, etc.
- */
-maybetty()
-{
- register char *cp = dbuf->d_name;
- static struct lttys *dp;
- struct lttys *olddp;
- int x;
- struct stat stb;
-
- switch (cp[0]) {
-
- case 'c':
- if (!strcmp(cp, "console")) {
- x = 0;
- goto donecand;
- }
- /* cu[la]? are possible!?! don't rule them out */
- break;
-
- case 'd':
- if (!strcmp(cp, "drum"))
- return;
- break;
-
- case 'f':
- if (!strcmp(cp, "floppy"))
- return;
- break;
-
- case 'k':
- cp++;
- if (*cp == 'U')
- cp++;
- goto trymem;
-
- case 'r':
- cp++;
-#define is(a,b) cp[0] == 'a' && cp[1] == 'b'
- if (is(h,p) || is(r,a) || is(u,p) || is(h,k)
- || is(r,b) || is(m,t)) {
- cp += 2;
- if (isdigit(*cp) && cp[2] == 0)
- return;
- }
- break;
-
- case 'm':
-trymem:
- if (cp[0] == 'm' && cp[1] == 'e' && cp[2] == 'm' && cp[3] == 0)
- return;
- if (cp[0] == 'm' && cp[1] == 't')
- return;
- break;
-
- case 'n':
- if (!strcmp(cp, "null"))
- return;
- if (!strncmp(cp, "nrmt", 4))
- return;
- break;
-
- case 'p':
- if (cp[1] && cp[1] == 't' && cp[2] == 'y')
- return;
- break;
-
- case 'v':
- if ((cp[1] == 'a' || cp[1] == 'p') && isdigit(cp[2]) &&
- cp[3] == 0)
- return;
- break;
- }
- cp = dbuf->d_name + dbuf->d_namlen - 1;
- x = 0;
- if (cp[-1] == 'd') {
- if (dialbase == -1) {
- if (stat("ttyd0", &stb) == 0)
- dialbase = stb.st_rdev & 017;
- else
- dialbase = -2;
- }
- if (dialbase == -2)
- x = 0;
- else
- x = 11;
- }
- if (cp > dbuf->d_name && isdigit(cp[-1]) && isdigit(*cp))
- x += 10 * (cp[-1] - ' ') + cp[0] - '0';
- else if (*cp >= 'a' && *cp <= 'f')
- x += 10 + *cp - 'a';
- else if (isdigit(*cp))
- x += *cp - '0';
- else
- x = -1;
-donecand:
- olddp = dp;
- dp = (struct lttys *)malloc(sizeof(struct lttys));
- if (dp == NULL) {
- fprintf(stderr, "ps: Can't malloc space for tty table\n");
- exit(1);
- }
- if (lallttys == NULL)
- lallttys = dp;
- nttys++;
- if (olddp)
- olddp->next = dp;
- dp->next = NULL;
- (void) strcpy(dp->ttys.name, dbuf->d_name);
- if (Uflg) {
- if (stat(dp->ttys.name, &stb) == 0 &&
- (stb.st_mode&S_IFMT)==S_IFCHR)
- dp->ttys.ttyd = x = stb.st_rdev;
- else {
- nttys--;
- if (lallttys == dp)
- lallttys = NULL;
- free(dp);
- dp = olddp;
- if (dp)
- dp->next = NULL;
- return;
- }
- } else
- dp->ttys.ttyd = -1;
- if (x == -1)
- return;
- x &= 017;
- dp->ttys.cand = cand[x];
- cand[x] = nttys-1;
-}
-
-char *
-gettty()
-{
- register char *p;
- register struct ttys *dp;
- struct stat stb;
- int x;
-
- if (u.u_ttyp == 0)
- return("?");
- x = u.u_ttyd & 017;
- for (dp = &allttys[cand[x]]; dp != &allttys[-1];
- dp = &allttys[dp->cand]) {
- if (dp->ttyd == -1) {
- if (stat(dp->name, &stb) == 0 &&
- (stb.st_mode&S_IFMT)==S_IFCHR)
- dp->ttyd = stb.st_rdev;
- else
- dp->ttyd = -2;
- }
- if (dp->ttyd == u.u_ttyd)
- goto found;
- }
- /* ick */
- for (dp = allttys; dp < &allttys[nttys]; dp++) {
- if (dp->ttyd == -1) {
- if (stat(dp->name, &stb) == 0 &&
- (stb.st_mode&S_IFMT)==S_IFCHR)
- dp->ttyd = stb.st_rdev;
- else
- dp->ttyd = -2;
- }
- if (dp->ttyd == u.u_ttyd)
- goto found;
- }
- return ("?");
-found:
- p = dp->name;
- if (p[0]=='t' && p[1]=='t' && p[2]=='y')
- p += 3;
- return (p);
-}
-
-save()
-{
- register struct savcom *sp;
- register struct asav *ap;
- register char *cp;
- register struct text *xp;
- char *ttyp, *cmdp;
-
- if (mproc->p_stat != SZOMB && getu() == 0)
- return;
- ttyp = gettty();
- if (xflg == 0 && ttyp[0] == '?' || tptr && strncmp(tptr, ttyp, 2))
- return;
- sp = &savcom[npr];
- cmdp = getcmd();
- if (cmdp == 0)
- return;
- sp->ap = ap = (struct asav *)calloc(1, sizeof (struct asav));
- sp->ap->a_cmdp = cmdp;
-#define e(a,b) ap->a = mproc->b
- e(a_flag, p_flag); e(a_stat, p_stat); e(a_nice, p_nice);
- e(a_uid, p_uid); e(a_pid, p_pid); e(a_pri, p_pri);
- e(a_slptime, p_slptime); e(a_time, p_time);
- ap->a_tty[0] = ttyp[0];
- ap->a_tty[1] = ttyp[1] ? ttyp[1] : ' ';
- if (ap->a_stat == SZOMB) {
- ap->a_cpu = 0;
- } else {
- ap->a_size = mproc->p_dsize + mproc->p_ssize;
- e(a_rss, p_rssize);
- ap->a_ttyd = u.u_ttyd;
- ap->a_cpu = u.u_ru.ru_utime.tv_sec + u.u_ru.ru_stime.tv_sec;
- if (sumcpu)
- ap->a_cpu += u.u_cru.ru_utime.tv_sec + u.u_cru.ru_stime.tv_sec;
- if (mproc->p_textp && text) {
- xp = &text[mproc->p_textp - atext];
- ap->a_tsiz = xp->x_size;
- ap->a_txtrss = xp->x_rssize;
- ap->a_xccount = xp->x_ccount;
- }
- }
-#undef e
- ap->a_maxrss = mproc->p_maxrss;
- if (lflg) {
- register struct lsav *lp;
-
- sp->s_un.lp = lp = (struct lsav *)
- calloc(1, sizeof (struct lsav));
-#define e(a,b) lp->a = mproc->b
- e(l_ppid, p_ppid); e(l_cpu, p_cpu);
- if (ap->a_stat != SZOMB)
- e(l_wchan, p_wchan);
-#undef e
- lp->l_addr = pcbpf;
- } else if (vflg) {
- register struct vsav *vp;
-
- sp->s_un.vp = vp = (struct vsav *)
- calloc(1, sizeof (struct vsav));
-#define e(a,b) vp->a = mproc->b
- if (ap->a_stat != SZOMB) {
- e(v_swrss, p_swrss);
- vp->v_majflt = u.u_ru.ru_majflt;
- if (mproc->p_textp)
- vp->v_txtswrss = xp->x_swrss;