Home | History | Annotate | Line # | Download | only in ia64
      1  1.1  jakllsch /*	$NetBSD: eficontext.h,v 1.1.1.1 2014/04/01 16:16:07 jakllsch Exp $	*/
      2  1.1  jakllsch 
      3  1.1  jakllsch /*
      4  1.1  jakllsch  * Copyright (c) 1999, 2000
      5  1.1  jakllsch  * Intel Corporation.
      6  1.1  jakllsch  * All rights reserved.
      7  1.1  jakllsch  *
      8  1.1  jakllsch  * Redistribution and use in source and binary forms, with or without
      9  1.1  jakllsch  * modification, are permitted provided that the following conditions
     10  1.1  jakllsch  * are met:
     11  1.1  jakllsch  *
     12  1.1  jakllsch  * 1. Redistributions of source code must retain the above copyright
     13  1.1  jakllsch  *    notice, this list of conditions and the following disclaimer.
     14  1.1  jakllsch  *
     15  1.1  jakllsch  * 2. Redistributions in binary form must reproduce the above copyright
     16  1.1  jakllsch  *    notice, this list of conditions and the following disclaimer in the
     17  1.1  jakllsch  *    documentation and/or other materials provided with the distribution.
     18  1.1  jakllsch  *
     19  1.1  jakllsch  * 3. All advertising materials mentioning features or use of this software
     20  1.1  jakllsch  *    must display the following acknowledgement:
     21  1.1  jakllsch  *
     22  1.1  jakllsch  *    This product includes software developed by Intel Corporation and
     23  1.1  jakllsch  *    its contributors.
     24  1.1  jakllsch  *
     25  1.1  jakllsch  * 4. Neither the name of Intel Corporation or its contributors may be
     26  1.1  jakllsch  *    used to endorse or promote products derived from this software
     27  1.1  jakllsch  *    without specific prior written permission.
     28  1.1  jakllsch  *
     29  1.1  jakllsch  * THIS SOFTWARE IS PROVIDED BY INTEL CORPORATION AND CONTRIBUTORS ``AS IS''
     30  1.1  jakllsch  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
     31  1.1  jakllsch  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
     32  1.1  jakllsch  * ARE DISCLAIMED.  IN NO EVENT SHALL INTEL CORPORATION OR CONTRIBUTORS BE
     33  1.1  jakllsch  * LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
     34  1.1  jakllsch  * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
     35  1.1  jakllsch  * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
     36  1.1  jakllsch  * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
     37  1.1  jakllsch  * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
     38  1.1  jakllsch  * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
     39  1.1  jakllsch  * THE POSSIBILITY OF SUCH DAMAGE.
     40  1.1  jakllsch  *
     41  1.1  jakllsch  */
     42  1.1  jakllsch 
     43  1.1  jakllsch 
     44  1.1  jakllsch #ifndef _EFICONTEXT_H_
     45  1.1  jakllsch #define _EFICONTEXT_H_
     46  1.1  jakllsch 
     47  1.1  jakllsch 
     48  1.1  jakllsch //
     49  1.1  jakllsch //  IA-64 processor exception types
     50  1.1  jakllsch //
     51  1.1  jakllsch #define    EXCPT_ALT_DTLB            4
     52  1.1  jakllsch #define    EXCPT_DNESTED_TLB         5
     53  1.1  jakllsch #define    EXCPT_BREAKPOINT         11
     54  1.1  jakllsch #define    EXCPT_EXTERNAL_INTERRUPT	12
     55  1.1  jakllsch #define    EXCPT_GEN_EXCEPT         24
     56  1.1  jakllsch #define    EXCPT_NAT_CONSUMPTION    26
     57  1.1  jakllsch #define    EXCPT_DEBUG_EXCEPT       29
     58  1.1  jakllsch #define    EXCPT_UNALIGNED_ACCESS   30
     59  1.1  jakllsch #define    EXCPT_FP_FAULT           32
     60  1.1  jakllsch #define    EXCPT_FP_TRAP            33
     61  1.1  jakllsch #define    EXCPT_TAKEN_BRANCH       35
     62  1.1  jakllsch #define    EXCPT_SINGLE_STEP        36
     63  1.1  jakllsch 
     64  1.1  jakllsch //
     65  1.1  jakllsch //  IA-64 processor context definition - must be 512 byte aligned!!!
     66  1.1  jakllsch //
     67  1.1  jakllsch typedef
     68  1.1  jakllsch struct {
     69  1.1  jakllsch 	UINT64 reserved;	// necessary to preserve alignment for the correct bits in UNAT and to insure F2 is 16 byte aligned...
     70  1.1  jakllsch 
     71  1.1  jakllsch     UINT64 r1;
     72  1.1  jakllsch     UINT64 r2;
     73  1.1  jakllsch     UINT64 r3;
     74  1.1  jakllsch     UINT64 r4;
     75  1.1  jakllsch     UINT64 r5;
     76  1.1  jakllsch     UINT64 r6;
     77  1.1  jakllsch     UINT64 r7;
     78  1.1  jakllsch     UINT64 r8;
     79  1.1  jakllsch     UINT64 r9;
     80  1.1  jakllsch     UINT64 r10;
     81  1.1  jakllsch     UINT64 r11;
     82  1.1  jakllsch     UINT64 r12;
     83  1.1  jakllsch     UINT64 r13;
     84  1.1  jakllsch     UINT64 r14;
     85  1.1  jakllsch     UINT64 r15;
     86  1.1  jakllsch     UINT64 r16;
     87  1.1  jakllsch     UINT64 r17;
     88  1.1  jakllsch     UINT64 r18;
     89  1.1  jakllsch     UINT64 r19;
     90  1.1  jakllsch     UINT64 r20;
     91  1.1  jakllsch     UINT64 r21;
     92  1.1  jakllsch     UINT64 r22;
     93  1.1  jakllsch     UINT64 r23;
     94  1.1  jakllsch     UINT64 r24;
     95  1.1  jakllsch     UINT64 r25;
     96  1.1  jakllsch     UINT64 r26;
     97  1.1  jakllsch     UINT64 r27;
     98  1.1  jakllsch     UINT64 r28;
     99  1.1  jakllsch     UINT64 r29;
    100  1.1  jakllsch     UINT64 r30;
    101  1.1  jakllsch     UINT64 r31;
    102  1.1  jakllsch 
    103  1.1  jakllsch     UINT64 f2[2];
    104  1.1  jakllsch     UINT64 f3[2];
    105  1.1  jakllsch     UINT64 f4[2];
    106  1.1  jakllsch     UINT64 f5[2];
    107  1.1  jakllsch     UINT64 f6[2];
    108  1.1  jakllsch     UINT64 f7[2];
    109  1.1  jakllsch     UINT64 f8[2];
    110  1.1  jakllsch     UINT64 f9[2];
    111  1.1  jakllsch     UINT64 f10[2];
    112  1.1  jakllsch     UINT64 f11[2];
    113  1.1  jakllsch     UINT64 f12[2];
    114  1.1  jakllsch     UINT64 f13[2];
    115  1.1  jakllsch     UINT64 f14[2];
    116  1.1  jakllsch     UINT64 f15[2];
    117  1.1  jakllsch     UINT64 f16[2];
    118  1.1  jakllsch     UINT64 f17[2];
    119  1.1  jakllsch     UINT64 f18[2];
    120  1.1  jakllsch     UINT64 f19[2];
    121  1.1  jakllsch     UINT64 f20[2];
    122  1.1  jakllsch     UINT64 f21[2];
    123  1.1  jakllsch     UINT64 f22[2];
    124  1.1  jakllsch     UINT64 f23[2];
    125  1.1  jakllsch     UINT64 f24[2];
    126  1.1  jakllsch     UINT64 f25[2];
    127  1.1  jakllsch     UINT64 f26[2];
    128  1.1  jakllsch     UINT64 f27[2];
    129  1.1  jakllsch     UINT64 f28[2];
    130  1.1  jakllsch     UINT64 f29[2];
    131  1.1  jakllsch     UINT64 f30[2];
    132  1.1  jakllsch     UINT64 f31[2];
    133  1.1  jakllsch 
    134  1.1  jakllsch     UINT64 pr;
    135  1.1  jakllsch 
    136  1.1  jakllsch     UINT64 b0;
    137  1.1  jakllsch     UINT64 b1;
    138  1.1  jakllsch     UINT64 b2;
    139  1.1  jakllsch     UINT64 b3;
    140  1.1  jakllsch     UINT64 b4;
    141  1.1  jakllsch     UINT64 b5;
    142  1.1  jakllsch     UINT64 b6;
    143  1.1  jakllsch     UINT64 b7;
    144  1.1  jakllsch 
    145  1.1  jakllsch     // application registers
    146  1.1  jakllsch     UINT64 ar_rsc;
    147  1.1  jakllsch     UINT64 ar_bsp;
    148  1.1  jakllsch     UINT64 ar_bspstore;
    149  1.1  jakllsch     UINT64 ar_rnat;
    150  1.1  jakllsch 
    151  1.1  jakllsch     UINT64 ar_fcr;
    152  1.1  jakllsch 
    153  1.1  jakllsch     UINT64 ar_eflag;
    154  1.1  jakllsch     UINT64 ar_csd;
    155  1.1  jakllsch     UINT64 ar_ssd;
    156  1.1  jakllsch     UINT64 ar_cflg;
    157  1.1  jakllsch     UINT64 ar_fsr;
    158  1.1  jakllsch     UINT64 ar_fir;
    159  1.1  jakllsch     UINT64 ar_fdr;
    160  1.1  jakllsch 
    161  1.1  jakllsch     UINT64 ar_ccv;
    162  1.1  jakllsch 
    163  1.1  jakllsch     UINT64 ar_unat;
    164  1.1  jakllsch 
    165  1.1  jakllsch     UINT64 ar_fpsr;
    166  1.1  jakllsch 
    167  1.1  jakllsch     UINT64 ar_pfs;
    168  1.1  jakllsch     UINT64 ar_lc;
    169  1.1  jakllsch     UINT64 ar_ec;
    170  1.1  jakllsch 
    171  1.1  jakllsch     // control registers
    172  1.1  jakllsch     UINT64 cr_dcr;
    173  1.1  jakllsch     UINT64 cr_itm;
    174  1.1  jakllsch     UINT64 cr_iva;
    175  1.1  jakllsch     UINT64 cr_pta;
    176  1.1  jakllsch     UINT64 cr_ipsr;
    177  1.1  jakllsch     UINT64 cr_isr;
    178  1.1  jakllsch     UINT64 cr_iip;
    179  1.1  jakllsch     UINT64 cr_ifa;
    180  1.1  jakllsch     UINT64 cr_itir;
    181  1.1  jakllsch     UINT64 cr_iipa;
    182  1.1  jakllsch     UINT64 cr_ifs;
    183  1.1  jakllsch     UINT64 cr_iim;
    184  1.1  jakllsch     UINT64 cr_iha;
    185  1.1  jakllsch 
    186  1.1  jakllsch     // debug registers
    187  1.1  jakllsch     UINT64 dbr0;
    188  1.1  jakllsch     UINT64 dbr1;
    189  1.1  jakllsch     UINT64 dbr2;
    190  1.1  jakllsch     UINT64 dbr3;
    191  1.1  jakllsch     UINT64 dbr4;
    192  1.1  jakllsch     UINT64 dbr5;
    193  1.1  jakllsch     UINT64 dbr6;
    194  1.1  jakllsch     UINT64 dbr7;
    195  1.1  jakllsch 
    196  1.1  jakllsch     UINT64 ibr0;
    197  1.1  jakllsch     UINT64 ibr1;
    198  1.1  jakllsch     UINT64 ibr2;
    199  1.1  jakllsch     UINT64 ibr3;
    200  1.1  jakllsch     UINT64 ibr4;
    201  1.1  jakllsch     UINT64 ibr5;
    202  1.1  jakllsch     UINT64 ibr6;
    203  1.1  jakllsch     UINT64 ibr7;
    204  1.1  jakllsch 
    205  1.1  jakllsch     // virtual registers
    206  1.1  jakllsch     UINT64 int_nat;	// nat bits for R1-R31
    207  1.1  jakllsch 
    208  1.1  jakllsch } SYSTEM_CONTEXT;
    209  1.1  jakllsch 
    210  1.1  jakllsch #endif /* _EFI_CONTEXT_H_ */
    211