Home | History | Annotate | Line # | Download | only in include
      1  1.25     ragge /*      $NetBSD: trap.h,v 1.25 2023/03/26 12:23:42 ragge Exp $     */
      2   1.2       cgd 
      3   1.1     ragge /*-
      4   1.1     ragge  * Copyright (c) 1990 The Regents of the University of California.
      5   1.1     ragge  * All rights reserved.
      6   1.1     ragge  *
      7   1.1     ragge  * This code is derived from software contributed to Berkeley by
      8   1.1     ragge  * William Jolitz.
      9   1.1     ragge  *
     10   1.1     ragge  * Redistribution and use in source and binary forms, with or without
     11   1.1     ragge  * modification, are permitted provided that the following conditions
     12   1.1     ragge  * are met:
     13   1.1     ragge  * 1. Redistributions of source code must retain the above copyright
     14   1.1     ragge  *    notice, this list of conditions and the following disclaimer.
     15   1.1     ragge  * 2. Redistributions in binary form must reproduce the above copyright
     16   1.1     ragge  *    notice, this list of conditions and the following disclaimer in the
     17   1.1     ragge  *    documentation and/or other materials provided with the distribution.
     18  1.19       agc  * 3. Neither the name of the University nor the names of its contributors
     19   1.1     ragge  *    may be used to endorse or promote products derived from this software
     20   1.1     ragge  *    without specific prior written permission.
     21   1.1     ragge  *
     22   1.1     ragge  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     23   1.1     ragge  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     24   1.1     ragge  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     25   1.1     ragge  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     26   1.1     ragge  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     27   1.1     ragge  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     28   1.1     ragge  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     29   1.1     ragge  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     30   1.1     ragge  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     31   1.1     ragge  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     32   1.1     ragge  * SUCH DAMAGE.
     33   1.1     ragge  *
     34   1.2       cgd  *	@(#)trap.h	5.4 (Berkeley) 5/9/91
     35   1.1     ragge  */
     36   1.1     ragge 
     37   1.1     ragge /*
     38   1.1     ragge  * Trap type values
     39   1.1     ragge  * also known in trap.c for name strings
     40   1.1     ragge  */
     41   1.6     ragge #ifndef _VAX_TRAP_H_
     42   1.6     ragge #define _VAX_TRAP_H_
     43   1.1     ragge 
     44   1.1     ragge #define	T_RESADFLT	0	/* reserved addressing */
     45   1.1     ragge #define	T_PRIVINFLT	1	/* privileged instruction */
     46   1.1     ragge #define	T_RESOPFLT	2	/* reserved operand */
     47   1.1     ragge #define	T_BPTFLT	3	/* breakpoint instruction */
     48  1.16     ragge #define	T_XFCFLT	4	/* Customer reserved instruction */
     49   1.1     ragge #define	T_SYSCALL	5	/* system call (kcall) */
     50   1.3     ragge #define	T_ARITHFLT	6	/* arithmetic trap */
     51   1.1     ragge #define	T_ASTFLT	7	/* system forced exception */
     52   1.4     ragge #define	T_PTELEN	8	/* Page table length exceeded */
     53   1.3     ragge #define	T_TRANSFLT	9	/* translation fault */
     54   1.7     ragge #define	T_TRCTRAP	10	/* trace trap */
     55  1.11     ragge #define	T_COMPAT	11	/* compatibility mode fault on VAX */
     56   1.4     ragge #define	T_ACCFLT	12	/* Access violation fault */
     57   1.8     ragge #define	T_KSPNOTVAL	15	/* kernel stack pointer not valid */
     58   1.8     ragge #define	T_KDBTRAP	17	/* kernel debugger trap */
     59   1.1     ragge 
     60   1.4     ragge /* These gets ORed with the word for page handling routines */
     61   1.4     ragge #define	T_WRITE		0x80
     62   1.4     ragge #define	T_PTEFETCH	0x40
     63   1.1     ragge 
     64  1.22  christos /* Section 6.4.1 Arithmetic Traps/Faults */
     65  1.22  christos #define ATRP_INTOVF	0x1	/* integer overflow */
     66  1.22  christos #define ATRP_INTDIV	0x2	/* integer divide by zero */
     67  1.22  christos #define ATRP_FLTOVF	0x3	/* floating overflow */
     68  1.22  christos #define ATRP_FLTDIV	0x4	/* floating/decimal divide by zero */
     69  1.22  christos #define ATRP_FLTUND	0x5	/* floating underflow */
     70  1.22  christos #define ATRP_DECOVF	0x6	/* decimal underflow */
     71  1.22  christos #define ATRP_FLTSUB	0x7	/* subscript range */
     72  1.21      matt #define	AFLT_FLTOVF	0x8	/* floating overflow */
     73  1.21      matt #define	AFLT_FLTDIV	0x9	/* floating divide-by-zero */
     74  1.21      matt #define	AFLT_FLTUND	0xa	/* floating underflow */
     75  1.21      matt 
     76  1.23      matt /* Used by RAS to detect an interrupted CAS */
     77  1.25     ragge #define	CASMAGIC	0xFEDABABE /* always invalid space */
     78  1.23      matt 
     79   1.1     ragge /* Trap's coming from user mode */
     80   1.3     ragge #define	T_USER	0x100
     81   1.3     ragge 
     82  1.12   mycroft #ifndef _LOCORE
     83   1.4     ragge struct	trapframe {
     84  1.24      matt 	long	tf_fp;	/* Stack frame pointer */
     85  1.24      matt 	long	tf_ap;     /* Argument pointer on user stack */
     86  1.24      matt 	long	tf_sp;	/* Stack pointer */
     87  1.24      matt 	long	tf_r0;     /* General registers saved upon trap/syscall */
     88  1.24      matt 	long	tf_r1;
     89  1.24      matt 	long	tf_r2;
     90  1.24      matt 	long	tf_r3;
     91  1.24      matt 	long	tf_r4;
     92  1.24      matt 	long	tf_r5;
     93  1.24      matt 	long	tf_r6;
     94  1.24      matt 	long	tf_r7;
     95  1.24      matt 	long	tf_r8;
     96  1.24      matt 	long	tf_r9;
     97  1.24      matt 	long	tf_r10;
     98  1.24      matt 	long	tf_r11;
     99  1.24      matt 	long	tf_trap;	/* Type of trap */
    100  1.24      matt         long	tf_code;   /* Trap specific code */
    101  1.24      matt         long	tf_pc;     /* User pc */
    102  1.24      matt         long	tf_psl;    /* User psl */
    103   1.3     ragge };
    104   1.9     ragge 
    105  1.12   mycroft #endif /* _LOCORE */
    106   1.6     ragge 
    107  1.17      matt #endif /* _VAX_TRAP_H_ */
    108