Annotation of 43BSDTahoe/sys/tahoevba/drreg.h, revision 1.1

1.1     ! root        1: /*
        !             2:  *     @(#)drreg.h     7.1 (Berkeley) 5/21/88
        !             3:  */
        !             4: 
        !             5: /*
        !             6:     ------------------------------------------
        !             7:     Must include <h/types.h> and <h/buf.h>
        !             8:     ------------------------------------------
        !             9: */
        !            10: 
        !            11: #define        DRINTV  0x9c            /* Has to match with ml/scb.s */
        !            12: #define DRADDMOD 0x01          /* Addr modifier used to access TAHOE memory */
        !            13: #define DR_ZERO 0
        !            14: #define DRPRI  (PZERO+1)
        !            15: 
        !            16: #define DR_TICK 600            /* Default # of clock ticks between call
        !            17:                                   to local timer watchdog routine */
        !            18: #define        DR_TOCK 2               /* default # of calls to local watch dog
        !            19:                                   before an IO or wait is determined to
        !            20:                                   have timeout */
        !            21: 
        !            22: 
        !            23: struct rsdevice {
        !            24:     ushort dr_cstat;           /* Control & status registers */
        !            25:     ushort dr_data;            /* Input/Ouptut data registers */
        !            26:     char dr_addmod;            /* Address modifier for DMA */
        !            27:     char dr_intvect;           /* Interrupt vector */
        !            28:     ushort dr_pulse;           /* Pulse command register */
        !            29:     ushort dr_xx08;            /* Not used */
        !            30:     ushort dr_xx0A;            /* Not used */
        !            31:     ushort dr_xx0C;            /* Not used */
        !            32:     ushort dr_xx0E;            /* Not used */
        !            33:     ushort dr_xx10;            /* Not used */
        !            34:     ushort dr_walo;            /* Low DMA address register --when written-- */
        !            35:     ushort dr_range;           /* DMA range counter */
        !            36:     ushort dr_ralo;            /* Low DMA address register --when read-- */
        !            37:     ushort dr_xx18;            /* Not used */
        !            38:     ushort dr_wahi;            /* High DMA address register --when written-- */
        !            39:     ushort dr_xx1C;            /* Not used */
        !            40:     ushort dr_rahi;            /* High DMA address register --when read-- */
        !            41: };
        !            42: 
        !            43: 
        !            44: struct dr_aux {
        !            45:        struct rsdevice *dr_addr; /* Physical addr of currently active DR11 */
        !            46:        struct buf *dr_actf;    /* Pointers to DR11's active buffers list */
        !            47:        unsigned int dr_flags;  /* State: Hold open, active,... */
        !            48:        ushort dr_cmd;          /* Hold cmd placed here by ioctl
        !            49:                                   for later execution by rsstrategy() */
        !            50:        ushort dr_op;           /* Current operation: DR_READ/DR_WRITE */
        !            51:        long   dr_bycnt;        /* Total byte cnt of current operation */
        !            52:                                /* decremented by completion interrupt */
        !            53:        caddr_t dr_oba;         /* original xfer addr, count */
        !            54:        long   dr_obc;
        !            55:        unsigned long
        !            56:                rtimoticks,     /* No of ticks before timing out on no stall
        !            57:                                   read */
        !            58:                wtimoticks,     /* No of ticks before timing out on no stall
        !            59:                                   write */
        !            60:                currenttimo;    /* the number of current timeout call to
        !            61:                                   omrwtimo() */
        !            62:        ushort dr_istat;        /* Latest interrupt status */
        !            63:        struct buf dr_buf;
        !            64: 
        !            65:        /*ushort dr_time;               /* # of ticks until timeout */
        !            66:        /*ushort dr_tock;               /* # of ticks accumulated */
        !            67:        /*ushort dr_cseq;               /* Current sequence number */
        !            68:        /*ushort dr_lseq;               /* Last sequence number */
        !            69: };
        !            70: 
        !            71: /*     Command used by drioctl() 
        !            72: */
        !            73: struct dr11io {
        !            74:        ushort arg[8];
        !            75: };
        !            76: 
        !            77: #define RSADDR(unit)    ((struct rsdevice *)drinfo[unit]->ui_addr)
        !            78: 
        !            79: /*     Control register bits */
        !            80: #define        RDMA    0x8000          /* reset DMA end-of-range flag */
        !            81: #define        RATN    0x4000          /* reset attention flag */
        !            82: #define RPER   0x2000          /* reset device parity error flag */
        !            83: #define MCLR   0x1000          /* master clear board and INT device */
        !            84: #define CYCL   0x0100          /* forces DMA cycle if DMA enabled */
        !            85: #define IENB   0x0040          /* enables interrupt */
        !            86: #define FCN3   0x0008          /* func. bit 3 to device (FNCT3 H) */
        !            87: #define FCN2   0x0004          /* func. bit 2 to device (FNCT2 H) */
        !            88:                                /* also asserts ACLO FCNT2 H to device */
        !            89: #define FCN1   0x0002          /* func. bit 1 to device (FNCT1 H) */
        !            90: #define GO     0x0001          /* enable DMA and pulse GO to device */
        !            91: 
        !            92: /*     Status register bits */
        !            93: #define        DMAF    0x8000          /* indicates DMA end-of-range */
        !            94: #define        ATTF    0x4000          /* indicates attention false-to-true */
        !            95: #define ATTN   0x2000          /* current state of ATTENTION H input */
        !            96: #define PERR   0x1000          /* Set by external parity error */
        !            97: #define STTA   0x0800          /* STATUS A H input state */
        !            98: #define STTB   0x0400          /* STATUS B H input state */
        !            99: #define STTC   0x0200          /* STATUS C H input state */
        !           100: #define REDY   0x0080          /* board ready for cmd (dma not on) */
        !           101: #define IENF   0x0040          /* Interrupt enabled if on */
        !           102: #define BERR   0x0020          /* Set if bus error during DMA */
        !           103: #define TERR   0x0010          /* Set if bus timeout during DMA */
        !           104: #define FC3S   0x0008          /* State of FCN3 latch */
        !           105: #define FC2S   0x0004          /* State of FCN2 latch */
        !           106: #define FC1S   0x0002          /* State of FCN1 latch */
        !           107: #define DLFG   0x0001          /* 0 -> IKON-10083 *** 1 -> IKON-10077 */
        !           108: 
        !           109: /*     Pulse command register bits */
        !           110: #define SMSK   0x0040          /* pulse interrupt mask on:  Set IENB */
        !           111: #define RMSK   0x0020          /* pulse interrupt mask off: Reset IENB */
        !           112: 
        !           113: 
        !           114: /*     
        !           115:  *     DR11 driver's internal flags -- to be stored in dr_flags 
        !           116: */
        !           117: #define DR_FMSK                0x0000E /* function bits mask */
        !           118: #define        DR_OPEN         0x00001 /* This dr11 has been opened */
        !           119: #define DR_PRES                0x00002 /* This dr11 is present */
        !           120: #define DR_ACTV                0x00004 /* waiting for end-of-range */
        !           121: #define DR_ATWT        0x00008 /* waiting for attention interrupt */
        !           122: #define DR_ATRX        0x00010 /* attn received-resets when read */
        !           123: #define DR_TMDM                0x00020 /* timeout waiting for end-of-range */
        !           124: #define DR_TMAT                0x00040 /* timeout waiting for attention */
        !           125: #define DR_DMAX                0x00080 /* end-of-range interrupt received */
        !           126: #define DR_PCYL                0x00100 /* set cycle with next go */
        !           127: #define DR_DFCN        0x00200 /* donot update function bits until next  go */
        !           128: #define DR_DACL                0x00400 /* defer alco pulse until go */
        !           129: #define DR_LOOPTST     0x02000 /* This dr11 is in loopback test mode */
        !           130: #define DR_LNKMODE     0x04000 /* This dr11 is in link mode */
        !           131: #define        DR_NORSTALL     0x10000 /* Device is set to no stall mode for reads. */
        !           132: #define        DR_NOWSTALL     0x20000 /* Device is set to no stall mode for writes. */
        !           133: #define        DR_TIMEDOUT     0x40000 /* The device timed out on a stall mode R/W */
        !           134: 
        !           135: /*     
        !           136:  *     DR11 driver's internal flags -- to be stored in dr_op 
        !           137: */
        !           138: #define        DR_READ         FCN1
        !           139: #define DR_WRITE       0
        !           140: 
        !           141: /*
        !           142:  *     Ioctl commands
        !           143: */
        !           144: #define DRWAIT         _IOWR('d',1,long)
        !           145: #define        DRPIOW          _IOWR('d',2,long)
        !           146: #define DRPACL         _IOWR('d',3,long)
        !           147: #define DRDACL         _IOWR('d',4,long)
        !           148: #define DRPCYL         _IOWR('d',5,long)
        !           149: #define DRDFCN                 _IOWR('d',6,long)
        !           150: #define DRRPER                 _IOWR('d',7,long)
        !           151: #define DRRATN         _IOWR('d',8,long)
        !           152: #define DRRDMA                 _IOWR('d',9,long)
        !           153: #define DRSFCN                 _IOWR('d',10,long)
        !           154: 
        !           155: #define        DRSETRSTALL     _IOWR('d',13,long)
        !           156: #define        DRSETNORSTALL   _IOWR('d',14,long)
        !           157: #define        DRGETRSTALL     _IOWR('d',15,long)
        !           158: #define        DRSETRTIMEOUT   _IOWR('d',16,long)
        !           159: #define        DRGETRTIMEOUT   _IOWR('d',17,long)
        !           160: #define        DRSETWSTALL     _IOWR('d',18,long)
        !           161: #define        DRSETNOWSTALL   _IOWR('d',19,long)
        !           162: #define        DRGETWSTALL     _IOWR('d',20,long)
        !           163: #define        DRSETWTIMEOUT   _IOWR('d',21,long)
        !           164: #define        DRGETWTIMEOUT   _IOWR('d',22,long)
        !           165: #define        DRWRITEREADY    _IOWR('d',23,long)
        !           166: #define        DRREADREADY     _IOWR('d',24,long)
        !           167: #define        DRBUSY          _IOWR('d',25,long)
        !           168: #define        DRRESET         _IOWR('d',26,long)
        !           169: 
        !           170: /* The block size for buffering and DMA transfers. */
        !           171: /* OM_BLOCKSIZE must be even and <= 32768. Multiples of 512 are prefered. */
        !           172: #define        OM_BLOCKSIZE    32768
        !           173: 
        !           174: 
        !           175: /* --- Define ioctl call used by dr11 utility device --  */
        !           176: 
        !           177: #define DR11STAT       _IOWR('d',30,struct dr11io)   /* Get status dr11, unit 
        !           178:                                                   number is dr11io.arg[0] */
        !           179: #define DR11LOOP       _IOR('d',31,struct dr11io)   /* Perform loopback test */
        !           180: 
        !           181: /* ---------------------------------------------------- */
        !           182: 

unix.superglobalmegacorp.com

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