1*95e1ffb1Schristos /* $NetBSD: if_dmcreg.h,v 1.4 2005/12/11 12:23:29 christos Exp $ */ 209a79adaSragge /* 309a79adaSragge * Copyright (c) 1982, 1986 Regents of the University of California. 409a79adaSragge * All rights reserved. 509a79adaSragge * 609a79adaSragge * Redistribution and use in source and binary forms, with or without 709a79adaSragge * modification, are permitted provided that the following conditions 809a79adaSragge * are met: 909a79adaSragge * 1. Redistributions of source code must retain the above copyright 1009a79adaSragge * notice, this list of conditions and the following disclaimer. 1109a79adaSragge * 2. Redistributions in binary form must reproduce the above copyright 1209a79adaSragge * notice, this list of conditions and the following disclaimer in the 1309a79adaSragge * documentation and/or other materials provided with the distribution. 14aad01611Sagc * 3. Neither the name of the University nor the names of its contributors 1509a79adaSragge * may be used to endorse or promote products derived from this software 1609a79adaSragge * without specific prior written permission. 1709a79adaSragge * 1809a79adaSragge * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND 1909a79adaSragge * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE 2009a79adaSragge * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE 2109a79adaSragge * ARE DISCLAIMED. IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE 2209a79adaSragge * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL 2309a79adaSragge * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS 2409a79adaSragge * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) 2509a79adaSragge * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT 2609a79adaSragge * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY 2709a79adaSragge * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF 2809a79adaSragge * SUCH DAMAGE. 2909a79adaSragge * 3009a79adaSragge * @(#)if_dmc.h 7.5 (Berkeley) 6/28/90 3109a79adaSragge */ 3209a79adaSragge 3309a79adaSragge /* 3409a79adaSragge * DMC-11 Interface 3509a79adaSragge */ 3609a79adaSragge 3709a79adaSragge #ifdef notdef 3809a79adaSragge struct dmcdevice { 3909a79adaSragge char bsel0; 4009a79adaSragge char bsel1; 4109a79adaSragge char bsel2; 4209a79adaSragge char bsel3; 4309a79adaSragge short sel4; 4409a79adaSragge short sel6; 4509a79adaSragge }; 4609a79adaSragge #endif 4709a79adaSragge 4809a79adaSragge #define DMC_BSEL0 0 4909a79adaSragge #define DMC_BSEL1 1 5009a79adaSragge #define DMC_BSEL2 2 5109a79adaSragge #define DMC_BSEL3 3 5209a79adaSragge #define DMC_SEL4 4 5309a79adaSragge #define DMC_SEL6 6 5409a79adaSragge 5509a79adaSragge /* 5609a79adaSragge * dmc software packet encapsulation. This allows the dmc 5709a79adaSragge * link to be multiplexed among several protocols. 5809a79adaSragge * The first eight bytes of the dmc header are garbage, 5909a79adaSragge * since on a vax the uba has been known to mung these 6009a79adaSragge * bytes. The next two bytes encapsulate packet type. 6109a79adaSragge */ 6209a79adaSragge struct dmc_header { 6309a79adaSragge char dmc_buf[8]; /* space for uba on vax */ 6409a79adaSragge short dmc_type; /* encapsulate packet type */ 6509a79adaSragge }; 6609a79adaSragge 6709a79adaSragge /* packet types */ 6809a79adaSragge #define DMC_IPTYPE 1 6909a79adaSragge #define DMC_TRAILER 2 7009a79adaSragge #define DMC_NTRAILER 16 7109a79adaSragge 7209a79adaSragge /* 7309a79adaSragge * DMCMTU includes space for data (1024) + 7409a79adaSragge * protocol header (256) + trailer descriptor (4). 7509a79adaSragge * The software link encapsulation header (dmc_header) 7609a79adaSragge * is handled separately. 7709a79adaSragge #define DMCMTU 1284 7809a79adaSragge */ 7909a79adaSragge #define DMCMTU 1500 8009a79adaSragge 8109a79adaSragge #define RDYSCAN 16 /* loop delay for RDYI after RQI */ 8209a79adaSragge 8309a79adaSragge /* defines for bsel0 */ 8409a79adaSragge #define DMC_BACCI 0 8509a79adaSragge #define DMC_CNTLI 1 8609a79adaSragge #define DMC_PERR 2 8709a79adaSragge #define DMC_BASEI 3 8809a79adaSragge #define DMC_WRITE 0 /* transmit block */ 8909a79adaSragge #define DMC_READ 4 /* read block */ 9009a79adaSragge #define DMC_RQI 0040 /* port request bit */ 9109a79adaSragge #define DMC_IEI 0100 /* enable input interrupts */ 9209a79adaSragge #define DMC_RDYI 0200 /* port ready */ 9309a79adaSragge #define DMC0BITS "\10\10RDI\7IEI\6RQI" 9409a79adaSragge 9509a79adaSragge /* defines for bsel1 */ 9609a79adaSragge #define DMC_MCLR 0100 /* DMC11 Master Clear */ 9709a79adaSragge #define DMC_RUN 0200 /* clock running */ 9809a79adaSragge #define DMC1BITS "\10\10RUN\7MCLR" 9909a79adaSragge 10009a79adaSragge /* defines for bsel2 */ 10109a79adaSragge #define DMC_BACCO 0 10209a79adaSragge #define DMC_CNTLO 1 10309a79adaSragge #define DMC_OUX 0 /* transmit block */ 10409a79adaSragge #define DMC_OUR 4 /* read block */ 10509a79adaSragge #define DMC_IEO 0100 /* enable output interrupts */ 10609a79adaSragge #define DMC_RDYO 0200 /* port available */ 10709a79adaSragge #define DMC2BITS "\10\10RDO\7IEO" 10809a79adaSragge 10909a79adaSragge /* defines for CNTLI mode */ 11009a79adaSragge #define DMC_HDPLX 02000 /* half duplex DDCMP operation */ 11109a79adaSragge #define DMC_SEC 04000 /* half duplex secondary station */ 11209a79adaSragge #define DMC_MAINT 00400 /* enter maintenance mode */ 11309a79adaSragge 11409a79adaSragge /* defines for BACCI/O and BASEI mode */ 11509a79adaSragge #define DMC_XMEM 0140000 /* xmem bit position */ 11609a79adaSragge #define DMC_CCOUNT 0037777 /* character count mask */ 11709a79adaSragge #define DMC_RESUME 0002000 /* resume (BASEI only) */ 11809a79adaSragge 11909a79adaSragge /* defines for CNTLO */ 12009a79adaSragge #define DMC_CNTMASK 01777 12109a79adaSragge 12209a79adaSragge #define DMC_DATACK 01 12309a79adaSragge #define DMC_TIMEOUT 02 12409a79adaSragge #define DMC_NOBUFS 04 12509a79adaSragge #define DMC_MAINTREC 010 12609a79adaSragge #define DMC_LOSTDATA 020 12709a79adaSragge #define DMC_DISCONN 0100 12809a79adaSragge #define DMC_START 0200 12909a79adaSragge #define DMC_NEXMEM 0400 13009a79adaSragge #define DMC_ERROR 01000 13109a79adaSragge 13209a79adaSragge #define DMC_FATAL (DMC_ERROR|DMC_NEXMEM|DMC_START|DMC_LOSTDATA|DMC_MAINTREC) 13309a79adaSragge #define CNTLO_BITS \ 13409a79adaSragge "\10\12ERROR\11NEXMEM\10START\7DISC\5LSTDATA\4MAINT\3NOBUF\2TIMEO\1DATACK" 135