Home | History | Annotate | Line # | Download | only in include
trap.h revision 1.17
      1  1.17     matt /*      $NetBSD: trap.h,v 1.17 2000/01/24 02:40:32 matt 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.1    ragge  * 3. All advertising materials mentioning features or use of this software
     19   1.1    ragge  *    must display the following acknowledgement:
     20   1.1    ragge  *	This product includes software developed by the University of
     21   1.1    ragge  *	California, Berkeley and its contributors.
     22   1.1    ragge  * 4. Neither the name of the University nor the names of its contributors
     23   1.1    ragge  *    may be used to endorse or promote products derived from this software
     24   1.1    ragge  *    without specific prior written permission.
     25   1.1    ragge  *
     26   1.1    ragge  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     27   1.1    ragge  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     28   1.1    ragge  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     29   1.1    ragge  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     30   1.1    ragge  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     31   1.1    ragge  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     32   1.1    ragge  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     33   1.1    ragge  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     34   1.1    ragge  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     35   1.1    ragge  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     36   1.1    ragge  * SUCH DAMAGE.
     37   1.1    ragge  *
     38   1.2      cgd  *	@(#)trap.h	5.4 (Berkeley) 5/9/91
     39   1.1    ragge  */
     40   1.1    ragge 
     41   1.1    ragge /*
     42   1.1    ragge  * Trap type values
     43   1.1    ragge  * also known in trap.c for name strings
     44   1.1    ragge  */
     45   1.6    ragge #ifndef _VAX_TRAP_H_
     46   1.6    ragge #define _VAX_TRAP_H_
     47   1.1    ragge 
     48   1.1    ragge #define	T_RESADFLT	0	/* reserved addressing */
     49   1.1    ragge #define	T_PRIVINFLT	1	/* privileged instruction */
     50   1.1    ragge #define	T_RESOPFLT	2	/* reserved operand */
     51   1.1    ragge #define	T_BPTFLT	3	/* breakpoint instruction */
     52  1.16    ragge #define	T_XFCFLT	4	/* Customer reserved instruction */
     53   1.1    ragge #define	T_SYSCALL	5	/* system call (kcall) */
     54   1.3    ragge #define	T_ARITHFLT	6	/* arithmetic trap */
     55   1.1    ragge #define	T_ASTFLT	7	/* system forced exception */
     56   1.4    ragge #define	T_PTELEN	8	/* Page table length exceeded */
     57   1.3    ragge #define	T_TRANSFLT	9	/* translation fault */
     58   1.7    ragge #define	T_TRCTRAP	10	/* trace trap */
     59  1.11    ragge #define	T_COMPAT	11	/* compatibility mode fault on VAX */
     60   1.4    ragge #define	T_ACCFLT	12	/* Access violation fault */
     61   1.8    ragge #define	T_KSPNOTVAL	15	/* kernel stack pointer not valid */
     62   1.8    ragge #define	T_KDBTRAP	17	/* kernel debugger trap */
     63   1.1    ragge 
     64   1.4    ragge /* These gets ORed with the word for page handling routines */
     65   1.4    ragge #define	T_WRITE		0x80
     66   1.4    ragge #define	T_PTEFETCH	0x40
     67   1.1    ragge 
     68   1.1    ragge /* Trap's coming from user mode */
     69   1.3    ragge #define	T_USER	0x100
     70   1.3    ragge 
     71  1.12  mycroft #ifndef _LOCORE
     72   1.4    ragge struct	trapframe {
     73  1.15    ragge 	long	fp;	/* Stack frame pointer */
     74  1.15    ragge 	long	ap;     /* Argument pointer on user stack */
     75  1.15    ragge 	long	sp;	/* Stack pointer */
     76  1.15    ragge 	long	r0;     /* General registers saved upon trap/syscall */
     77  1.15    ragge 	long	r1;
     78  1.15    ragge 	long	r2;
     79  1.15    ragge 	long	r3;
     80  1.15    ragge 	long	r4;
     81  1.15    ragge 	long	r5;
     82  1.15    ragge 	long	r6;
     83  1.15    ragge 	long	r7;
     84  1.15    ragge 	long	r8;
     85  1.15    ragge 	long	r9;
     86  1.15    ragge 	long	r10;
     87  1.15    ragge 	long	r11;
     88  1.15    ragge 	long	trap;	/* Type of trap */
     89  1.15    ragge         long	code;   /* Trap specific code */
     90  1.15    ragge         long	pc;     /* User pc */
     91  1.15    ragge         long	psl;    /* User psl */
     92   1.3    ragge };
     93   1.9    ragge 
     94   1.9    ragge /*
     95   1.9    ragge  * This struct is used when setting up interrupt vectors dynamically.
     96   1.9    ragge  * It pushes a longword between 0-63 on the stack; this number is
     97   1.9    ragge  * normally used as the ctlr number on devices. This use effectively
     98  1.11    ragge  * limits the number of interruptable ctlrs on one unibus to 64.
     99   1.9    ragge  */
    100   1.9    ragge struct ivec_dsp {
    101   1.9    ragge 	char	pushr; 		/* pushr */
    102  1.17     matt 	char	pushrarg;	/* $0x3f */
    103  1.17     matt 	char	jsb;
    104  1.17     matt 	char	mode;
    105  1.17     matt 	long	displacement;
    106  1.17     matt 	void	(*hoppaddr) __P((void *));
    107  1.17     matt 	void	*pushlarg;
    108   1.9    ragge };
    109  1.14    ragge 
    110  1.17     matt #ifdef _KERNEL
    111  1.17     matt extern	const struct ivec_dsp idsptch;
    112  1.17     matt #endif
    113   1.9    ragge 
    114  1.12  mycroft #endif /* _LOCORE */
    115   1.6    ragge 
    116  1.17     matt #endif /* _VAX_TRAP_H_ */
    117