Annotation of 43BSDReno/sys/tahoevba/cyreg.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1988 The Regents of the University of California.
        !             3:  * All rights reserved.
        !             4:  *
        !             5:  * This code is derived from software contributed to Berkeley by
        !             6:  * Computer Consoles Inc.
        !             7:  *
        !             8:  * Redistribution is only permitted until one year after the first shipment
        !             9:  * of 4.4BSD by the Regents.  Otherwise, redistribution and use in source and
        !            10:  * binary forms are permitted provided that: (1) source distributions retain
        !            11:  * this entire copyright notice and comment, and (2) distributions including
        !            12:  * binaries display the following acknowledgement:  This product includes
        !            13:  * software developed by the University of California, Berkeley and its
        !            14:  * contributors'' in the documentation or other materials provided with the
        !            15:  * distribution and in all advertising materials mentioning features or use
        !            16:  * of this software.  Neither the name of the University nor the names of
        !            17:  * its contributors may be used to endorse or promote products derived from
        !            18:  * this software without specific prior written permission.
        !            19:  * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
        !            20:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
        !            21:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
        !            22:  *
        !            23:  *     @(#)cyreg.h     7.8 (Berkeley) 6/28/90
        !            24:  */
        !            25: 
        !            26: /*
        !            27:  * Tapemaster controller definitions.
        !            28:  */
        !            29: 
        !            30: /*
        !            31:  * With 20-bit addressing, the intermediate buffer
        !            32:  * must be allocated early in startup().
        !            33:  */
        !            34: #define        CYMAXIO (64*1024)               /* max i/o size + 1 */
        !            35: char   *cybuf;
        !            36: 
        !            37: /* for byte swapping Multibus values */
        !            38: #define        htoms(x) (u_short)((((x)>>8)&0xff) | (((x)<<8)&0xff00))
        !            39: 
        !            40: #define        b_repcnt  b_bcount
        !            41: #define        b_command b_resid
        !            42: 
        !            43: /*
        !            44:  * System configuration pointer.
        !            45:  * Memory address is jumpered on controller.
        !            46:  */
        !            47: struct cyscp {
        !            48:        char    csp_buswidth;   /* system bus width */
        !            49: #define        CSP_16BITS      1       /* 16-bit system bus */
        !            50: #define        CSP_8BITS       0       /* 8-bit system bus */
        !            51:        char    csp_unused;
        !            52:        u_char  csp_scb[4];     /* point to system config block */
        !            53: };
        !            54: 
        !            55: /*
        !            56:  * System configuration block
        !            57:  */
        !            58: struct cyscb {
        !            59:        char    csb_fixed;      /* fixed value code (must be 3) */
        !            60:        char    csb_unused;     /* unused */
        !            61:        u_char  csb_ccb[4];     /* pointer to channel control block */
        !            62: };
        !            63: 
        !            64: #define        CSB_FIXED       0x3
        !            65: 
        !            66: /*
        !            67:  * Channel control block definitions
        !            68:  */
        !            69: struct cyccb {
        !            70:        char    cbcw;           /* channel control word */
        !            71:        char    cbgate;         /* tpb access gate */
        !            72:        u_char  cbtpb[4];       /* first tape parameter block */
        !            73: };
        !            74: 
        !            75: #define        GATE_OPEN       (char)(0x00)
        !            76: #define        GATE_CLOSED     (char)(0xff)
        !            77: 
        !            78: #define        CY_GO(addr)     movob((addr), 0xff)     /* channel attention */
        !            79: #define        CY_RESET(addr)  movob((addr)+1, 0xff)   /* software controller reset */
        !            80: 
        !            81: #define        CBCW_IE         0x11            /* interrupt on cmd completion */
        !            82: #define        CBCW_CLRINT     0x09            /* clear active interrupt */
        !            83: 
        !            84: /*
        !            85:  * Tape parameter block definitions
        !            86:  */
        !            87: struct cytpb {
        !            88:        u_long  tpcmd;          /* command, see below */
        !            89:        u_short tpcontrol;      /* control word */
        !            90:        u_short tpcount;        /* return count */
        !            91:        u_short tpsize;         /* buffer size */
        !            92:        u_short tprec;          /* records/overrun */
        !            93:        u_char  tpdata[4];      /* pointer to source/dest */
        !            94:        u_short tpstatus;       /* status */
        !            95:        u_char  tplink[4];      /* pointer to next parameter block */
        !            96: };
        !            97: 
        !            98: /* control field bit definitions */
        !            99: #define        CYCW_UNIT       (0x000c<<8)     /* unit select mask, 2 bit field */
        !           100: #define        CYCW_IE         (0x0020<<8)     /* interrupt enable */
        !           101: #define        CYCW_LOCK       (0x0080<<8)     /* bus lock flag */
        !           102: #define        CYCW_REV        (0x0400>>8)     /* reverse flag */
        !           103: #define        CYCW_SPEED      (0x0800>>8)     /* speed/density */
        !           104: #define            CYCW_25IPS  0
        !           105: #define            CYCW_100IPS (0x0800>>8)
        !           106: #define        CYCW_WIDTH      (0x8000>>8)     /* width */
        !           107: #define            CYCW_8BITS  0
        !           108: #define            CYCW_16BITS (0x8000>>8)
        !           109: 
        !           110: #define        CYCW_BITS       "\20\3REV\005100IPS\00716BITS\16IE\20LOCK"
        !           111: 
        !           112: /*
        !           113:  * Controller commands
        !           114:  */
        !           115: 
        !           116: /* control status/commands */
        !           117: #define        CY_CONFIG       (0x00<<24)      /* configure */
        !           118: #define        CY_NOP          (0x20<<24)      /* no operation */
        !           119: #define        CY_SETPAGE      (0x08<<24)      /* set page (addr bits 20-23) */
        !           120: #define        CY_SENSE        (0x28<<24)      /* drive status */
        !           121: #define        CY_CLRINT       (0x9c<<24)      /* clear Multibus interrupt */
        !           122: 
        !           123: /* tape position commands */
        !           124: #define        CY_REW          (0x34<<24)      /* rewind tape */
        !           125: #define        CY_OFFL         (0x38<<24)      /* off_line and unload */
        !           126: #define        CY_WEOF         (0x40<<24)      /* write end-of-file mark */
        !           127: #define        CY_SFORW        (0x70<<24)      /* space record forward */
        !           128: #define        CY_SREV         (CY_SFORW|CYCW_REV) /* space record backwards */
        !           129: #define        CY_FSF          (0x44<<24)      /* space file forward */
        !           130: #define        CY_BSF          (CY_FSF|CYCW_REV) /* space file backwards */
        !           131: #define        CY_ERASE        (0x4c<<24)      /* erase record */
        !           132: 
        !           133: /* data transfer commands */
        !           134: #define        CY_BRCOM        (0x10<<24)      /* read buffered */
        !           135: #define        CY_BWCOM        (0x14<<24)      /* write buffered */
        !           136: #define        CY_RCOM         (0x2c<<24)      /* read tape unbuffered */
        !           137: #define        CY_WCOM         (0x30<<24)      /* write tape unbuffered */
        !           138: 
        !           139: /* status field bit definitions */
        !           140: #define        CYS_WP          (0x0002<<8)     /* write protected, no write ring */
        !           141: #define        CYS_BSY         (0x0004<<8)     /* formatter busy */
        !           142: #define        CYS_RDY         (0x0008<<8)     /* drive ready */
        !           143: #define        CYS_EOT         (0x0010<<8)     /* end of tape detected */
        !           144: #define        CYS_BOT         (0x0020<<8)     /* tape is at load point */
        !           145: #define        CYS_OL          (0x0040<<8)     /* drive on_line */
        !           146: #define        CYS_FM          (0x0080<<8)     /* filemark detected */
        !           147: #define        CYS_ERR         (0x1f00>>8)     /* error value mask */
        !           148: #define        CYS_CR          (0x2000>>8)     /* controller executed retries */
        !           149: #define        CYS_CC          (0x4000>>8)     /* command completed successfully */
        !           150: #define        CYS_CE          (0x8000>>8)     /* command execution has begun */
        !           151: 
        !           152: #define        CYS_BITS "\20\6CR\7CC\10CE\12WP\13BSY\14RDY\15EOT/BOT\16BOT\17OL\20FM"
        !           153: 
        !           154: /* error codes for CYS_ERR */
        !           155: #define        CYER_TIMOUT     0x01    /* timed out data busy false */
        !           156: #define        CYER_TIMOUT1    0x02    /* data busy false,formatter,ready */
        !           157: #define        CYER_TIMOUT2    0x03    /* time out ready busy false */
        !           158: #define        CYER_TIMOUT3    0x04    /* time out ready busy true */
        !           159: #define        CYER_TIMOUT4    0x05    /* time out data busy true */
        !           160: #define        CYER_NXM        0x06    /* time out memory */
        !           161: #define        CYER_BLANK      0x07    /* blank tape */
        !           162: #define        CYER_DIAG       0x08    /* micro-diagnostic */
        !           163: #define        CYER_EOT        0x09    /* EOT forward, BOT rev. */
        !           164: #define        CYER_BOT        0x09    /* EOT forward, BOT rev. */
        !           165: #define        CYER_HERR       0x0a    /* retry unsuccessful */
        !           166: #define        CYER_FIFO       0x0b    /* FIFO over/under flow */
        !           167: #define        CYER_PARITY     0x0d    /* drive to tapemaster parity error */
        !           168: #define        CYER_CKSUM      0x0e    /* prom checksum */
        !           169: #define        CYER_STROBE     0x0f    /* time out tape strobe */
        !           170: #define        CYER_NOTRDY     0x10    /* tape not ready */
        !           171: #define        CYER_PROT       0x11    /* write, no enable ring */
        !           172: #define        CYER_JUMPER     0x13    /* missing diagnostic jumper */
        !           173: #define        CYER_LINK       0x14    /* bad link, link inappropriate */
        !           174: #define        CYER_FM         0x15    /* unexpected filemark */
        !           175: #define        CYER_PARAM      0x16    /* bad parameter, byte count ? */
        !           176: #define        CYER_HDWERR     0x18    /* unidentified hardware error */
        !           177: #define        CYER_NOSTRM     0x19    /* streaming terminated */
        !           178: 
        !           179: #ifdef CYERROR
        !           180: char   *cyerror[] = {
        !           181:        "no error",
        !           182:        "timeout",
        !           183:        "timeout1",
        !           184:        "timeout2",
        !           185:        "timeout3",
        !           186:        "timeout4", 
        !           187:        "non-existent memory",
        !           188:        "blank tape",
        !           189:        "micro-diagnostic",
        !           190:        "eot/bot detected",
        !           191:        "retry unsuccessful",
        !           192:        "fifo over/under-flow",
        !           193:        "#0xc",
        !           194:        "drive to controller parity error",
        !           195:        "prom checksum",
        !           196:        "time out tape strobe (record length error)",
        !           197:        "tape not ready",
        !           198:        "write protected",
        !           199:        "#0x12",
        !           200:        "missing diagnostic jumper",
        !           201:        "invalid link pointer",
        !           202:        "unexpected file mark",
        !           203:        "invalid byte count/parameter",
        !           204:        "#0x17",
        !           205:        "unidentified hardware error",
        !           206:        "streaming terminated"
        !           207: };
        !           208: #define        NCYERROR        (sizeof (cyerror) / sizeof (cyerror[0]))
        !           209: #endif
        !           210: 
        !           211: /*
        !           212:  * Masks defining hard and soft errors (must check against 1<<CYER_code).
        !           213:  */
        !           214: #define        CYMASK(e)       (1 << (e))
        !           215: #define        CYER_HARD       (CYMASK(CYER_TIMOUT)|CYMASK(CYER_TIMOUT1)|\
        !           216:        CYMASK(CYER_TIMOUT2)|CYMASK(CYER_TIMOUT3)|CYMASK(CYER_TIMOUT4)|\
        !           217:        CYMASK(CYER_NXM)|CYMASK(CYER_DIAG)|CYMASK(CYER_JUMPER)|\
        !           218:        CYMASK(CYER_STROBE)|CYMASK(CYER_PROT)|CYMASK(CYER_CKSUM)|\
        !           219:        CYMASK(CYER_HERR)|CYMASK(CYER_BLANK))
        !           220: #define        CYER_RSOFT      (CYMASK(CYER_FIFO)|CYMASK(CYER_NOTRDY)|\
        !           221:        CYMASK(CYER_PARITY))
        !           222: #define        CYER_WSOFT      (CYMASK(CYER_HERR)|CYMASK(CYER_FIFO)|\
        !           223:        CYMASK(CYER_NOTRDY)|CYMASK(CYER_PARITY))

unix.superglobalmegacorp.com

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