Annotation of 43BSDTahoe/sys/vaxbi/kdbreg.h, revision 1.1

1.1     ! root        1: /*
        !             2:  * Copyright (c) 1988 Regents of the University of California.
        !             3:  * All rights reserved.
        !             4:  *
        !             5:  * This code is derived from software contributed to Berkeley by
        !             6:  * Chris Torek.
        !             7:  *
        !             8:  * Redistribution and use in source and binary forms are permitted
        !             9:  * provided that the above copyright notice and this paragraph are
        !            10:  * duplicated in all such forms and that any documentation,
        !            11:  * advertising materials, and other materials related to such
        !            12:  * distribution and use acknowledge that the software was developed
        !            13:  * by the University of California, Berkeley.  The name of the
        !            14:  * University may not be used to endorse or promote products derived
        !            15:  * from this software without specific prior written permission.
        !            16:  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR
        !            17:  * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED
        !            18:  * WARRANTIES OF MERCHANTIBILITY AND FITNESS FOR A PARTICULAR PURPOSE.
        !            19:  *
        !            20:  *     @(#)kdbreg.h    7.2 (Berkeley) 7/9/88
        !            21:  */
        !            22: 
        !            23: /*
        !            24:  * The KDB50 registers are embedded inside the bi interface
        !            25:  * general-purpose registers.
        !            26:  */
        !            27: struct kdb_regs {
        !            28:        struct  biiregs kdb_bi;
        !            29:        short   kdb_xxx;        /* first half of GPR 0 unused */
        !            30:        short   kdb_ip;         /* initialisation and polling */
        !            31:        short   kdb_sa;         /* status & address (r/o half) */
        !            32:        short   kdb_sw;         /* status & address (w/o half) */
        !            33: };
        !            34: 
        !            35: /*
        !            36:  * Bits in KDB status register during initialisation
        !            37:  */
        !            38: #define        KDB_ERR         0x8000  /* error */
        !            39: #define        KDB_STEP4       0x4000  /* step 4 has started */
        !            40: #define        KDB_STEP3       0x2000  /* step 3 has started */
        !            41: #define        KDB_STEP2       0x1000  /* step 2 has started */
        !            42: #define        KDB_STEP1       0x0800  /* step 1 has started */
        !            43: #define        KDB_DI          0x0100  /* controller implements diagnostics */
        !            44: #define        KDB_IE          0x0080  /* interrupt enable */
        !            45: #define        KDB_NCNRMASK    0x003f  /* in STEP1, bits 0-2=NCMDL2, 3-5=NRSPL2 */
        !            46: #define        KDB_IVECMASK    0x007f  /* in STEP2, bits 0-6 are interruptvec / 4 */
        !            47: 
        !            48: /* after initialisation: */
        !            49: #define        KDB_GO          0x0001  /* run */
        !            50: 
        !            51: #define KDBSR_BITS \
        !            52: "\20\20ERR\17STEP4\16STEP3\15STEP2\14STEP1\13oldNV\12oldQB\11DI\10IE\1GO"
        !            53: 
        !            54: /*
        !            55:  * KDB Communications Area.  Note that this structure definition
        !            56:  * requires NRSP and NCMD to be defined already.
        !            57:  */
        !            58: struct kdbca {
        !            59:        short   ca_xxx1;        /* unused */
        !            60:        char    ca_xxx2;        /* unused */
        !            61:        char    ca_bdp;         /* BDP to purge  XXX */
        !            62:        short   ca_cmdint;      /* command ring transition flag */
        !            63:        short   ca_rspint;      /* response ring transition flag */
        !            64:        long    ca_rspdsc[NRSP];/* response descriptors */
        !            65:        long    ca_cmddsc[NCMD];/* command descriptors */
        !            66: };
        !            67: 
        !            68: /*
        !            69:  * Simplified routines (crash dump) use one command and one response.
        !            70:  */
        !            71: struct kdb1ca {
        !            72:        long    ca_xxx;
        !            73:        short   ca_cmdint;
        !            74:        short   ca_rspint;
        !            75:        long    ca_rspdsc;
        !            76:        long    ca_cmddsc;
        !            77: };
        !            78: 
        !            79: /*
        !            80:  * Asserting KDB_MAP in values placed in mscp_seq.seq_buffer tells
        !            81:  * the KDB to use mscp_seq.seq_mapbase as a set of PTEs and seq_buffer
        !            82:  * as an offset value.  Hence we need no mappings; the KDB50 reads
        !            83:  * the hardware page tables directly.  (Without KDB_MAP, seq_bufer
        !            84:  * represents the physical memory address instead, and seq_mapbase is
        !            85:  * unused.)
        !            86:  */
        !            87: #define        KDB_MAP         0x80000000
        !            88: #define        KDB_PHYS        0               /* pseudo flag */
        !            89: 
        !            90: /*
        !            91:  * KDB statistics.
        !            92:  */
        !            93: #define        KS_MAXC 32
        !            94: 
        !            95: struct kdbstats {
        !            96:        int     ks_sys;         /* transfers done from Sysmap */
        !            97:        int     ks_paget;       /* transfers done from Usrptmap */
        !            98:        int     ks_contig;      /* transfers done from contiguous user map */
        !            99:        int     ks_copies;      /* transfers done from pte copies */
        !           100:        int     ks_mapwait;     /* number of out-of-map waits */
        !           101:        int     ks_cmd[KS_MAXC];/* commands started at once */
        !           102:        int     ks_inval;       /* copies due to !PG_V */
        !           103: };

unix.superglobalmegacorp.com

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