Annotation of 42BSD/sys/vax/sys_machdep.c, revision 1.1.1.1

1.1       root        1: /*     sys_machdep.c   6.1     83/07/29        */
                      2: 
                      3: #include "../h/param.h"
                      4: #include "../h/systm.h"
                      5: #include "../h/dir.h"
                      6: #include "../h/user.h"
                      7: #include "../h/ioctl.h"
                      8: #include "../h/file.h"
                      9: #include "../h/proc.h"
                     10: #include "../h/uio.h"
                     11: #include "../h/kernel.h"
                     12: #include "../h/mtio.h"
                     13: #include "../h/buf.h"
                     14: 
                     15: #include "../vax/dkio.h"
                     16: #include "../vax/pte.h"
                     17: #include "../vaxuba/ubareg.h"
                     18: #include "../vaxuba/ubavar.h"
                     19: 
                     20: resuba()
                     21: {
                     22: 
                     23:        if (suser())
                     24:        if (u.u_arg[0] < numuba)
                     25:                ubareset(u.u_arg[0]);
                     26: }
                     27: 
                     28: #ifdef TRACE
                     29: int    nvualarm;
                     30: 
                     31: vtrace()
                     32: {
                     33:        register struct a {
                     34:                int     request;
                     35:                int     value;
                     36:        } *uap;
                     37:        int vdoualarm();
                     38: 
                     39:        uap = (struct a *)u.u_ap;
                     40:        switch (uap->request) {
                     41: 
                     42:        case VTR_DISABLE:               /* disable a trace point */
                     43:        case VTR_ENABLE:                /* enable a trace point */
                     44:                if (uap->value < 0 || uap->value >= TR_NFLAGS)
                     45:                        u.u_error = EINVAL;
                     46:                else {
                     47:                        u.u_r.r_val1 = traceflags[uap->value];
                     48:                        traceflags[uap->value] = uap->request;
                     49:                }
                     50:                break;
                     51: 
                     52:        case VTR_VALUE:         /* return a trace point setting */
                     53:                if (uap->value < 0 || uap->value >= TR_NFLAGS)
                     54:                        u.u_error = EINVAL;
                     55:                else
                     56:                        u.u_r.r_val1 = traceflags[uap->value];
                     57:                break;
                     58: 
                     59:        case VTR_UALARM:        /* set a real-time ualarm, less than 1 min */
                     60:                if (uap->value <= 0 || uap->value > 60 * hz ||
                     61:                    nvualarm > 5)
                     62:                        u.u_error = EINVAL;
                     63:                else {
                     64:                        nvualarm++;
                     65:                        timeout(vdoualarm, (caddr_t)u.u_procp->p_pid,
                     66:                            uap->value);
                     67:                }
                     68:                break;
                     69: 
                     70:        case VTR_STAMP:
                     71:                trace(TR_STAMP, uap->value, u.u_procp->p_pid);
                     72:                break;
                     73:        }
                     74: }
                     75: 
                     76: vdoualarm(arg)
                     77:        int arg;
                     78: {
                     79:        register struct proc *p;
                     80: 
                     81:        p = pfind(arg);
                     82:        if (p)
                     83:                psignal(p, 16);
                     84:        nvualarm--;
                     85: }
                     86: #endif
                     87: 
                     88: #ifdef COMPAT
                     89: /*
                     90:  * Note: these tables are sorted by
                     91:  * ioctl "code" (in ascending order).
                     92:  */
                     93: int dctls[] = { DKIOCHDR, 0 };
                     94: int fctls[] = { FIOCLEX, FIONCLEX, FIOASYNC, FIONBIO, FIONREAD, 0 };
                     95: int mctls[] = { MTIOCTOP, MTIOCGET, 0 };
                     96: int tctls[] = {
                     97:        TIOCGETD, TIOCSETD, TIOCHPCL, TIOCMODG, TIOCMODS,
                     98:        TIOCGETP, TIOCSETP, TIOCSETN, TIOCEXCL, TIOCNXCL,
                     99:        TIOCFLUSH,TIOCSETC, TIOCGETC, TIOCREMOTE,TIOCMGET,
                    100:        TIOCMBIC, TIOCMBIS, TIOCMSET, TIOCSTART,TIOCSTOP,
                    101:        TIOCPKT,  TIOCNOTTY,TIOCSTI,  TIOCOUTQ, TIOCGLTC,
                    102:        TIOCSLTC, TIOCSPGRP,TIOCGPGRP,TIOCCDTR, TIOCSDTR,
                    103:        TIOCCBRK, TIOCSBRK, TIOCLGET, TIOCLSET, TIOCLBIC,
                    104:        TIOCLBIS, 0
                    105: };
                    106: 
                    107: /*
                    108:  * Map an old style ioctl command to new.
                    109:  */
                    110: mapioctl(cmd)
                    111:        int cmd;
                    112: {
                    113:        register int *map, c;
                    114: 
                    115:        switch ((cmd >> 8) & 0xff) {
                    116: 
                    117:        case 'd':
                    118:                map = dctls;
                    119:                break;
                    120: 
                    121:        case 'f':
                    122:                map = fctls;
                    123:                break;
                    124: 
                    125:        case 'm':
                    126:                map = mctls;
                    127:                break;
                    128: 
                    129:        case 't':
                    130:                map = tctls;
                    131:                break;
                    132: 
                    133:        default:
                    134:                return (0);
                    135:        }
                    136:        while ((c = *map) && (c&0xff) < (cmd&0xff))
                    137:                map++;
                    138:        if (c && (c&0xff) == (cmd&0xff))
                    139:                return (c);
                    140:        return (0);
                    141: }
                    142: #endif

unix.superglobalmegacorp.com

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