|
|
1.1 ! root 1: #include <stdio.h> ! 2: #include "ps.h" ! 3: #include <sys/text.h> ! 4: #include <sys/inode.h> ! 5: #include <sys/file.h> ! 6: ! 7: #define Error(msg) return (fprintf(stderr, "%s %s: %s\n", progname, s, msg), \ ! 8: close(fd), -1) ! 9: #define Reject return (close(fd), -1) ! 10: #define Accept return fd ! 11: ! 12: doselect(s, pp, up) ! 13: char *s; register struct proc *pp; register struct user *up; ! 14: { ! 15: char sstr[32], *error, *getuarea(); register Select *sp; ! 16: register fd; ! 17: ! 18: up->u_procp = 0; ! 19: ! 20: if ((fd = open(strcat(strcpy(sstr, "/proc/"), s), 0)) < 0) ! 21: return -1; ! 22: if (!Ioctl(fd, PIOCGETPR, pp)) ! 23: Error("/proc ioctl error"); ! 24: ! 25: if (!Nflag && !tflag && !Fflag) { ! 26: if (!aflag && !rflag && pp->p_uid != myuid && pp->p_pid != mypid) ! 27: Reject; ! 28: if (error = getuarea(fd, pp, up)) ! 29: Error(error); ! 30: if (!aflag && rflag && up->u_uid != myuid && up->u_ruid != myuid) ! 31: Reject; ! 32: if (!xflag && xreject(pp, up)) ! 33: Reject; ! 34: Accept; ! 35: } ! 36: for (sp=selbeg; sp<selend; sp++) { ! 37: if (sp->flag & SELTTY) { ! 38: if (error = getuarea(fd, pp, up)) ! 39: Error(error); ! 40: if (strncmp(sp->id, gettty(up->u_ttydev, up->u_ttyino), 5)) ! 41: continue; ! 42: if (!(sp->flag & SELXFL) && xreject(pp, up)) ! 43: continue; ! 44: Accept; ! 45: } else if (sp->flag & SELFIL) { ! 46: if (error = getuarea(fd, pp, up)) ! 47: Error(error); ! 48: if (fdselect(sp->dev, sp->ino, pp, up)) ! 49: Accept; ! 50: } else if (atoi(sp->id) == pp->p_pid) { ! 51: if (error = getuarea(fd, pp, up)) ! 52: Error(error); ! 53: Accept; ! 54: } ! 55: } ! 56: Reject; ! 57: } ! 58: ! 59: char * ! 60: getuarea(fd, pp, up) ! 61: register struct proc *pp; register struct user *up; ! 62: { ! 63: extern errno; ! 64: if (up->u_procp) ! 65: return 0; ! 66: if (pp->p_flag & SLOAD) { ! 67: register ntry = 4; ! 68: do ! 69: if (Sread(fd, UBASE, up)) ! 70: return 0; ! 71: while (errno == EBUSY && --ntry > 0); ! 72: return "/proc read error"; ! 73: } ! 74: if (Sread(drum, pp->p_swaddr*NBPG, up)) ! 75: return 0; ! 76: return "drum read error"; ! 77: } ! 78: ! 79: xreject(pp, up) ! 80: register struct proc *pp; register struct user *up; ! 81: { ! 82: return (pp->p_stat != SSTOP && ! 83: (strcmp(up->u_comm, "sh") == 0 || ! 84: strcmp(up->u_comm, "csh") == 0 || ! 85: strcmp(up->u_comm, "init") == 0 || ! 86: up->u_comm[0] == 0)); ! 87: } ! 88: ! 89: fdselect(dev, ino, pp, up) ! 90: register struct proc *pp; register struct user *up; ! 91: { ! 92: register k; ! 93: struct text x; struct file f; struct inode i; ! 94: ! 95: if (Kread(pp->p_textp, &x) && Kread(x.x_iptr, &i) && ! 96: dev == i.i_dev && ino == i.i_number) ! 97: return 1; ! 98: if (Kread(up->u_cdir, &i) && dev == i.i_dev && ino == i.i_number) ! 99: return 1; ! 100: if (Kread(up->u_rdir, &i) && dev == i.i_dev && ino == i.i_number) ! 101: return 1; ! 102: ! 103: for (k = 0; k < NOFILE; k++) { ! 104: if (!Kread(up->u_ofile[k], &f) || !Kread(f.f_inode, &i)) ! 105: continue; ! 106: if (dev == i.i_dev && ino == i.i_number) ! 107: return 1; ! 108: } ! 109: return 0; ! 110: }
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.