Annotation of 43BSDTahoe/sys/tahoevba/cyreg.h, revision 1.1.1.1

1.1       root        1: /*     %M%     %I%     %E%     */
                      2: 
                      3: /*
                      4:  * Tapemaster controller definitions.
                      5:  */
                      6: 
                      7: /*
                      8:  * With 20-bit addressing, the intermediate buffer
                      9:  * must be allocated early in startup().
                     10:  */
                     11: #define        CYMAXIO (64*1024)               /* max i/o size + 1 */
                     12: char   *cybuf;
                     13: 
                     14: /* for byte swapping Multibus values */
                     15: #define        htoms(x) (u_short)((((x)>>8)&0xff) | (((x)<<8)&0xff00))
                     16: 
                     17: #define        b_repcnt  b_bcount
                     18: #define        b_command b_resid
                     19: 
                     20: /*
                     21:  * System configuration pointer.
                     22:  * Memory address is jumpered on controller.
                     23:  */
                     24: struct cyscp {
                     25:        char    csp_buswidth;   /* system bus width */
                     26: #define        CSP_16BITS      1       /* 16-bit system bus */
                     27: #define        CSP_8BITS       0       /* 8-bit system bus */
                     28:        char    csp_unused;
                     29:        u_char  csp_scb[4];     /* point to system config block */
                     30: };
                     31: 
                     32: /*
                     33:  * System configuration block
                     34:  */
                     35: struct cyscb {
                     36:        char    csb_fixed;      /* fixed value code (must be 3) */
                     37:        char    csb_unused;     /* unused */
                     38:        u_char  csb_ccb[4];     /* pointer to channel control block */
                     39: };
                     40: 
                     41: #define        CSB_FIXED       0x3
                     42: 
                     43: /*
                     44:  * Channel control block definitions
                     45:  */
                     46: struct cyccb {
                     47:        char    cbcw;           /* channel control word */
                     48:        char    cbgate;         /* tpb access gate */
                     49:        u_char  cbtpb[4];       /* first tape parameter block */
                     50: };
                     51: 
                     52: #define        GATE_OPEN       (char)(0x00)
                     53: #define        GATE_CLOSED     (char)(0xff)
                     54: 
                     55: #define        CY_GO(addr)     movob((addr), 0xff)     /* channel attention */
                     56: #define        CY_RESET(addr)  movob((addr)+1, 0xff)   /* software controller reset */
                     57: 
                     58: #define        CBCW_IE         0x11            /* interrupt on cmd completion */
                     59: #define        CBCW_CLRINT     0x09            /* clear active interrupt */
                     60: 
                     61: /*
                     62:  * Tape parameter block definitions
                     63:  */
                     64: struct cytpb {
                     65:        u_long  tpcmd;          /* command, see below */
                     66:        u_short tpcontrol;      /* control word */
                     67:        u_short tpcount;        /* return count */
                     68:        u_short tpsize;         /* buffer size */
                     69:        u_short tprec;          /* records/overrun */
                     70:        u_char  tpdata[4];      /* pointer to source/dest */
                     71:        u_short tpstatus;       /* status */
                     72:        u_char  tplink[4];      /* pointer to next parameter block */
                     73: };
                     74: 
                     75: /* control field bit definitions */
                     76: #define        CYCW_UNIT       (0x000c<<8)     /* unit select mask, 2 bit field */
                     77: #define        CYCW_IE         (0x0020<<8)     /* interrupt enable */
                     78: #define        CYCW_LOCK       (0x0080<<8)     /* bus lock flag */
                     79: #define        CYCW_REV        (0x0400>>8)     /* reverse flag */
                     80: #define        CYCW_SPEED      (0x0800>>8)     /* speed/density */
                     81: #define            CYCW_25IPS  0
                     82: #define            CYCW_100IPS (0x0800>>8)
                     83: #define        CYCW_WIDTH      (0x8000>>8)     /* width */
                     84: #define            CYCW_8BITS  0
                     85: #define            CYCW_16BITS (0x8000>>8)
                     86: 
                     87: #define        CYCW_BITS       "\20\3REV\005100IPS\00716BITS\16IE\20LOCK"
                     88: 
                     89: /*
                     90:  * Controller commands
                     91:  */
                     92: 
                     93: /* control status/commands */
                     94: #define        CY_CONFIG       (0x00<<24)      /* configure */
                     95: #define        CY_NOP          (0x20<<24)      /* no operation */
                     96: #define        CY_SETPAGE      (0x08<<24)      /* set page (addr bits 20-23) */
                     97: #define        CY_SENSE        (0x28<<24)      /* drive status */
                     98: #define        CY_CLRINT       (0x9c<<24)      /* clear Multibus interrupt */
                     99: 
                    100: /* tape position commands */
                    101: #define        CY_REW          (0x34<<24)      /* rewind tape */
                    102: #define        CY_OFFL         (0x38<<24)      /* off_line and unload */
                    103: #define        CY_WEOF         (0x40<<24)      /* write end-of-file mark */
                    104: #define        CY_SFORW        (0x70<<24)      /* space record forward */
                    105: #define        CY_SREV         (CY_SFORW|CYCW_REV) /* space record backwards */
                    106: #define        CY_FSF          (0x44<<24)      /* space file forward */
                    107: #define        CY_BSF          (CY_FSF|CYCW_REV) /* space file backwards */
                    108: #define        CY_ERASE        (0x4c<<24)      /* erase record */
                    109: 
                    110: /* data transfer commands */
                    111: #define        CY_BRCOM        (0x10<<24)      /* read buffered */
                    112: #define        CY_BWCOM        (0x14<<24)      /* write buffered */
                    113: #define        CY_RCOM         (0x2c<<24)      /* read tape unbuffered */
                    114: #define        CY_WCOM         (0x30<<24)      /* write tape unbuffered */
                    115: 
                    116: /* status field bit definitions */
                    117: #define        CYS_WP          (0x0002<<8)     /* write protected, no write ring */
                    118: #define        CYS_BSY         (0x0004<<8)     /* formatter busy */
                    119: #define        CYS_RDY         (0x0008<<8)     /* drive ready */
                    120: #define        CYS_EOT         (0x0010<<8)     /* end of tape detected */
                    121: #define        CYS_BOT         (0x0020<<8)     /* tape is at load point */
                    122: #define        CYS_OL          (0x0040<<8)     /* drive on_line */
                    123: #define        CYS_FM          (0x0080<<8)     /* filemark detected */
                    124: #define        CYS_ERR         (0x1f00>>8)     /* error value mask */
                    125: #define        CYS_CR          (0x2000>>8)     /* controller executed retries */
                    126: #define        CYS_CC          (0x4000>>8)     /* command completed successfully */
                    127: #define        CYS_CE          (0x8000>>8)     /* command execution has begun */
                    128: 
                    129: #define        CYS_BITS "\20\6CR\7CC\10CE\12WP\13BSY\14RDY\15EOT/BOT\16BOT\17OL\20FM"
                    130: 
                    131: /* error codes for CYS_ERR */
                    132: #define        CYER_TIMOUT     0x01    /* timed out data busy false */
                    133: #define        CYER_TIMOUT1    0x02    /* data busy false,formatter,ready */
                    134: #define        CYER_TIMOUT2    0x03    /* time out ready busy false */
                    135: #define        CYER_TIMOUT3    0x04    /* time out ready busy true */
                    136: #define        CYER_TIMOUT4    0x05    /* time out data busy true */
                    137: #define        CYER_NXM        0x06    /* time out memory */
                    138: #define        CYER_BLANK      0x07    /* blank tape */
                    139: #define        CYER_DIAG       0x08    /* micro-diagnostic */
                    140: #define        CYER_EOT        0x09    /* EOT forward, BOT rev. */
                    141: #define        CYER_BOT        0x09    /* EOT forward, BOT rev. */
                    142: #define        CYER_HERR       0x0a    /* retry unsuccessful */
                    143: #define        CYER_FIFO       0x0b    /* FIFO over/under flow */
                    144: #define        CYER_PARITY     0x0d    /* drive to tapemaster parity error */
                    145: #define        CYER_CKSUM      0x0e    /* prom checksum */
                    146: #define        CYER_STROBE     0x0f    /* time out tape strobe */
                    147: #define        CYER_NOTRDY     0x10    /* tape not ready */
                    148: #define        CYER_PROT       0x11    /* write, no enable ring */
                    149: #define        CYER_JUMPER     0x13    /* missing diagnostic jumper */
                    150: #define        CYER_LINK       0x14    /* bad link, link inappropriate */
                    151: #define        CYER_FM         0x15    /* unexpected filemark */
                    152: #define        CYER_PARAM      0x16    /* bad parameter, byte count ? */
                    153: #define        CYER_HDWERR     0x18    /* unidentified hardware error */
                    154: #define        CYER_NOSTRM     0x19    /* streaming terminated */
                    155: 
                    156: #ifdef CYERROR
                    157: char   *cyerror[] = {
                    158:        "no error",
                    159:        "timeout",
                    160:        "timeout1",
                    161:        "timeout2",
                    162:        "timeout3",
                    163:        "timeout4", 
                    164:        "non-existent memory",
                    165:        "blank tape",
                    166:        "micro-diagnostic",
                    167:        "eot/bot detected",
                    168:        "retry unsuccessful",
                    169:        "fifo over/under-flow",
                    170:        "#0xc",
                    171:        "drive to controller parity error",
                    172:        "prom checksum",
                    173:        "time out tape strobe (record length error)",
                    174:        "tape not ready",
                    175:        "write protected",
                    176:        "#0x12",
                    177:        "missing diagnostic jumper",
                    178:        "invalid link pointer",
                    179:        "unexpected file mark",
                    180:        "invalid byte count/parameter",
                    181:        "#0x17",
                    182:        "unidentified hardware error",
                    183:        "streaming terminated"
                    184: };
                    185: #define        NCYERROR        (sizeof (cyerror) / sizeof (cyerror[0]))
                    186: #endif
                    187: 
                    188: /*
                    189:  * Masks defining hard and soft errors (must check against 1<<CYER_code).
                    190:  */
                    191: #define        CYMASK(e)       (1 << (e))
                    192: #define        CYBIT(e)        (1<<(CYER_/**/e))
                    193: #define        CYER_HARD       (CYBIT(TIMOUT)|CYBIT(TIMOUT1)|CYBIT(TIMOUT2)|\
                    194:     CYBIT(TIMOUT3)|CYBIT(TIMOUT4)|CYBIT(NXM)|CYBIT(DIAG)|CYBIT(JUMPER)|\
                    195:     CYBIT(STROBE)|CYBIT(PROT)|CYBIT(CKSUM)|CYBIT(HERR)|CYBIT(BLANK))
                    196: #define        CYER_RSOFT      (CYBIT(FIFO)|CYBIT(NOTRDY)|CYBIT(PARITY))
                    197: #define        CYER_WSOFT      (CYBIT(HERR)|CYBIT(FIFO)|CYBIT(NOTRDY)|CYBIT(PARITY))

unix.superglobalmegacorp.com

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