Home | History | Annotate | Line # | Download | only in include
regnum.h revision 1.1
      1  1.1  jonathan /*	$NetBSD: regnum.h,v 1.1 1995/12/20 02:00:28 jonathan Exp $	*/
      2  1.1  jonathan 
      3  1.1  jonathan /*
      4  1.1  jonathan  * Copyright (c) 1988 University of Utah.
      5  1.1  jonathan  * Copyright (c) 1992, 1993
      6  1.1  jonathan  *	The Regents of the University of California.  All rights reserved.
      7  1.1  jonathan  *
      8  1.1  jonathan  * This code is derived from software contributed to Berkeley by
      9  1.1  jonathan  * the Systems Programming Group of the University of Utah Computer
     10  1.1  jonathan  * Science Department and Ralph Campbell.
     11  1.1  jonathan  *
     12  1.1  jonathan  * Redistribution and use in source and binary forms, with or without
     13  1.1  jonathan  * modification, are permitted provided that the following conditions
     14  1.1  jonathan  * are met:
     15  1.1  jonathan  * 1. Redistributions of source code must retain the above copyright
     16  1.1  jonathan  *    notice, this list of conditions and the following disclaimer.
     17  1.1  jonathan  * 2. Redistributions in binary form must reproduce the above copyright
     18  1.1  jonathan  *    notice, this list of conditions and the following disclaimer in the
     19  1.1  jonathan  *    documentation and/or other materials provided with the distribution.
     20  1.1  jonathan  * 3. All advertising materials mentioning features or use of this software
     21  1.1  jonathan  *    must display the following acknowledgement:
     22  1.1  jonathan  *	This product includes software developed by the University of
     23  1.1  jonathan  *	California, Berkeley and its contributors.
     24  1.1  jonathan  * 4. Neither the name of the University nor the names of its contributors
     25  1.1  jonathan  *    may be used to endorse or promote products derived from this software
     26  1.1  jonathan  *    without specific prior written permission.
     27  1.1  jonathan  *
     28  1.1  jonathan  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
     29  1.1  jonathan  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     30  1.1  jonathan  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     31  1.1  jonathan  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
     32  1.1  jonathan  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
     33  1.1  jonathan  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
     34  1.1  jonathan  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
     35  1.1  jonathan  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
     36  1.1  jonathan  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
     37  1.1  jonathan  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
     38  1.1  jonathan  * SUCH DAMAGE.
     39  1.1  jonathan  *
     40  1.1  jonathan  * from: Utah Hdr: reg.h 1.1 90/07/09
     41  1.1  jonathan  *
     42  1.1  jonathan  *	@(#)reg.h	8.2 (Berkeley) 1/11/94
     43  1.1  jonathan  */
     44  1.1  jonathan 
     45  1.1  jonathan /*
     46  1.1  jonathan  * Location of the users' stored
     47  1.1  jonathan  * registers relative to ZERO.
     48  1.1  jonathan  * Usage is p->p_regs[XX].
     49  1.1  jonathan  */
     50  1.1  jonathan #define ZERO	0
     51  1.1  jonathan #define AST	1
     52  1.1  jonathan #define V0	2
     53  1.1  jonathan #define V1	3
     54  1.1  jonathan #define A0	4
     55  1.1  jonathan #define A1	5
     56  1.1  jonathan #define A2	6
     57  1.1  jonathan #define A3	7
     58  1.1  jonathan #define T0	8
     59  1.1  jonathan #define T1	9
     60  1.1  jonathan #define T2	10
     61  1.1  jonathan #define T3	11
     62  1.1  jonathan #define T4	12
     63  1.1  jonathan #define T5	13
     64  1.1  jonathan #define T6	14
     65  1.1  jonathan #define T7	15
     66  1.1  jonathan #define S0	16
     67  1.1  jonathan #define S1	17
     68  1.1  jonathan #define S2	18
     69  1.1  jonathan #define S3	19
     70  1.1  jonathan #define S4	20
     71  1.1  jonathan #define S5	21
     72  1.1  jonathan #define S6	22
     73  1.1  jonathan #define S7	23
     74  1.1  jonathan #define T8	24
     75  1.1  jonathan #define T9	25
     76  1.1  jonathan #define K0	26
     77  1.1  jonathan #define K1	27
     78  1.1  jonathan #define GP	28
     79  1.1  jonathan #define SP	29
     80  1.1  jonathan #define S8	30
     81  1.1  jonathan #define RA	31
     82  1.1  jonathan #define	SR	32
     83  1.1  jonathan #define	PS	SR	/* alias for SR */
     84  1.1  jonathan #define MULLO	33
     85  1.1  jonathan #define MULHI	34
     86  1.1  jonathan #define BADVADDR 35
     87  1.1  jonathan #define CAUSE	36
     88  1.1  jonathan #define	PC	37
     89  1.1  jonathan 
     90  1.1  jonathan #define FPBASE	38
     91  1.1  jonathan #define F0	(FPBASE+0)
     92  1.1  jonathan #define F1	(FPBASE+1)
     93  1.1  jonathan #define F2	(FPBASE+2)
     94  1.1  jonathan #define F3	(FPBASE+3)
     95  1.1  jonathan #define F4	(FPBASE+4)
     96  1.1  jonathan #define F5	(FPBASE+5)
     97  1.1  jonathan #define F6	(FPBASE+6)
     98  1.1  jonathan #define F7	(FPBASE+7)
     99  1.1  jonathan #define F8	(FPBASE+8)
    100  1.1  jonathan #define F9	(FPBASE+9)
    101  1.1  jonathan #define F10	(FPBASE+10)
    102  1.1  jonathan #define F11	(FPBASE+11)
    103  1.1  jonathan #define F12	(FPBASE+12)
    104  1.1  jonathan #define F13	(FPBASE+13)
    105  1.1  jonathan #define F14	(FPBASE+14)
    106  1.1  jonathan #define F15	(FPBASE+15)
    107  1.1  jonathan #define F16	(FPBASE+16)
    108  1.1  jonathan #define F17	(FPBASE+17)
    109  1.1  jonathan #define F18	(FPBASE+18)
    110  1.1  jonathan #define F19	(FPBASE+19)
    111  1.1  jonathan #define F20	(FPBASE+20)
    112  1.1  jonathan #define F21	(FPBASE+21)
    113  1.1  jonathan #define F22	(FPBASE+22)
    114  1.1  jonathan #define F23	(FPBASE+23)
    115  1.1  jonathan #define F24	(FPBASE+24)
    116  1.1  jonathan #define F25	(FPBASE+25)
    117  1.1  jonathan #define F26	(FPBASE+26)
    118  1.1  jonathan #define F27	(FPBASE+27)
    119  1.1  jonathan #define F28	(FPBASE+28)
    120  1.1  jonathan #define F29	(FPBASE+29)
    121  1.1  jonathan #define F30	(FPBASE+30)
    122  1.1  jonathan #define F31	(FPBASE+31)
    123  1.1  jonathan #define	FSR	(FPBASE+32)
    124  1.1  jonathan 
    125  1.1  jonathan #ifdef IPCREG
    126  1.1  jonathan #define	NIPCREG (FSR + 1)
    127  1.1  jonathan int ipcreg[NIPCREG] = {
    128  1.1  jonathan 	ZERO, AST, V0, V1, A0, A1, A2, A3, T0, T1, T2, T3, T4, T5, T6, T7,
    129  1.1  jonathan 	S0, S1, S2, S3, S4, S5, S6, S7, T8, T9, K0, K1, GP, SP, S8, RA,
    130  1.1  jonathan 	SR, MULLO, MULHI, BADVADDR, CAUSE, PC,
    131  1.1  jonathan 	F0, F1, F2, F3, F4, F5, F6, F7,
    132  1.1  jonathan 	F8, F9, F10, F11, F12, F13, F14, F15,
    133  1.1  jonathan 	F16, F17, F18, F19, F20, F21, F22, F23,
    134  1.1  jonathan 	F24, F25, F26, F27, F28, F29, F30, F31, FSR,
    135  1.1  jonathan };
    136  1.1  jonathan #endif
    137  1.1  jonathan 
    138  1.1  jonathan #ifdef LANGUAGE_C
    139  1.1  jonathan /*
    140  1.1  jonathan  * Register set accessible via /proc/$pid/reg
    141  1.1  jonathan  */
    142  1.1  jonathan struct reg {
    143  1.1  jonathan         int     r_regs[71];	/* numbered as above */
    144  1.1  jonathan };
    145  1.1  jonathan #endif /* LANGUAGE_C */
    146