Annotation of 41BSD/4.0.upgrade/sys/stand/uda.c, revision 1.1

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

unix.superglobalmegacorp.com

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