Home | History | Annotate | Line # | Download | only in include
frame.h revision 1.3.2.1
      1  1.3.2.1  cgd /* $NetBSD: frame.h,v 1.3.2.1 1997/06/01 04:12:17 cgd Exp $ */
      2      1.1  cgd 
      3      1.1  cgd /*
      4      1.1  cgd  * Copyright (c) 1994, 1995 Carnegie-Mellon University.
      5      1.1  cgd  * All rights reserved.
      6      1.1  cgd  *
      7      1.1  cgd  * Author: Chris G. Demetriou
      8      1.1  cgd  *
      9      1.1  cgd  * Permission to use, copy, modify and distribute this software and
     10      1.1  cgd  * its documentation is hereby granted, provided that both the copyright
     11      1.1  cgd  * notice and this permission notice appear in all copies of the
     12      1.1  cgd  * software, derivative works or modified versions, and any portions
     13      1.1  cgd  * thereof, and that both notices appear in supporting documentation.
     14      1.1  cgd  *
     15      1.1  cgd  * CARNEGIE MELLON ALLOWS FREE USE OF THIS SOFTWARE IN ITS "AS IS"
     16      1.1  cgd  * CONDITION.  CARNEGIE MELLON DISCLAIMS ANY LIABILITY OF ANY KIND
     17      1.1  cgd  * FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
     18      1.1  cgd  *
     19      1.1  cgd  * Carnegie Mellon requests users of this software to return to
     20      1.1  cgd  *
     21      1.1  cgd  *  Software Distribution Coordinator  or  Software.Distribution (at) CS.CMU.EDU
     22      1.1  cgd  *  School of Computer Science
     23      1.1  cgd  *  Carnegie Mellon University
     24      1.1  cgd  *  Pittsburgh PA 15213-3890
     25      1.1  cgd  *
     26      1.1  cgd  * any improvements or extensions that they make and grant Carnegie the
     27      1.1  cgd  * rights to redistribute these changes.
     28      1.1  cgd  */
     29      1.1  cgd 
     30      1.1  cgd #ifndef _ALPHA_FRAME_H_
     31      1.1  cgd #define	_ALPHA_FRAME_H_
     32      1.1  cgd 
     33      1.2  cgd #include <machine/alpha_cpu.h>
     34      1.1  cgd 
     35      1.1  cgd /*
     36      1.3  cgd  * Software trap, exception, and syscall frame.
     37      1.1  cgd  *
     38      1.3  cgd  * Includes "hardware" (PALcode) frame.
     39      1.3  cgd  *
     40      1.3  cgd  * PALcode puts ALPHA_HWFRAME_* fields on stack.  We have to add
     41      1.3  cgd  * all of the general-purpose registers except for zero, for sp
     42      1.3  cgd  * (which is automatically saved in the PCB's USP field for entries
     43      1.3  cgd  * from user mode, and which is implicitly saved and restored by the
     44      1.3  cgd  * calling conventions for entries from kernel mode), and (on traps
     45      1.3  cgd  * and exceptions) for a0, a1, and a2 (which are saved by PALcode).
     46      1.1  cgd  */
     47      1.1  cgd 
     48      1.3  cgd /* Quadword offsets of the registers to be saved. */
     49      1.1  cgd #define	FRAME_V0	0
     50      1.1  cgd #define	FRAME_T0	1
     51      1.1  cgd #define	FRAME_T1	2
     52      1.1  cgd #define	FRAME_T2	3
     53      1.1  cgd #define	FRAME_T3	4
     54      1.1  cgd #define	FRAME_T4	5
     55      1.1  cgd #define	FRAME_T5	6
     56      1.1  cgd #define	FRAME_T6	7
     57      1.1  cgd #define	FRAME_T7	8
     58      1.1  cgd #define	FRAME_S0	9
     59      1.1  cgd #define	FRAME_S1	10
     60      1.1  cgd #define	FRAME_S2	11
     61      1.1  cgd #define	FRAME_S3	12
     62      1.1  cgd #define	FRAME_S4	13
     63      1.1  cgd #define	FRAME_S5	14
     64      1.1  cgd #define	FRAME_S6	15
     65      1.1  cgd #define	FRAME_A3	16
     66      1.1  cgd #define	FRAME_A4	17
     67      1.1  cgd #define	FRAME_A5	18
     68      1.1  cgd #define	FRAME_T8	19
     69      1.1  cgd #define	FRAME_T9	20
     70      1.1  cgd #define	FRAME_T10	21
     71      1.1  cgd #define	FRAME_T11	22
     72      1.1  cgd #define	FRAME_RA	23
     73      1.1  cgd #define	FRAME_T12	24
     74      1.1  cgd #define	FRAME_AT	25
     75      1.1  cgd #define	FRAME_SP	26
     76      1.3  cgd 
     77      1.3  cgd #define	FRAME_SW_SIZE	(FRAME_SP + 1)
     78      1.3  cgd #define	FRAME_HW_OFFSET	FRAME_SW_SIZE
     79      1.3  cgd 
     80      1.3  cgd #define	FRAME_PS	(FRAME_HW_OFFSET + ALPHA_HWFRAME_PS)
     81      1.3  cgd #define	FRAME_PC	(FRAME_HW_OFFSET + ALPHA_HWFRAME_PC)
     82      1.3  cgd #define	FRAME_GP	(FRAME_HW_OFFSET + ALPHA_HWFRAME_GP)
     83      1.3  cgd #define	FRAME_A0	(FRAME_HW_OFFSET + ALPHA_HWFRAME_A0)
     84      1.3  cgd #define	FRAME_A1	(FRAME_HW_OFFSET + ALPHA_HWFRAME_A1)
     85      1.3  cgd #define	FRAME_A2	(FRAME_HW_OFFSET + ALPHA_HWFRAME_A2)
     86      1.3  cgd 
     87      1.3  cgd #define	FRAME_HW_SIZE	ALPHA_HWFRAME_SIZE
     88      1.3  cgd #define	FRAME_SIZE	(FRAME_HW_OFFSET + FRAME_HW_SIZE)
     89      1.1  cgd 
     90      1.1  cgd struct trapframe {
     91      1.3  cgd 	unsigned long	tf_regs[FRAME_SIZE];	/* See above */
     92      1.1  cgd };
     93      1.1  cgd 
     94      1.1  cgd #endif /* _ALPHA_FRAME_H_ */
     95