corebits.h 8.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185
  1. /*
  2. * xtensa/corebits.h - Xtensa Special Register field positions, masks, values.
  3. *
  4. * (In previous releases, these were defined in specreg.h, a generated file.
  5. * This file is not generated, ie. it is processor configuration independent.)
  6. */
  7. /* $Id: //depot/rel/Eaglenest/Xtensa/OS/include/xtensa/corebits.h#2 $ */
  8. /*
  9. * Copyright (c) 2005-2011 Tensilica Inc.
  10. *
  11. * Permission is hereby granted, free of charge, to any person obtaining
  12. * a copy of this software and associated documentation files (the
  13. * "Software"), to deal in the Software without restriction, including
  14. * without limitation the rights to use, copy, modify, merge, publish,
  15. * distribute, sublicense, and/or sell copies of the Software, and to
  16. * permit persons to whom the Software is furnished to do so, subject to
  17. * the following conditions:
  18. *
  19. * The above copyright notice and this permission notice shall be included
  20. * in all copies or substantial portions of the Software.
  21. *
  22. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
  23. * EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
  24. * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
  25. * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
  26. * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
  27. * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
  28. * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  29. */
  30. #ifndef XTENSA_COREBITS_H
  31. #define XTENSA_COREBITS_H
  32. /* EXCCAUSE register fields: */
  33. #define EXCCAUSE_EXCCAUSE_SHIFT 0
  34. #define EXCCAUSE_EXCCAUSE_MASK 0x3F
  35. /* EXCCAUSE register values: */
  36. /*
  37. * General Exception Causes
  38. * (values of EXCCAUSE special register set by general exceptions,
  39. * which vector to the user, kernel, or double-exception vectors).
  40. */
  41. #define EXCCAUSE_ILLEGAL 0 /* Illegal Instruction */
  42. #define EXCCAUSE_SYSCALL 1 /* System Call (SYSCALL instruction) */
  43. #define EXCCAUSE_INSTR_ERROR 2 /* Instruction Fetch Error */
  44. # define EXCCAUSE_IFETCHERROR 2 /* (backward compatibility macro, deprecated, avoid) */
  45. #define EXCCAUSE_LOAD_STORE_ERROR 3 /* Load Store Error */
  46. # define EXCCAUSE_LOADSTOREERROR 3 /* (backward compatibility macro, deprecated, avoid) */
  47. #define EXCCAUSE_LEVEL1_INTERRUPT 4 /* Level 1 Interrupt */
  48. # define EXCCAUSE_LEVEL1INTERRUPT 4 /* (backward compatibility macro, deprecated, avoid) */
  49. #define EXCCAUSE_ALLOCA 5 /* Stack Extension Assist (MOVSP instruction) for alloca */
  50. #define EXCCAUSE_DIVIDE_BY_ZERO 6 /* Integer Divide by Zero */
  51. #define EXCCAUSE_SPECULATION 7 /* Use of Failed Speculative Access (not implemented) */
  52. #define EXCCAUSE_PRIVILEGED 8 /* Privileged Instruction */
  53. #define EXCCAUSE_UNALIGNED 9 /* Unaligned Load or Store */
  54. /* Reserved 10..11 */
  55. #define EXCCAUSE_INSTR_DATA_ERROR 12 /* PIF Data Error on Instruction Fetch (RB-200x and later) */
  56. #define EXCCAUSE_LOAD_STORE_DATA_ERROR 13 /* PIF Data Error on Load or Store (RB-200x and later) */
  57. #define EXCCAUSE_INSTR_ADDR_ERROR 14 /* PIF Address Error on Instruction Fetch (RB-200x and later) */
  58. #define EXCCAUSE_LOAD_STORE_ADDR_ERROR 15 /* PIF Address Error on Load or Store (RB-200x and later) */
  59. #define EXCCAUSE_ITLB_MISS 16 /* ITLB Miss (no ITLB entry matches, hw refill also missed) */
  60. #define EXCCAUSE_ITLB_MULTIHIT 17 /* ITLB Multihit (multiple ITLB entries match) */
  61. #define EXCCAUSE_INSTR_RING 18 /* Ring Privilege Violation on Instruction Fetch */
  62. /* Reserved 19 */ /* Size Restriction on IFetch (not implemented) */
  63. #define EXCCAUSE_INSTR_PROHIBITED 20 /* Cache Attribute does not allow Instruction Fetch */
  64. /* Reserved 21..23 */
  65. #define EXCCAUSE_DTLB_MISS 24 /* DTLB Miss (no DTLB entry matches, hw refill also missed) */
  66. #define EXCCAUSE_DTLB_MULTIHIT 25 /* DTLB Multihit (multiple DTLB entries match) */
  67. #define EXCCAUSE_LOAD_STORE_RING 26 /* Ring Privilege Violation on Load or Store */
  68. /* Reserved 27 */ /* Size Restriction on Load/Store (not implemented) */
  69. #define EXCCAUSE_LOAD_PROHIBITED 28 /* Cache Attribute does not allow Load */
  70. #define EXCCAUSE_STORE_PROHIBITED 29 /* Cache Attribute does not allow Store */
  71. /* Reserved 30..31 */
  72. #define EXCCAUSE_CP_DISABLED(n) (32+(n)) /* Access to Coprocessor 'n' when disabled */
  73. #define EXCCAUSE_CP0_DISABLED 32 /* Access to Coprocessor 0 when disabled */
  74. #define EXCCAUSE_CP1_DISABLED 33 /* Access to Coprocessor 1 when disabled */
  75. #define EXCCAUSE_CP2_DISABLED 34 /* Access to Coprocessor 2 when disabled */
  76. #define EXCCAUSE_CP3_DISABLED 35 /* Access to Coprocessor 3 when disabled */
  77. #define EXCCAUSE_CP4_DISABLED 36 /* Access to Coprocessor 4 when disabled */
  78. #define EXCCAUSE_CP5_DISABLED 37 /* Access to Coprocessor 5 when disabled */
  79. #define EXCCAUSE_CP6_DISABLED 38 /* Access to Coprocessor 6 when disabled */
  80. #define EXCCAUSE_CP7_DISABLED 39 /* Access to Coprocessor 7 when disabled */
  81. /* Reserved 40..63 */
  82. /* PS register fields: */
  83. #define PS_WOE_SHIFT 18
  84. #define PS_WOE_MASK 0x00040000
  85. #define PS_WOE PS_WOE_MASK
  86. #define PS_CALLINC_SHIFT 16
  87. #define PS_CALLINC_MASK 0x00030000
  88. #define PS_CALLINC(n) (((n)&3)<<PS_CALLINC_SHIFT) /* n = 0..3 */
  89. #define PS_OWB_SHIFT 8
  90. #define PS_OWB_MASK 0x00000F00
  91. #define PS_OWB(n) (((n)&15)<<PS_OWB_SHIFT) /* n = 0..15 (or 0..7) */
  92. #define PS_RING_SHIFT 6
  93. #define PS_RING_MASK 0x000000C0
  94. #define PS_RING(n) (((n)&3)<<PS_RING_SHIFT) /* n = 0..3 */
  95. #define PS_UM_SHIFT 5
  96. #define PS_UM_MASK 0x00000020
  97. #define PS_UM PS_UM_MASK
  98. #define PS_EXCM_SHIFT 4
  99. #define PS_EXCM_MASK 0x00000010
  100. #define PS_EXCM PS_EXCM_MASK
  101. #define PS_INTLEVEL_SHIFT 0
  102. #define PS_INTLEVEL_MASK 0x0000000F
  103. #define PS_INTLEVEL(n) ((n)&PS_INTLEVEL_MASK) /* n = 0..15 */
  104. /* Backward compatibility (deprecated): */
  105. #define PS_PROGSTACK_SHIFT PS_UM_SHIFT
  106. #define PS_PROGSTACK_MASK PS_UM_MASK
  107. #define PS_PROG_SHIFT PS_UM_SHIFT
  108. #define PS_PROG_MASK PS_UM_MASK
  109. #define PS_PROG PS_UM
  110. /* DBREAKCn register fields: */
  111. #define DBREAKC_MASK_SHIFT 0
  112. #define DBREAKC_MASK_MASK 0x0000003F
  113. #define DBREAKC_LOADBREAK_SHIFT 30
  114. #define DBREAKC_LOADBREAK_MASK 0x40000000
  115. #define DBREAKC_STOREBREAK_SHIFT 31
  116. #define DBREAKC_STOREBREAK_MASK 0x80000000
  117. /* DEBUGCAUSE register fields: */
  118. #define DEBUGCAUSE_DEBUGINT_SHIFT 5
  119. #define DEBUGCAUSE_DEBUGINT_MASK 0x20 /* debug interrupt */
  120. #define DEBUGCAUSE_BREAKN_SHIFT 4
  121. #define DEBUGCAUSE_BREAKN_MASK 0x10 /* BREAK.N instruction */
  122. #define DEBUGCAUSE_BREAK_SHIFT 3
  123. #define DEBUGCAUSE_BREAK_MASK 0x08 /* BREAK instruction */
  124. #define DEBUGCAUSE_DBREAK_SHIFT 2
  125. #define DEBUGCAUSE_DBREAK_MASK 0x04 /* DBREAK match */
  126. #define DEBUGCAUSE_IBREAK_SHIFT 1
  127. #define DEBUGCAUSE_IBREAK_MASK 0x02 /* IBREAK match */
  128. #define DEBUGCAUSE_ICOUNT_SHIFT 0
  129. #define DEBUGCAUSE_ICOUNT_MASK 0x01 /* ICOUNT would increment to zero */
  130. /* MESR register fields: */
  131. #define MESR_MEME 0x00000001 /* memory error */
  132. #define MESR_MEME_SHIFT 0
  133. #define MESR_DME 0x00000002 /* double memory error */
  134. #define MESR_DME_SHIFT 1
  135. #define MESR_RCE 0x00000010 /* recorded memory error */
  136. #define MESR_RCE_SHIFT 4
  137. #define MESR_LCE
  138. #define MESR_LCE_SHIFT ?
  139. #define MESR_LCE_L
  140. #define MESR_ERRENAB 0x00000100
  141. #define MESR_ERRENAB_SHIFT 8
  142. #define MESR_ERRTEST 0x00000200
  143. #define MESR_ERRTEST_SHIFT 9
  144. #define MESR_DATEXC 0x00000400
  145. #define MESR_DATEXC_SHIFT 10
  146. #define MESR_INSEXC 0x00000800
  147. #define MESR_INSEXC_SHIFT 11
  148. #define MESR_WAYNUM_SHIFT 16
  149. #define MESR_ACCTYPE_SHIFT 20
  150. #define MESR_MEMTYPE_SHIFT 24
  151. #define MESR_ERRTYPE_SHIFT 30
  152. /* MEMCTL register fields: */
  153. #define MEMCTL_SNOOP_EN_SHIFT 1
  154. #define MEMCTL_SNOOP_EN 0x02 /* enable snoop responses (default 0) */
  155. #define MEMCTL_L0IBUF_EN_SHIFT 0
  156. #define MEMCTL_L0IBUF_EN 0x01 /* enable loop instr. buffer (default 1) */
  157. #define MEMCTL_INV_EN_SHIFT 23
  158. #define MEMCTL_INV_EN 0x00800000 /* invalidate cache ways being increased */
  159. #define MEMCTL_DCWU_SHIFT 8
  160. #define MEMCTL_DCWU_BITS 5
  161. #define MEMCTL_DCWA_SHIFT 13
  162. #define MEMCTL_DCWA_BITS 5
  163. #define MEMCTL_ICWU_SHIFT 18
  164. #define MEMCTL_ICWU_BITS 5
  165. #define MEMCTL_DCWU_MASK 0x00001F00 /* Bits 8-12 dcache ways in use */
  166. #define MEMCTL_DCWA_MASK 0x0003E000 /* Bits 13-17 dcache ways allocatable */
  167. #define MEMCTL_ICWU_MASK 0x007C0000 /* Bits 18-22 icache ways in use */
  168. #define MEMCTL_DCWU_CLR_MASK ~(MEMCTL_DCWU_MASK)
  169. #define MEMCTL_DCWA_CLR_MASK ~(MEMCTL_DCWA_MASK)
  170. #define MEMCTL_ICWU_CLR_MASK ~(MEMCTL_ICWU_MASK)
  171. #define MEMCTL_DCW_CLR_MASK (MEMCTL_DCWU_CLR_MASK | MEMCTL_DCWA_CLR_MASK)
  172. #define MEMCTL_IDCW_CLR_MASK (MEMCTL_DCW_CLR_MASK | MEMCTL_ICWU_CLR_MASK)
  173. #endif /*XTENSA_COREBITS_H*/