123288Smckusick /* 229277Smckusick * Copyright (c) 1982, 1986 Regents of the University of California. 3*35317Sbostic * All rights reserved. 423288Smckusick * 5*35317Sbostic * Redistribution and use in source and binary forms are permitted 6*35317Sbostic * provided that the above copyright notice and this paragraph are 7*35317Sbostic * duplicated in all such forms and that any documentation, 8*35317Sbostic * advertising materials, and other materials related to such 9*35317Sbostic * distribution and use acknowledge that the software was developed 10*35317Sbostic * by the University of California, Berkeley. The name of the 11*35317Sbostic * University may not be used to endorse or promote products derived 12*35317Sbostic * from this software without specific prior written permission. 13*35317Sbostic * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR 14*35317Sbostic * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED 15*35317Sbostic * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE. 16*35317Sbostic * 17*35317Sbostic * @(#)if_dmc.h 7.4 (Berkeley) 08/04/88 1823288Smckusick */ 195854Sroot 205854Sroot /* 215854Sroot * DMC-11 Interface 225854Sroot */ 235854Sroot 245854Sroot struct dmcdevice { 2517564Skarels char bsel0; 2617564Skarels char bsel1; 2717564Skarels char bsel2; 2817564Skarels char bsel3; 2917564Skarels short sel4; 3017564Skarels short sel6; 315854Sroot }; 325854Sroot 3317564Skarels /* 3417564Skarels * dmc software packet encapsulation. This allows the dmc 3517564Skarels * link to be multiplexed among several protocols. 3617564Skarels * The first eight bytes of the dmc header are garbage, 3717564Skarels * since on a vax the uba has been known to mung these 3817564Skarels * bytes. The next two bytes encapsulate packet type. 3917564Skarels */ 4017564Skarels struct dmc_header { 4117564Skarels char dmc_buf[8]; /* space for uba on vax */ 4217564Skarels short dmc_type; /* encapsulate packet type */ 4317564Skarels }; 445854Sroot 4517564Skarels /* packet types */ 4617564Skarels #define DMC_IPTYPE 1 4717564Skarels #define DMC_TRAILER 2 4817564Skarels #define DMC_NTRAILER 16 495854Sroot 5017564Skarels /* 5117564Skarels * DMCMTU includes space for data (1024) + 5217564Skarels * protocol header (256) + trailer descriptor (4). 5317564Skarels * The software link encapsulation header (dmc_header) 5417564Skarels * is handled separately. 5533036Skarels #define DMCMTU 1284 5617564Skarels */ 5733036Skarels #define DMCMTU 1500 5817564Skarels 595921Ssam #define RDYSCAN 16 /* loop delay for RDYI after RQI */ 605854Sroot 615854Sroot /* defines for bsel0 */ 625854Sroot #define DMC_BACCI 0 635854Sroot #define DMC_CNTLI 1 645854Sroot #define DMC_PERR 2 655854Sroot #define DMC_BASEI 3 665854Sroot #define DMC_WRITE 0 /* transmit block */ 675854Sroot #define DMC_READ 4 /* read block */ 685854Sroot #define DMC_RQI 0040 /* port request bit */ 695854Sroot #define DMC_IEI 0100 /* enable input interrupts */ 705854Sroot #define DMC_RDYI 0200 /* port ready */ 7134504Skarels #define DMC0BITS "\10\10RDI\7IEI\6RQI" 725854Sroot 735854Sroot /* defines for bsel1 */ 745854Sroot #define DMC_MCLR 0100 /* DMC11 Master Clear */ 755854Sroot #define DMC_RUN 0200 /* clock running */ 7634504Skarels #define DMC1BITS "\10\10RUN\7MCLR" 775854Sroot 785854Sroot /* defines for bsel2 */ 795854Sroot #define DMC_BACCO 0 805854Sroot #define DMC_CNTLO 1 815854Sroot #define DMC_OUX 0 /* transmit block */ 825854Sroot #define DMC_OUR 4 /* read block */ 835854Sroot #define DMC_IEO 0100 /* enable output interrupts */ 845854Sroot #define DMC_RDYO 0200 /* port available */ 8534504Skarels #define DMC2BITS "\10\10RDO\7IEO" 865854Sroot 875854Sroot /* defines for CNTLI mode */ 885854Sroot #define DMC_HDPLX 02000 /* half duplex DDCMP operation */ 895854Sroot #define DMC_SEC 04000 /* half duplex secondary station */ 905854Sroot #define DMC_MAINT 00400 /* enter maintenance mode */ 915854Sroot 925854Sroot /* defines for BACCI/O and BASEI mode */ 935854Sroot #define DMC_XMEM 0140000 /* xmem bit position */ 945854Sroot #define DMC_CCOUNT 0037777 /* character count mask */ 955854Sroot #define DMC_RESUME 0002000 /* resume (BASEI only) */ 965854Sroot 975854Sroot /* defines for CNTLO */ 985854Sroot #define DMC_CNTMASK 01777 9917219Stef 10017219Stef #define DMC_DATACK 01 10117219Stef #define DMC_TIMEOUT 02 10217219Stef #define DMC_NOBUFS 04 10317219Stef #define DMC_MAINTREC 010 10417219Stef #define DMC_LOSTDATA 020 10517219Stef #define DMC_DISCONN 0100 10617219Stef #define DMC_START 0200 10717219Stef #define DMC_NEXMEM 0400 10817219Stef #define DMC_ERROR 01000 10917219Stef 11017219Stef #define DMC_FATAL (DMC_ERROR|DMC_NEXMEM|DMC_START|DMC_LOSTDATA|DMC_MAINTREC) 11117219Stef #define CNTLO_BITS \ 11217219Stef "\10\12ERROR\11NEXMEM\10START\7DISC\5LSTDATA\4MAINT\3NOBUF\2TIMEO\1DATACK" 113