sysreg.h 13 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332
  1. /*
  2. * AVR32 System Registers
  3. *
  4. * Copyright (C) 2004-2006 Atmel Corporation
  5. *
  6. * This program is free software; you can redistribute it and/or modify
  7. * it under the terms of the GNU General Public License version 2 as
  8. * published by the Free Software Foundation.
  9. */
  10. #ifndef __ASM_AVR32_SYSREG_H__
  11. #define __ASM_AVR32_SYSREG_H__
  12. /* sysreg register offsets */
  13. #define SYSREG_SR 0x0000
  14. #define SYSREG_EVBA 0x0004
  15. #define SYSREG_ACBA 0x0008
  16. #define SYSREG_CPUCR 0x000c
  17. #define SYSREG_ECR 0x0010
  18. #define SYSREG_RSR_SUP 0x0014
  19. #define SYSREG_RSR_INT0 0x0018
  20. #define SYSREG_RSR_INT1 0x001c
  21. #define SYSREG_RSR_INT2 0x0020
  22. #define SYSREG_RSR_INT3 0x0024
  23. #define SYSREG_RSR_EX 0x0028
  24. #define SYSREG_RSR_NMI 0x002c
  25. #define SYSREG_RSR_DBG 0x0030
  26. #define SYSREG_RAR_SUP 0x0034
  27. #define SYSREG_RAR_INT0 0x0038
  28. #define SYSREG_RAR_INT1 0x003c
  29. #define SYSREG_RAR_INT2 0x0040
  30. #define SYSREG_RAR_INT3 0x0044
  31. #define SYSREG_RAR_EX 0x0048
  32. #define SYSREG_RAR_NMI 0x004c
  33. #define SYSREG_RAR_DBG 0x0050
  34. #define SYSREG_JECR 0x0054
  35. #define SYSREG_JOSP 0x0058
  36. #define SYSREG_JAVA_LV0 0x005c
  37. #define SYSREG_JAVA_LV1 0x0060
  38. #define SYSREG_JAVA_LV2 0x0064
  39. #define SYSREG_JAVA_LV3 0x0068
  40. #define SYSREG_JAVA_LV4 0x006c
  41. #define SYSREG_JAVA_LV5 0x0070
  42. #define SYSREG_JAVA_LV6 0x0074
  43. #define SYSREG_JAVA_LV7 0x0078
  44. #define SYSREG_JTBA 0x007c
  45. #define SYSREG_JBCR 0x0080
  46. #define SYSREG_CONFIG0 0x0100
  47. #define SYSREG_CONFIG1 0x0104
  48. #define SYSREG_COUNT 0x0108
  49. #define SYSREG_COMPARE 0x010c
  50. #define SYSREG_TLBEHI 0x0110
  51. #define SYSREG_TLBELO 0x0114
  52. #define SYSREG_PTBR 0x0118
  53. #define SYSREG_TLBEAR 0x011c
  54. #define SYSREG_MMUCR 0x0120
  55. #define SYSREG_TLBARLO 0x0124
  56. #define SYSREG_TLBARHI 0x0128
  57. #define SYSREG_PCCNT 0x012c
  58. #define SYSREG_PCNT0 0x0130
  59. #define SYSREG_PCNT1 0x0134
  60. #define SYSREG_PCCR 0x0138
  61. #define SYSREG_BEAR 0x013c
  62. /* Bitfields in SR */
  63. #define SYSREG_SR_C_OFFSET 0
  64. #define SYSREG_SR_C_SIZE 1
  65. #define SYSREG_Z_OFFSET 1
  66. #define SYSREG_Z_SIZE 1
  67. #define SYSREG_SR_N_OFFSET 2
  68. #define SYSREG_SR_N_SIZE 1
  69. #define SYSREG_SR_V_OFFSET 3
  70. #define SYSREG_SR_V_SIZE 1
  71. #define SYSREG_Q_OFFSET 4
  72. #define SYSREG_Q_SIZE 1
  73. #define SYSREG_GM_OFFSET 16
  74. #define SYSREG_GM_SIZE 1
  75. #define SYSREG_I0M_OFFSET 17
  76. #define SYSREG_I0M_SIZE 1
  77. #define SYSREG_I1M_OFFSET 18
  78. #define SYSREG_I1M_SIZE 1
  79. #define SYSREG_I2M_OFFSET 19
  80. #define SYSREG_I2M_SIZE 1
  81. #define SYSREG_I3M_OFFSET 20
  82. #define SYSREG_I3M_SIZE 1
  83. #define SYSREG_EM_OFFSET 21
  84. #define SYSREG_EM_SIZE 1
  85. #define SYSREG_M0_OFFSET 22
  86. #define SYSREG_M0_SIZE 1
  87. #define SYSREG_M1_OFFSET 23
  88. #define SYSREG_M1_SIZE 1
  89. #define SYSREG_M2_OFFSET 24
  90. #define SYSREG_M2_SIZE 1
  91. #define SYSREG_SR_D_OFFSET 26
  92. #define SYSREG_SR_D_SIZE 1
  93. #define SYSREG_DM_OFFSET 27
  94. #define SYSREG_DM_SIZE 1
  95. #define SYSREG_SR_J_OFFSET 28
  96. #define SYSREG_SR_J_SIZE 1
  97. #define SYSREG_R_OFFSET 29
  98. #define SYSREG_R_SIZE 1
  99. #define SYSREG_H_OFFSET 30
  100. #define SYSREG_H_SIZE 1
  101. /* Bitfields in EVBA */
  102. /* Bitfields in ACBA */
  103. /* Bitfields in CPUCR */
  104. #define SYSREG_BI_OFFSET 0
  105. #define SYSREG_BI_SIZE 1
  106. #define SYSREG_BE_OFFSET 1
  107. #define SYSREG_BE_SIZE 1
  108. #define SYSREG_FE_OFFSET 2
  109. #define SYSREG_FE_SIZE 1
  110. #define SYSREG_RE_OFFSET 3
  111. #define SYSREG_RE_SIZE 1
  112. #define SYSREG_IBE_OFFSET 4
  113. #define SYSREG_IBE_SIZE 1
  114. #define SYSREG_IEE_OFFSET 5
  115. #define SYSREG_IEE_SIZE 1
  116. /* Bitfields in ECR */
  117. #define SYSREG_ECR_OFFSET 0
  118. #define SYSREG_ECR_SIZE 32
  119. /* Bitfields in RSR_SUP */
  120. /* Bitfields in RSR_INT0 */
  121. /* Bitfields in RSR_INT1 */
  122. /* Bitfields in RSR_INT2 */
  123. /* Bitfields in RSR_INT3 */
  124. /* Bitfields in RSR_EX */
  125. /* Bitfields in RSR_NMI */
  126. /* Bitfields in RSR_DBG */
  127. /* Bitfields in RAR_SUP */
  128. /* Bitfields in RAR_INT0 */
  129. /* Bitfields in RAR_INT1 */
  130. /* Bitfields in RAR_INT2 */
  131. /* Bitfields in RAR_INT3 */
  132. /* Bitfields in RAR_EX */
  133. /* Bitfields in RAR_NMI */
  134. /* Bitfields in RAR_DBG */
  135. /* Bitfields in JECR */
  136. /* Bitfields in JOSP */
  137. /* Bitfields in JAVA_LV0 */
  138. /* Bitfields in JAVA_LV1 */
  139. /* Bitfields in JAVA_LV2 */
  140. /* Bitfields in JAVA_LV3 */
  141. /* Bitfields in JAVA_LV4 */
  142. /* Bitfields in JAVA_LV5 */
  143. /* Bitfields in JAVA_LV6 */
  144. /* Bitfields in JAVA_LV7 */
  145. /* Bitfields in JTBA */
  146. /* Bitfields in JBCR */
  147. /* Bitfields in CONFIG0 */
  148. #define SYSREG_CONFIG0_D_OFFSET 1
  149. #define SYSREG_CONFIG0_D_SIZE 1
  150. #define SYSREG_CONFIG0_S_OFFSET 2
  151. #define SYSREG_CONFIG0_S_SIZE 1
  152. #define SYSREG_O_OFFSET 3
  153. #define SYSREG_O_SIZE 1
  154. #define SYSREG_P_OFFSET 4
  155. #define SYSREG_P_SIZE 1
  156. #define SYSREG_CONFIG0_J_OFFSET 5
  157. #define SYSREG_CONFIG0_J_SIZE 1
  158. #define SYSREG_F_OFFSET 6
  159. #define SYSREG_F_SIZE 1
  160. #define SYSREG_MMUT_OFFSET 7
  161. #define SYSREG_MMUT_SIZE 3
  162. #define SYSREG_AR_OFFSET 10
  163. #define SYSREG_AR_SIZE 3
  164. #define SYSREG_AT_OFFSET 13
  165. #define SYSREG_AT_SIZE 3
  166. #define SYSREG_PROCESSORREVISION_OFFSET 16
  167. #define SYSREG_PROCESSORREVISION_SIZE 8
  168. #define SYSREG_PROCESSORID_OFFSET 24
  169. #define SYSREG_PROCESSORID_SIZE 8
  170. /* Bitfields in CONFIG1 */
  171. #define SYSREG_DASS_OFFSET 0
  172. #define SYSREG_DASS_SIZE 3
  173. #define SYSREG_DLSZ_OFFSET 3
  174. #define SYSREG_DLSZ_SIZE 3
  175. #define SYSREG_DSET_OFFSET 6
  176. #define SYSREG_DSET_SIZE 4
  177. #define SYSREG_IASS_OFFSET 10
  178. #define SYSREG_IASS_SIZE 2
  179. #define SYSREG_ILSZ_OFFSET 13
  180. #define SYSREG_ILSZ_SIZE 3
  181. #define SYSREG_ISET_OFFSET 16
  182. #define SYSREG_ISET_SIZE 4
  183. #define SYSREG_DMMUSZ_OFFSET 20
  184. #define SYSREG_DMMUSZ_SIZE 6
  185. #define SYSREG_IMMUSZ_OFFSET 26
  186. #define SYSREG_IMMUSZ_SIZE 6
  187. /* Bitfields in COUNT */
  188. /* Bitfields in COMPARE */
  189. /* Bitfields in TLBEHI */
  190. #define SYSREG_ASID_OFFSET 0
  191. #define SYSREG_ASID_SIZE 8
  192. #define SYSREG_TLBEHI_I_OFFSET 8
  193. #define SYSREG_TLBEHI_I_SIZE 1
  194. #define SYSREG_TLBEHI_V_OFFSET 9
  195. #define SYSREG_TLBEHI_V_SIZE 1
  196. #define SYSREG_VPN_OFFSET 10
  197. #define SYSREG_VPN_SIZE 22
  198. /* Bitfields in TLBELO */
  199. #define SYSREG_W_OFFSET 0
  200. #define SYSREG_W_SIZE 1
  201. #define SYSREG_TLBELO_D_OFFSET 1
  202. #define SYSREG_TLBELO_D_SIZE 1
  203. #define SYSREG_SZ_OFFSET 2
  204. #define SYSREG_SZ_SIZE 2
  205. #define SYSREG_AP_OFFSET 4
  206. #define SYSREG_AP_SIZE 3
  207. #define SYSREG_B_OFFSET 7
  208. #define SYSREG_B_SIZE 1
  209. #define SYSREG_G_OFFSET 8
  210. #define SYSREG_G_SIZE 1
  211. #define SYSREG_TLBELO_C_OFFSET 9
  212. #define SYSREG_TLBELO_C_SIZE 1
  213. #define SYSREG_PFN_OFFSET 10
  214. #define SYSREG_PFN_SIZE 22
  215. /* Bitfields in PTBR */
  216. /* Bitfields in TLBEAR */
  217. /* Bitfields in MMUCR */
  218. #define SYSREG_E_OFFSET 0
  219. #define SYSREG_E_SIZE 1
  220. #define SYSREG_M_OFFSET 1
  221. #define SYSREG_M_SIZE 1
  222. #define SYSREG_MMUCR_I_OFFSET 2
  223. #define SYSREG_MMUCR_I_SIZE 1
  224. #define SYSREG_MMUCR_N_OFFSET 3
  225. #define SYSREG_MMUCR_N_SIZE 1
  226. #define SYSREG_MMUCR_S_OFFSET 4
  227. #define SYSREG_MMUCR_S_SIZE 1
  228. #define SYSREG_DLA_OFFSET 8
  229. #define SYSREG_DLA_SIZE 6
  230. #define SYSREG_DRP_OFFSET 14
  231. #define SYSREG_DRP_SIZE 6
  232. #define SYSREG_ILA_OFFSET 20
  233. #define SYSREG_ILA_SIZE 6
  234. #define SYSREG_IRP_OFFSET 26
  235. #define SYSREG_IRP_SIZE 6
  236. /* Bitfields in TLBARLO */
  237. /* Bitfields in TLBARHI */
  238. /* Bitfields in PCCNT */
  239. /* Bitfields in PCNT0 */
  240. /* Bitfields in PCNT1 */
  241. /* Bitfields in PCCR */
  242. /* Bitfields in BEAR */
  243. /* Constants for ECR */
  244. #define ECR_UNRECOVERABLE 0
  245. #define ECR_TLB_MULTIPLE 1
  246. #define ECR_BUS_ERROR_WRITE 2
  247. #define ECR_BUS_ERROR_READ 3
  248. #define ECR_NMI 4
  249. #define ECR_ADDR_ALIGN_X 5
  250. #define ECR_PROTECTION_X 6
  251. #define ECR_DEBUG 7
  252. #define ECR_ILLEGAL_OPCODE 8
  253. #define ECR_UNIMPL_INSTRUCTION 9
  254. #define ECR_PRIVILEGE_VIOLATION 10
  255. #define ECR_FPE 11
  256. #define ECR_COPROC_ABSENT 12
  257. #define ECR_ADDR_ALIGN_R 13
  258. #define ECR_ADDR_ALIGN_W 14
  259. #define ECR_PROTECTION_R 15
  260. #define ECR_PROTECTION_W 16
  261. #define ECR_DTLB_MODIFIED 17
  262. #define ECR_TLB_MISS_X 20
  263. #define ECR_TLB_MISS_R 24
  264. #define ECR_TLB_MISS_W 28
  265. /* Bit manipulation macros */
  266. #define SYSREG_BIT(name) (1 << SYSREG_##name##_OFFSET)
  267. #define SYSREG_BF(name,value) (((value) & ((1 << SYSREG_##name##_SIZE) - 1)) << SYSREG_##name##_OFFSET)
  268. #define SYSREG_BFEXT(name,value) (((value) >> SYSREG_##name##_OFFSET) & ((1 << SYSREG_##name##_SIZE) - 1))
  269. #define SYSREG_BFINS(name,value,old) (((old) & ~(((1 << SYSREG_##name##_SIZE) - 1) << SYSREG_##name##_OFFSET)) | SYSREG_BF(name,value))
  270. #ifdef __CHECKER__
  271. extern unsigned long __builtin_mfsr(unsigned long reg);
  272. extern void __builtin_mtsr(unsigned long reg, unsigned long value);
  273. #endif
  274. /* Register access macros */
  275. #define sysreg_read(reg) __builtin_mfsr(SYSREG_##reg)
  276. #define sysreg_write(reg, value) __builtin_mtsr(SYSREG_##reg, value)
  277. #endif /* __ASM_AVR32_SYSREG_H__ */