move sboot to the root directory
[open-ath9k-htc-firmware.git] / sboot / include / xtensa-elf / xtensa / corebits.h
diff --git a/sboot/include/xtensa-elf/xtensa/corebits.h b/sboot/include/xtensa-elf/xtensa/corebits.h
new file mode 100644 (file)
index 0000000..9fbb994
--- /dev/null
@@ -0,0 +1,149 @@
+/*
+ * xtensa/corebits.h - Xtensa Special Register field positions, masks, values.
+ *
+ * (In previous releases, these were defined in specreg.h, a generated file.
+ *  This file is not generated, ie. it is processor configuration independent.)
+ */
+
+/* $Id: //depot/rel/BadgerPass/Xtensa/OS/include/xtensa/corebits.h#3 $ */
+
+/*
+ * Copyright (c) 2005-2007 by Tensilica Inc.  ALL RIGHTS RESERVED.
+ * These coded instructions, statements, and computer programs are the
+ * copyrighted works and confidential proprietary information of Tensilica Inc.
+ * They may not be modified, copied, reproduced, distributed, or disclosed to
+ * third parties in any manner, medium, or form, in whole or in part, without
+ * the prior written consent of Tensilica Inc.
+ */
+
+#ifndef XTENSA_COREBITS_H
+#define XTENSA_COREBITS_H
+
+/*  EXCCAUSE register fields:  */
+#define EXCCAUSE_EXCCAUSE_SHIFT        0
+#define EXCCAUSE_EXCCAUSE_MASK 0x3F
+/*  EXCCAUSE register values:  */
+/*
+ *  General Exception Causes
+ *  (values of EXCCAUSE special register set by general exceptions,
+ *   which vector to the user, kernel, or double-exception vectors).
+ */
+#define EXCCAUSE_ILLEGAL               0       /* Illegal Instruction */
+#define EXCCAUSE_SYSCALL               1       /* System Call (SYSCALL instruction) */
+#define EXCCAUSE_INSTR_ERROR           2       /* Instruction Fetch Error */
+# define EXCCAUSE_IFETCHERROR          2       /* (backward compatibility macro, deprecated, avoid) */
+#define EXCCAUSE_LOAD_STORE_ERROR      3       /* Load Store Error */
+# define EXCCAUSE_LOADSTOREERROR       3       /* (backward compatibility macro, deprecated, avoid) */
+#define EXCCAUSE_LEVEL1_INTERRUPT      4       /* Level 1 Interrupt */
+# define EXCCAUSE_LEVEL1INTERRUPT      4       /* (backward compatibility macro, deprecated, avoid) */
+#define EXCCAUSE_ALLOCA                        5       /* Stack Extension Assist (MOVSP instruction) for alloca */
+#define EXCCAUSE_DIVIDE_BY_ZERO                6       /* Integer Divide by Zero */
+#define EXCCAUSE_SPECULATION           7       /* Use of Failed Speculative Access (not implemented) */
+#define EXCCAUSE_PRIVILEGED            8       /* Privileged Instruction */
+#define EXCCAUSE_UNALIGNED             9       /* Unaligned Load or Store */
+/* Reserved                            10..11 */
+#define EXCCAUSE_INSTR_DATA_ERROR      12      /* PIF Data Error on Instruction Fetch (RB-200x and later) */
+#define EXCCAUSE_LOAD_STORE_DATA_ERROR 13      /* PIF Data Error on Load or Store (RB-200x and later) */
+#define EXCCAUSE_INSTR_ADDR_ERROR      14      /* PIF Address Error on Instruction Fetch (RB-200x and later) */
+#define EXCCAUSE_LOAD_STORE_ADDR_ERROR 15      /* PIF Address Error on Load or Store (RB-200x and later) */
+#define EXCCAUSE_ITLB_MISS             16      /* ITLB Miss (no ITLB entry matches, hw refill also missed) */
+#define EXCCAUSE_ITLB_MULTIHIT         17      /* ITLB Multihit (multiple ITLB entries match) */
+#define EXCCAUSE_INSTR_RING            18      /* Ring Privilege Violation on Instruction Fetch */
+/* Reserved                            19 */   /* Size Restriction on IFetch (not implemented) */
+#define EXCCAUSE_INSTR_PROHIBITED      20      /* Cache Attribute does not allow Instruction Fetch */
+/* Reserved                            21..23 */
+#define EXCCAUSE_DTLB_MISS             24      /* DTLB Miss (no DTLB entry matches, hw refill also missed) */
+#define EXCCAUSE_DTLB_MULTIHIT         25      /* DTLB Multihit (multiple DTLB entries match) */
+#define EXCCAUSE_LOAD_STORE_RING       26      /* Ring Privilege Violation on Load or Store */
+/* Reserved                            27 */   /* Size Restriction on Load/Store (not implemented) */
+#define EXCCAUSE_LOAD_PROHIBITED       28      /* Cache Attribute does not allow Load */
+#define EXCCAUSE_STORE_PROHIBITED      29      /* Cache Attribute does not allow Store */
+/* Reserved                            30..31 */
+#define EXCCAUSE_CP_DISABLED(n)                (32+(n))        /* Access to Coprocessor 'n' when disabled */
+#define EXCCAUSE_CP0_DISABLED          32      /* Access to Coprocessor 0 when disabled */
+#define EXCCAUSE_CP1_DISABLED          33      /* Access to Coprocessor 1 when disabled */
+#define EXCCAUSE_CP2_DISABLED          34      /* Access to Coprocessor 2 when disabled */
+#define EXCCAUSE_CP3_DISABLED          35      /* Access to Coprocessor 3 when disabled */
+#define EXCCAUSE_CP4_DISABLED          36      /* Access to Coprocessor 4 when disabled */
+#define EXCCAUSE_CP5_DISABLED          37      /* Access to Coprocessor 5 when disabled */
+#define EXCCAUSE_CP6_DISABLED          38      /* Access to Coprocessor 6 when disabled */
+#define EXCCAUSE_CP7_DISABLED          39      /* Access to Coprocessor 7 when disabled */
+/*#define EXCCAUSE_FLOATING_POINT      40*/    /* Floating Point Exception (not implemented) */
+/* Reserved                            40..63 */
+
+/*  PS register fields:  */
+#define PS_WOE_SHIFT           18
+#define PS_WOE_MASK            0x00040000
+#define PS_WOE                 PS_WOE_MASK
+#define PS_CALLINC_SHIFT       16
+#define PS_CALLINC_MASK                0x00030000
+#define PS_CALLINC(n)          (((n)&3)<<PS_CALLINC_SHIFT)     /* n = 0..3 */
+#define PS_OWB_SHIFT           8
+#define PS_OWB_MASK            0x00000F00
+#define PS_OWB(n)              (((n)&15)<<PS_OWB_SHIFT)        /* n = 0..15 (or 0..7) */
+#define PS_RING_SHIFT          6
+#define PS_RING_MASK           0x000000C0
+#define PS_RING(n)             (((n)&3)<<PS_RING_SHIFT)        /* n = 0..3 */
+#define PS_UM_SHIFT            5
+#define PS_UM_MASK             0x00000020
+#define PS_UM                  PS_UM_MASK
+#define PS_EXCM_SHIFT          4
+#define PS_EXCM_MASK           0x00000010
+#define PS_EXCM                        PS_EXCM_MASK
+#define PS_INTLEVEL_SHIFT      0
+#define PS_INTLEVEL_MASK       0x0000000F
+#define PS_INTLEVEL(n)         ((n)&PS_INTLEVEL_MASK)          /* n = 0..15 */
+/*  Backward compatibility (deprecated):  */
+#define PS_PROGSTACK_SHIFT     PS_UM_SHIFT
+#define PS_PROGSTACK_MASK      PS_UM_MASK
+#define PS_PROG_SHIFT          PS_UM_SHIFT
+#define PS_PROG_MASK           PS_UM_MASK
+#define PS_PROG                        PS_UM
+
+/*  DBREAKCn register fields:  */
+#define DBREAKC_MASK_SHIFT             0
+#define DBREAKC_MASK_MASK              0x0000003F
+#define DBREAKC_LOADBREAK_SHIFT                30
+#define DBREAKC_LOADBREAK_MASK         0x40000000
+#define DBREAKC_STOREBREAK_SHIFT       31
+#define DBREAKC_STOREBREAK_MASK                0x80000000
+
+/*  DEBUGCAUSE register fields:  */
+#define DEBUGCAUSE_DEBUGINT_SHIFT      5
+#define DEBUGCAUSE_DEBUGINT_MASK       0x20    /* debug interrupt */
+#define DEBUGCAUSE_BREAKN_SHIFT                4
+#define DEBUGCAUSE_BREAKN_MASK         0x10    /* BREAK.N instruction */
+#define DEBUGCAUSE_BREAK_SHIFT         3
+#define DEBUGCAUSE_BREAK_MASK          0x08    /* BREAK instruction */
+#define DEBUGCAUSE_DBREAK_SHIFT                2
+#define DEBUGCAUSE_DBREAK_MASK         0x04    /* DBREAK match */
+#define DEBUGCAUSE_IBREAK_SHIFT                1
+#define DEBUGCAUSE_IBREAK_MASK         0x02    /* IBREAK match */
+#define DEBUGCAUSE_ICOUNT_SHIFT                0
+#define DEBUGCAUSE_ICOUNT_MASK         0x01    /* ICOUNT would increment to zero */
+
+/*  MESR register fields:  */
+#define MESR_MEME              0x00000001      /* memory error */
+#define MESR_MEME_SHIFT                0
+#define MESR_DME               0x00000002      /* double memory error */
+#define MESR_DME_SHIFT         1
+#define MESR_RCE               0x00000010      /* recorded memory error */
+#define MESR_RCE_SHIFT         4
+#define MESR_LCE
+#define MESR_LCE_SHIFT         ?
+#define MESR_LCE_L
+#define MESR_ERRENAB           0x00000100
+#define MESR_ERRENAB_SHIFT     8
+#define MESR_ERRTEST           0x00000200
+#define MESR_ERRTEST_SHIFT     9
+#define MESR_DATEXC            0x00000400
+#define MESR_DATEXC_SHIFT      10
+#define MESR_INSEXC            0x00000800
+#define MESR_INSEXC_SHIFT      11
+#define MESR_WAYNUM_SHIFT      16
+#define MESR_ACCTYPE_SHIFT     20
+#define MESR_MEMTYPE_SHIFT     24
+#define MESR_ERRTYPE_SHIFT     30
+
+
+#endif /*XTENSA_COREBITS_H*/