[BACK]Return to trap.h CVS log [TXT][DIR] Up to [local] / sys / arch / mips64 / include

Annotation of sys/arch/mips64/include/trap.h, Revision 1.1.1.1

1.1       nbrk        1: /*      $OpenBSD: trap.h,v 1.8 2007/05/20 14:34:21 miod Exp $  */
                      2:
                      3: /*
                      4:  * Copyright (c) 1988 University of Utah.
                      5:  * Copyright (c) 1992, 1993
                      6:  *     The Regents of the University of California.  All rights reserved.
                      7:  *
                      8:  * This code is derived from software contributed to Berkeley by
                      9:  * the Systems Programming Group of the University of Utah Computer
                     10:  * Science Department and Ralph Campbell.
                     11:  *
                     12:  * Redistribution and use in source and binary forms, with or without
                     13:  * modification, are permitted provided that the following conditions
                     14:  * are met:
                     15:  * 1. Redistributions of source code must retain the above copyright
                     16:  *    notice, this list of conditions and the following disclaimer.
                     17:  * 2. Redistributions in binary form must reproduce the above copyright
                     18:  *    notice, this list of conditions and the following disclaimer in the
                     19:  *    documentation and/or other materials provided with the distribution.
                     20:  * 3. Neither the name of the University nor the names of its contributors
                     21:  *    may be used to endorse or promote products derived from this software
                     22:  *    without specific prior written permission.
                     23:  *
                     24:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
                     25:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
                     26:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
                     27:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
                     28:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
                     29:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
                     30:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     31:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     32:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     33:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     34:  * SUCH DAMAGE.
                     35:  *
                     36:  *     from: Utah Hdr: trap.h 1.1 90/07/09
                     37:  *     from: @(#)trap.h        8.1 (Berkeley) 6/10/93
                     38:  */
                     39:
                     40: #ifndef _MIPS_TRAP_H_
                     41: #define _MIPS_TRAP_H_
                     42:
                     43: /*
                     44:  * Trap codes (ExcCode in the cause register); also known in trap.c for
                     45:  * name strings.
                     46:  */
                     47:
                     48: #define T_INT                  0       /* Interrupt pending */
                     49: #define T_TLB_MOD              1       /* TLB modified fault */
                     50: #define T_TLB_LD_MISS          2       /* TLB miss on load or ifetch */
                     51: #define T_TLB_ST_MISS          3       /* TLB miss on a store */
                     52: #define T_ADDR_ERR_LD          4       /* Address error on a load or ifetch */
                     53: #define T_ADDR_ERR_ST          5       /* Address error on a store */
                     54: #define T_BUS_ERR_IFETCH       6       /* Bus error on an ifetch */
                     55: #define T_BUS_ERR_LD_ST                7       /* Bus error on a load or store */
                     56: #define T_SYSCALL              8       /* System call */
                     57: #define T_BREAK                        9       /* Breakpoint */
                     58: #define T_RES_INST             10      /* Reserved instruction exception */
                     59: #define T_COP_UNUSABLE         11      /* Coprocessor unusable */
                     60: #define T_OVFLOW               12      /* Arithmetic overflow */
                     61: #define        T_TRAP                  13      /* Trap instruction */
                     62: #define        T_VCEI                  14      /* R4k Virtual coherency instruction */
                     63: #define        T_FPE                   15      /* Floating point exception */
                     64: #define        T_IWATCH                16      /* R4k Inst. Watch address reference */
                     65: #define        T_C2E                   18      /* R5k Coprocessor 2 exception */
                     66: #define        T_MDMX                  22      /* R5k MDMX unusable */
                     67: #define        T_DWATCH                23      /* Data Watch address reference */
                     68: #define        T_MCHECK                24      /* Machine check */
                     69: #define        T_CACHEERR              30      /* Cache error */
                     70: #define T_VCED                 31      /* R4k Virtual coherency data */
                     71:
                     72: #define        T_USER                  0x20    /* user-mode flag or'ed with type */
                     73:
                     74: /*
                     75:  *  Defines for trap handler catching kernel accessng memory.
                     76:  */
                     77: #define        KT_COPYERR      1               /* User space copy error */
                     78: #define        KT_KCOPYERR     2               /* Kernel space copy error */
                     79: #define        KT_DDBERR       3               /* DDB access error */
                     80:
                     81: #ifndef _LOCORE
                     82:
                     83: #if defined(DDB) || defined(DEBUG)
                     84:
                     85: struct trapdebug {              /* trap history buffer for debugging */
                     86:        u_int   status;
                     87:         u_int  cause;
                     88:         u_long vadr;
                     89:         u_long   pc;
                     90:         u_long   ra;
                     91:         u_long   sp;
                     92:         u_int   code;
                     93:        u_int   cpl;
                     94: };
                     95:
                     96: #define        trapdebug_enter(x, cd) {        \
                     97:        u_int32_t __s = disableintr();  \
                     98:        trp->status = x->sr;            \
                     99:        trp->cause = x->cause;          \
                    100:        trp->vadr = x->badvaddr;        \
                    101:        trp->pc = x->pc;                \
                    102:        trp->sp = x->sp;                \
                    103:        trp->ra = x->ra;                \
                    104:        trp->cpl = x->cpl;              \
                    105:        trp->code = cd;                         \
                    106:        if (++trp == &trapdebug[TRAPSIZE])      \
                    107:                trp = trapdebug;                \
                    108:        setsr(__s);                             \
                    109:  }
                    110:
                    111: #define TRAPSIZE 10            /* Trap log buffer length */
                    112: extern struct trapdebug trapdebug[TRAPSIZE], *trp;
                    113:
                    114: void trapDump(char *msg);
                    115:
                    116: #else
                    117:
                    118: #define        trapdebug_enter(x, y)
                    119:
                    120: #endif
                    121: #endif /* _LOCORE */
                    122:
                    123: #endif /* !_MIPS_TRAP_H_ */

CVSweb