Annotation of researchv10no/cmd/ops/doselect.c, revision 1.1.1.1

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: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.