Annotation of 43BSDReno/sys/vax/sys_machdep.c, revision 1.1.1.1

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

unix.superglobalmegacorp.com

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