Annotation of 43BSDReno/sys/vaxbi/kdbreg.h, revision 1.1.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 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:  *     @(#)kdbreg.h    7.3 (Berkeley) 6/28/90
                     24:  */
                     25: 
                     26: /*
                     27:  * The KDB50 registers are embedded inside the bi interface
                     28:  * general-purpose registers.
                     29:  */
                     30: struct kdb_regs {
                     31:        struct  biiregs kdb_bi;
                     32:        short   kdb_xxx;        /* first half of GPR 0 unused */
                     33:        short   kdb_ip;         /* initialisation and polling */
                     34:        short   kdb_sa;         /* status & address (r/o half) */
                     35:        short   kdb_sw;         /* status & address (w/o half) */
                     36: };
                     37: 
                     38: /*
                     39:  * Bits in KDB status register during initialisation
                     40:  */
                     41: #define        KDB_ERR         0x8000  /* error */
                     42: #define        KDB_STEP4       0x4000  /* step 4 has started */
                     43: #define        KDB_STEP3       0x2000  /* step 3 has started */
                     44: #define        KDB_STEP2       0x1000  /* step 2 has started */
                     45: #define        KDB_STEP1       0x0800  /* step 1 has started */
                     46: #define        KDB_DI          0x0100  /* controller implements diagnostics */
                     47: #define        KDB_IE          0x0080  /* interrupt enable */
                     48: #define        KDB_NCNRMASK    0x003f  /* in STEP1, bits 0-2=NCMDL2, 3-5=NRSPL2 */
                     49: #define        KDB_IVECMASK    0x007f  /* in STEP2, bits 0-6 are interruptvec / 4 */
                     50: 
                     51: /* after initialisation: */
                     52: #define        KDB_GO          0x0001  /* run */
                     53: 
                     54: #define KDBSR_BITS \
                     55: "\20\20ERR\17STEP4\16STEP3\15STEP2\14STEP1\13oldNV\12oldQB\11DI\10IE\1GO"
                     56: 
                     57: /*
                     58:  * KDB Communications Area.  Note that this structure definition
                     59:  * requires NRSP and NCMD to be defined already.
                     60:  */
                     61: struct kdbca {
                     62:        short   ca_xxx1;        /* unused */
                     63:        char    ca_xxx2;        /* unused */
                     64:        char    ca_bdp;         /* BDP to purge  XXX */
                     65:        short   ca_cmdint;      /* command ring transition flag */
                     66:        short   ca_rspint;      /* response ring transition flag */
                     67:        long    ca_rspdsc[NRSP];/* response descriptors */
                     68:        long    ca_cmddsc[NCMD];/* command descriptors */
                     69: };
                     70: 
                     71: /*
                     72:  * Simplified routines (crash dump) use one command and one response.
                     73:  */
                     74: struct kdb1ca {
                     75:        long    ca_xxx;
                     76:        short   ca_cmdint;
                     77:        short   ca_rspint;
                     78:        long    ca_rspdsc;
                     79:        long    ca_cmddsc;
                     80: };
                     81: 
                     82: /*
                     83:  * Asserting KDB_MAP in values placed in mscp_seq.seq_buffer tells
                     84:  * the KDB to use mscp_seq.seq_mapbase as a set of PTEs and seq_buffer
                     85:  * as an offset value.  Hence we need no mappings; the KDB50 reads
                     86:  * the hardware page tables directly.  (Without KDB_MAP, seq_bufer
                     87:  * represents the physical memory address instead, and seq_mapbase is
                     88:  * unused.)
                     89:  */
                     90: #define        KDB_MAP         0x80000000
                     91: #define        KDB_PHYS        0               /* pseudo flag */
                     92: 
                     93: /*
                     94:  * KDB statistics.
                     95:  */
                     96: #define        KS_MAXC 32
                     97: 
                     98: struct kdbstats {
                     99:        int     ks_sys;         /* transfers done from Sysmap */
                    100:        int     ks_paget;       /* transfers done from Usrptmap */
                    101:        int     ks_contig;      /* transfers done from contiguous user map */
                    102:        int     ks_copies;      /* transfers done from pte copies */
                    103:        int     ks_mapwait;     /* number of out-of-map waits */
                    104:        int     ks_cmd[KS_MAXC];/* commands started at once */
                    105:        int     ks_inval;       /* copies due to !PG_V */
                    106: };

unix.superglobalmegacorp.com

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