Annotation of researchv10no/cmd/ps/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:                                -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 *error; register Select *sp;
                     16:        register int fd;
                     17: 
                     18:        up->u_procp = 0;
                     19: 
                     20:        if ((fd = getproc(s, pp)) == -1)
                     21:                return -1;
                     22: 
                     23:        if (!Nflag && !tflag && !Fflag) {
                     24:                if (!aflag && !rflag && pp->p_uid != myuid && pp->p_pid != mypid)
                     25:                        Reject;
                     26:                if (error = getuarea(fd, pp, up))
                     27:                        Error(error);
                     28:                if (!aflag && rflag && up->u_uid != myuid && up->u_ruid != myuid)
                     29:                        Reject;
                     30:                if (!xflag && xreject(pp, up))
                     31:                        Reject;
                     32:                Accept;
                     33:        }
                     34:        for (sp=selbeg; sp<selend; sp++) {
                     35:                if (sp->flag & SELTTY) {
                     36:                        if (error = getuarea(fd, pp, up))
                     37:                                Error(error);
                     38:                        if (strncmp(sp->id, gettty(up->u_ttydev, up->u_ttyino), 5))
                     39:                                continue;
                     40:                        if (!(sp->flag & SELXFL) && xreject(pp, up))
                     41:                                continue;
                     42:                        Accept;
                     43:                } else if (sp->flag & SELFIL) {
                     44:                        if (error = getuarea(fd, pp, up))
                     45:                                Error(error);
                     46:                        if (fdselect(sp->dev, sp->ino, pp, up))
                     47:                                Accept;
                     48:                } else if (atoi(sp->id) == pp->p_pid) {
                     49:                        if (error = getuarea(fd, pp, up))
                     50:                                Error(error);
                     51:                        Accept;
                     52:                }
                     53:        }
                     54:        Reject;
                     55: }
                     56: 
                     57: xreject(pp, up)
                     58: register struct proc *pp; register struct user *up;
                     59: {
                     60:        return (pp->p_stat != SSTOP &&
                     61:                (strcmp(up->u_comm, "sh") == 0 ||
                     62:                 strcmp(up->u_comm, "csh") == 0 ||
                     63:                 strcmp(up->u_comm, "init") == 0 ||
                     64:                 up->u_comm[0] == 0));
                     65: }
                     66: 
                     67: fdselect(dev, ino, pp, up)
                     68: register struct proc *pp; register struct user *up;
                     69: {
                     70:        register k;
                     71:        struct text x; struct file f; struct inode i;
                     72: 
                     73:        if (Kread(pp->p_textp, &x) && Kread(x.x_iptr, &i) &&
                     74:            dev == i.i_dev && ino == i.i_number)
                     75:                return 1;
                     76:        if (Kread(up->u_cdir, &i) && dev == i.i_dev && ino == i.i_number)
                     77:                return 1;
                     78:        if (Kread(up->u_rdir, &i) && dev == i.i_dev && ino == i.i_number)
                     79:                return 1;
                     80: 
                     81:        for (k = 0; k < NOFILE; k++) {
                     82:                if (!Kread(up->u_ofile[k], &f) || !Kread(f.f_inode, &i))
                     83:                        continue;
                     84:                if (dev == i.i_dev && ino == i.i_number)
                     85:                        return 1;
                     86:        }
                     87:        return 0;
                     88: }

unix.superglobalmegacorp.com

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