Annotation of 43BSDReno/sys/vaxif/if_dmc.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1982, 1986 Regents of the University of California.
        !             3:  * All rights reserved.
        !             4:  *
        !             5:  * Redistribution is only permitted until one year after the first shipment
        !             6:  * of 4.4BSD by the Regents.  Otherwise, redistribution and use in source and
        !             7:  * binary forms are permitted provided that: (1) source distributions retain
        !             8:  * this entire copyright notice and comment, and (2) distributions including
        !             9:  * binaries display the following acknowledgement:  This product includes
        !            10:  * software developed by the University of California, Berkeley and its
        !            11:  * contributors'' in the documentation or other materials provided with the
        !            12:  * distribution and in all advertising materials mentioning features or use
        !            13:  * of this software.  Neither the name of the University nor the names of
        !            14:  * its contributors may be used to endorse or promote products derived from
        !            15:  * this software without specific prior written permission.
        !            16:  * THIS SOFTWARE IS PROVIDED AS IS'' AND WITHOUT ANY EXPRESS OR IMPLIED
        !            17:  * WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED WARRANTIES OF
        !            18:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.
        !            19:  *
        !            20:  *     @(#)if_dmc.h    7.5 (Berkeley) 6/28/90
        !            21:  */
        !            22: 
        !            23: /*
        !            24:  * DMC-11 Interface
        !            25:  */
        !            26: 
        !            27: struct dmcdevice {
        !            28:         char    bsel0;
        !            29:        char    bsel1;
        !            30:        char    bsel2;
        !            31:        char    bsel3;
        !            32:        short   sel4;
        !            33:        short   sel6;
        !            34: };
        !            35: 
        !            36: /*
        !            37:  * dmc software packet encapsulation.  This allows the dmc
        !            38:  * link to be multiplexed among several protocols.
        !            39:  * The first eight bytes of the dmc header are garbage,
        !            40:  * since on a vax the uba has been known to mung these
        !            41:  * bytes.  The next two bytes encapsulate packet type.
        !            42:  */
        !            43: struct dmc_header {
        !            44:        char    dmc_buf[8];     /* space for uba on vax */
        !            45:        short   dmc_type;       /* encapsulate packet type */
        !            46: };
        !            47: 
        !            48: /* packet types */
        !            49: #define        DMC_IPTYPE      1
        !            50: #define        DMC_TRAILER     2
        !            51: #define        DMC_NTRAILER    16
        !            52: 
        !            53: /*
        !            54:  * DMCMTU includes space for data (1024) + 
        !            55:  * protocol header (256) + trailer descriptor (4).
        !            56:  * The software link encapsulation header (dmc_header)
        !            57:  * is handled separately.
        !            58:        #define DMCMTU  1284
        !            59:  */
        !            60: #define DMCMTU  1500
        !            61: 
        !            62: #define        RDYSCAN 16      /* loop delay for RDYI after RQI */
        !            63: 
        !            64: /* defines for bsel0 */
        !            65: #define        DMC_BACCI       0
        !            66: #define        DMC_CNTLI       1
        !            67: #define        DMC_PERR        2
        !            68: #define        DMC_BASEI       3
        !            69: #define        DMC_WRITE       0               /* transmit block */
        !            70: #define        DMC_READ        4               /* read block */
        !            71: #define        DMC_RQI         0040            /* port request bit */
        !            72: #define        DMC_IEI         0100            /* enable input interrupts */
        !            73: #define        DMC_RDYI        0200            /* port ready */
        !            74: #define        DMC0BITS        "\10\10RDI\7IEI\6RQI"
        !            75: 
        !            76: /* defines for bsel1 */
        !            77: #define        DMC_MCLR        0100            /* DMC11 Master Clear */
        !            78: #define        DMC_RUN         0200            /* clock running */
        !            79: #define        DMC1BITS        "\10\10RUN\7MCLR"
        !            80: 
        !            81: /* defines for bsel2 */
        !            82: #define        DMC_BACCO       0
        !            83: #define        DMC_CNTLO       1
        !            84: #define        DMC_OUX         0               /* transmit block */
        !            85: #define        DMC_OUR         4               /* read block */
        !            86: #define        DMC_IEO         0100            /* enable output interrupts */
        !            87: #define        DMC_RDYO        0200            /* port available */
        !            88: #define        DMC2BITS        "\10\10RDO\7IEO"
        !            89: 
        !            90: /* defines for CNTLI mode */
        !            91: #define        DMC_HDPLX       02000           /* half duplex DDCMP operation */
        !            92: #define        DMC_SEC         04000           /* half duplex secondary station */
        !            93: #define        DMC_MAINT       00400           /* enter maintenance mode */
        !            94: 
        !            95: /* defines for BACCI/O and BASEI mode */
        !            96: #define        DMC_XMEM        0140000         /* xmem bit position */
        !            97: #define        DMC_CCOUNT      0037777         /* character count mask */
        !            98: #define        DMC_RESUME      0002000         /* resume (BASEI only) */
        !            99: 
        !           100: /* defines for CNTLO */
        !           101: #define        DMC_CNTMASK     01777
        !           102: 
        !           103: #define        DMC_DATACK      01
        !           104: #define        DMC_TIMEOUT     02
        !           105: #define        DMC_NOBUFS      04
        !           106: #define        DMC_MAINTREC    010
        !           107: #define        DMC_LOSTDATA    020
        !           108: #define        DMC_DISCONN     0100
        !           109: #define        DMC_START       0200
        !           110: #define        DMC_NEXMEM      0400
        !           111: #define        DMC_ERROR       01000
        !           112: 
        !           113: #define        DMC_FATAL (DMC_ERROR|DMC_NEXMEM|DMC_START|DMC_LOSTDATA|DMC_MAINTREC)
        !           114: #define        CNTLO_BITS      \
        !           115:    "\10\12ERROR\11NEXMEM\10START\7DISC\5LSTDATA\4MAINT\3NOBUF\2TIMEO\1DATACK"

unix.superglobalmegacorp.com

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