Annotation of 42BSD/sys/stand/uda.c, revision 1.1.1.1

1.1       root        1: /*     uda.c   6.1     83/07/29        */
                      2: 
                      3: /*
                      4:  * UDA50/RAxx disk device driver
                      5:  */
                      6: #include "../machine/pte.h"
                      7: 
                      8: #include "../h/param.h"
                      9: #include "../h/inode.h"
                     10: #include "../h/fs.h"
                     11: 
                     12: #include "saio.h"
                     13: #include "savax.h"
                     14: 
                     15: /*
                     16:  * Parameters for the communications area
                     17:  */
                     18: #define        NRSPL2  0
                     19: #define        NCMDL2  0
                     20: #define        NRSP    (1<<NRSPL2)
                     21: #define        NCMD    (1<<NCMDL2)
                     22: 
                     23: #include "../vaxuba/udareg.h"
                     24: #include "../vaxuba/ubareg.h"
                     25: #include "../vax/mscp.h"
                     26: 
                     27: u_short udastd[] = { 0772150 };
                     28: 
                     29: struct iob     cudbuf;
                     30: 
                     31: struct udadevice *udaddr = 0;
                     32: 
                     33: struct uda {
                     34:        struct udaca    uda_ca;
                     35:        struct mscp     uda_rsp;
                     36:        struct mscp     uda_cmd;
                     37: } uda;
                     38: 
                     39: struct uda *ud_ubaddr;                 /* Unibus address of uda structure */
                     40: 
                     41: int uda_off[] = { 0, 15884, 0, -1, -1, -1, 49324, 131404 };
                     42: 
                     43: struct mscp *udcmd();
                     44: 
                     45: raopen(io)
                     46:        register struct iob *io;
                     47: {
                     48:        register struct mscp *mp;
                     49:        int i;
                     50: 
                     51:        if (udaddr == 0)
                     52:                udaddr = (struct udadevice *)ubamem(io->i_unit, udastd[0]);
                     53:        if (ud_ubaddr == 0) {
                     54:                cudbuf.i_ma = (caddr_t)&uda;
                     55:                cudbuf.i_cc = sizeof(uda);
                     56:                ud_ubaddr = (struct uda *)ubasetup(&cudbuf, 2);
                     57:        }
                     58:        udaddr->udaip = 0;
                     59:        while ((udaddr->udasa & UDA_STEP1) == 0)
                     60:                ;
                     61:        udaddr->udasa = UDA_ERR;
                     62:        while ((udaddr->udasa & UDA_STEP2) == 0)
                     63:                ;
                     64:        udaddr->udasa = (short)&ud_ubaddr->uda_ca.ca_ringbase;
                     65:        while ((udaddr->udasa & UDA_STEP3) == 0)
                     66:                ;
                     67:        udaddr->udasa = (short)(((int)&ud_ubaddr->uda_ca.ca_ringbase) >> 16);
                     68:        while ((udaddr->udasa & UDA_STEP4) == 0)
                     69:                ;
                     70:        udaddr->udasa = UDA_GO;
                     71:        uda.uda_ca.ca_rspdsc[0] = (long)&ud_ubaddr->uda_rsp.mscp_cmdref;
                     72:        uda.uda_ca.ca_cmddsc[0] = (long)&ud_ubaddr->uda_cmd.mscp_cmdref;
                     73:        uda.uda_cmd.mscp_cntflgs = 0;
                     74:        if (udcmd(M_OP_STCON) == 0) {
                     75:                _stop("ra: open error, STCON");
                     76:                return;
                     77:        }
                     78:        uda.uda_cmd.mscp_unit = io->i_unit&7;
                     79:        if (udcmd(M_OP_ONLIN) == 0) {
                     80:                _stop("ra: open error, ONLIN");
                     81:                return;
                     82:        }
                     83:        if (io->i_boff < 0 || io->i_boff > 7 || uda_off[io->i_boff] == -1)
                     84:                _stop("ra: bad unit");
                     85:        io->i_boff = uda_off[io->i_boff];
                     86: }
                     87: 
                     88: struct mscp *
                     89: udcmd(op)
                     90:        int op;
                     91: {
                     92:        struct mscp *mp;
                     93:        int i;
                     94: 
                     95:        uda.uda_cmd.mscp_opcode = op;
                     96:        uda.uda_rsp.mscp_header.uda_msglen = sizeof (struct mscp);
                     97:        uda.uda_cmd.mscp_header.uda_msglen = sizeof (struct mscp);
                     98:        uda.uda_ca.ca_rspdsc[0] |= UDA_OWN|UDA_INT;
                     99:        uda.uda_ca.ca_cmddsc[0] |= UDA_OWN|UDA_INT;
                    100:        i = udaddr->udaip;
                    101:        for (;;) {
                    102:                if (uda.uda_ca.ca_cmdint)
                    103:                        uda.uda_ca.ca_cmdint = 0;
                    104:                if (uda.uda_ca.ca_rspint)
                    105:                        break;
                    106:        }
                    107:        uda.uda_ca.ca_rspint = 0;
                    108:        mp = &uda.uda_rsp;
                    109:        if (mp->mscp_opcode != (op|M_OP_END) ||
                    110:            (mp->mscp_status&M_ST_MASK) != M_ST_SUCC)
                    111:                return(0);
                    112:        return(mp);
                    113: }
                    114: 
                    115: rastrategy(io, func)
                    116:        register struct iob *io;
                    117: {
                    118:        register struct mscp *mp;
                    119:        int ubinfo;
                    120: 
                    121:        ubinfo = ubasetup(io, 1);
                    122:        mp = &uda.uda_cmd;
                    123:        mp->mscp_lbn = io->i_bn;
                    124:        mp->mscp_unit = io->i_unit&7;
                    125:        mp->mscp_bytecnt = io->i_cc;
                    126:        mp->mscp_buffer = (ubinfo & 0x3ffff) | (((ubinfo>>28)&0xf)<<24);
                    127:        if ((mp = udcmd(func == READ ? M_OP_READ : M_OP_WRITE)) == 0) {
                    128:                printf("ra: I/O error\n");
                    129:                ubafree(io, ubinfo);
                    130:                return(-1);
                    131:        }
                    132:        ubafree(io, ubinfo);
                    133:        return(io->i_cc);
                    134: }
                    135: 
                    136: /*ARGSUSED*/
                    137: raioctl(io, cmd, arg)
                    138:        struct iob *io;
                    139:        int cmd;
                    140:        caddr_t arg;
                    141: {
                    142: 
                    143:        return (ECMD);
                    144: }

unix.superglobalmegacorp.com

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