/arch/arm/nxt/AT91SAM7.h

http://github.com/earl/gforth-mirror · C Header · 945 lines · 745 code · 38 blank · 162 comment · 0 complexity · 61f49e0cffad7ea7723fbe5093cf0c44 MD5 · raw file

Large files are truncated click here to view the full file

  1. // ----------------------------------------------------------------------------
  2. // ATMEL Microcontroller Software Support - ROUSSET -
  3. // ----------------------------------------------------------------------------
  4. // The software is delivered "AS IS" without warranty or condition of any
  5. // kind, either express, implied or statutory. This includes without
  6. // limitation any warranty or condition with respect to merchantability or
  7. // fitness for any particular purpose, or against the infringements of
  8. // intellectual property rights of others.
  9. // ----------------------------------------------------------------------------
  10. // File Name : AT91SAM7S64.h
  11. // Object : AT91SAM7S64 definitions
  12. // Generated : AT91 SW Application Group 09/01/2004 (10:02:06)
  13. //
  14. // CVS Reference : /AT91SAM7S64.pl/1.15/Mon Aug 30 08:48:08 2004//
  15. // CVS Reference : /SYS_SAM7Sxxx.pl/1.5/Mon Aug 30 13:17:50 2004//
  16. // CVS Reference : /MC_SAM02.pl/1.3/Mon Mar 08 09:22:24 2004//
  17. // CVS Reference : /UDP_1765B.pl/1.3/Fri Aug 02 14:45:38 2002//
  18. // CVS Reference : /AIC_1796B.pl/1.1.1.1/Fri Jun 28 09:36:48 2002//
  19. // CVS Reference : /PMC_SAM.pl/1.10/Mon May 10 12:08:48 2004//
  20. // CVS Reference : /PIO_1725D.pl/1.1.1.1/Fri Jun 28 09:36:48 2002//
  21. // CVS Reference : /DBGU_1754A.pl/1.4/Fri Jan 31 12:18:24 2003//
  22. // CVS Reference : /US_1739C.pl/1.2/Fri Jul 12 07:49:26 2002//
  23. // CVS Reference : /SPI2.pl/1.2/Fri Oct 17 08:13:40 2003//
  24. // CVS Reference : /SSC_1762A.pl/1.2/Fri Nov 08 13:26:40 2002//
  25. // CVS Reference : /TC_1753B.pl/1.4/Mon Mar 01 14:10:12 2004//
  26. // CVS Reference : /TWI_1761B.pl/1.4/Fri Feb 07 10:30:08 2003//
  27. // CVS Reference : /PDC_1734B.pl/1.2/Thu Nov 21 16:38:24 2002//
  28. // CVS Reference : /ADC_SAM.pl/1.7/Fri Oct 17 08:12:38 2003//
  29. // CVS Reference : /PWM_SAM.pl/1.5/Wed Apr 14 12:02:52 2004//
  30. // ----------------------------------------------------------------------------
  31. #ifndef AT91SAM7S64_H
  32. # define AT91SAM7S64_H
  33. # define CLOCK_FREQUENCY 48000000
  34. // AIC peripheral ids
  35. # define AT91C_PERIPHERAL_ID_FIQ 0
  36. # define AT91C_PERIPHERAL_ID_SYSIRQ 1
  37. # define AT91C_PERIPHERAL_ID_PIOA 2
  38. # define AT91C_PERIPHERAL_ID_ADC 4
  39. # define AT91C_PERIPHERAL_ID_SPI 5
  40. # define AT91C_PERIPHERAL_ID_US0 6
  41. # define AT91C_PERIPHERAL_ID_US1 7
  42. # define AT91C_PERIPHERAL_ID_SSC 8
  43. # define AT91C_PERIPHERAL_ID_TWI 9
  44. # define AT91C_PERIPHERAL_ID_PWMC 10
  45. # define AT91C_PERIPHERAL_ID_UDP 11
  46. # define AT91C_PERIPHERAL_ID_TC0 12
  47. # define AT91C_PERIPHERAL_ID_TC1 13
  48. # define AT91C_PERIPHERAL_ID_TC2 14
  49. # define AT91C_PERIPHERAL_ID_IRQ0 30
  50. # define AT91C_PERIPHERAL_ID_IRQ1 31
  51. typedef volatile unsigned int AT91_REG; // Hardware register definition
  52. // *****************************************************************************
  53. // SOFTWARE API DEFINITION FOR System Peripherals
  54. // *****************************************************************************
  55. typedef struct _AT91S_SYSC {
  56. AT91_REG SYSC_AIC_SMR[32]; // Source Mode Register
  57. AT91_REG SYSC_AIC_SVR[32]; // Source Vector Register
  58. AT91_REG SYSC_AIC_IVR; // IRQ Vector Register
  59. AT91_REG SYSC_AIC_FVR; // FIQ Vector Register
  60. AT91_REG SYSC_AIC_ISR; // Interrupt Status Register
  61. AT91_REG SYSC_AIC_IPR; // Interrupt Pending Register
  62. AT91_REG SYSC_AIC_IMR; // Interrupt Mask Register
  63. AT91_REG SYSC_AIC_CISR; // Core Interrupt Status Register
  64. AT91_REG Reserved0[2]; //
  65. AT91_REG SYSC_AIC_IECR; // Interrupt Enable Command Register
  66. AT91_REG SYSC_AIC_IDCR; // Interrupt Disable Command Register
  67. AT91_REG SYSC_AIC_ICCR; // Interrupt Clear Command Register
  68. AT91_REG SYSC_AIC_ISCR; // Interrupt Set Command Register
  69. AT91_REG SYSC_AIC_EOICR; // End of Interrupt Command Register
  70. AT91_REG SYSC_AIC_SPU; // Spurious Vector Register
  71. AT91_REG SYSC_AIC_DCR; // Debug Control Register (Protect)
  72. AT91_REG Reserved1[1]; //
  73. AT91_REG SYSC_AIC_FFER; // Fast Forcing Enable Register
  74. AT91_REG SYSC_AIC_FFDR; // Fast Forcing Disable Register
  75. AT91_REG SYSC_AIC_FFSR; // Fast Forcing Status Register
  76. AT91_REG Reserved2[45]; //
  77. AT91_REG SYSC_DBGU_CR; // Control Register
  78. AT91_REG SYSC_DBGU_MR; // Mode Register
  79. AT91_REG SYSC_DBGU_IER; // Interrupt Enable Register
  80. AT91_REG SYSC_DBGU_IDR; // Interrupt Disable Register
  81. AT91_REG SYSC_DBGU_IMR; // Interrupt Mask Register
  82. AT91_REG SYSC_DBGU_CSR; // Channel Status Register
  83. AT91_REG SYSC_DBGU_RHR; // Receiver Holding Register
  84. AT91_REG SYSC_DBGU_THR; // Transmitter Holding Register
  85. AT91_REG SYSC_DBGU_BRGR; // Baud Rate Generator Register
  86. AT91_REG Reserved3[7]; //
  87. AT91_REG SYSC_DBGU_C1R; // Chip ID1 Register
  88. AT91_REG SYSC_DBGU_C2R; // Chip ID2 Register
  89. AT91_REG SYSC_DBGU_FNTR; // Force NTRST Register
  90. AT91_REG Reserved4[45]; //
  91. AT91_REG SYSC_DBGU_RPR; // Receive Pointer Register
  92. AT91_REG SYSC_DBGU_RCR; // Receive Counter Register
  93. AT91_REG SYSC_DBGU_TPR; // Transmit Pointer Register
  94. AT91_REG SYSC_DBGU_TCR; // Transmit Counter Register
  95. AT91_REG SYSC_DBGU_RNPR; // Receive Next Pointer Register
  96. AT91_REG SYSC_DBGU_RNCR; // Receive Next Counter Register
  97. AT91_REG SYSC_DBGU_TNPR; // Transmit Next Pointer Register
  98. AT91_REG SYSC_DBGU_TNCR; // Transmit Next Counter Register
  99. AT91_REG SYSC_DBGU_PTCR; // PDC Transfer Control Register
  100. AT91_REG SYSC_DBGU_PTSR; // PDC Transfer Status Register
  101. AT91_REG Reserved5[54]; //
  102. AT91_REG SYSC_PIOA_PER; // PIO Enable Register
  103. AT91_REG SYSC_PIOA_PDR; // PIO Disable Register
  104. AT91_REG SYSC_PIOA_PSR; // PIO Status Register
  105. AT91_REG Reserved6[1]; //
  106. AT91_REG SYSC_PIOA_OER; // Output Enable Register
  107. AT91_REG SYSC_PIOA_ODR; // Output Disable Registerr
  108. AT91_REG SYSC_PIOA_OSR; // Output Status Register
  109. AT91_REG Reserved7[1]; //
  110. AT91_REG SYSC_PIOA_IFER; // Input Filter Enable Register
  111. AT91_REG SYSC_PIOA_IFDR; // Input Filter Disable Register
  112. AT91_REG SYSC_PIOA_IFSR; // Input Filter Status Register
  113. AT91_REG Reserved8[1]; //
  114. AT91_REG SYSC_PIOA_SODR; // Set Output Data Register
  115. AT91_REG SYSC_PIOA_CODR; // Clear Output Data Register
  116. AT91_REG SYSC_PIOA_ODSR; // Output Data Status Register
  117. AT91_REG SYSC_PIOA_PDSR; // Pin Data Status Register
  118. AT91_REG SYSC_PIOA_IER; // Interrupt Enable Register
  119. AT91_REG SYSC_PIOA_IDR; // Interrupt Disable Register
  120. AT91_REG SYSC_PIOA_IMR; // Interrupt Mask Register
  121. AT91_REG SYSC_PIOA_ISR; // Interrupt Status Register
  122. AT91_REG SYSC_PIOA_MDER; // Multi-driver Enable Register
  123. AT91_REG SYSC_PIOA_MDDR; // Multi-driver Disable Register
  124. AT91_REG SYSC_PIOA_MDSR; // Multi-driver Status Register
  125. AT91_REG Reserved9[1]; //
  126. AT91_REG SYSC_PIOA_PPUDR; // Pull-up Disable Register
  127. AT91_REG SYSC_PIOA_PPUER; // Pull-up Enable Register
  128. AT91_REG SYSC_PIOA_PPUSR; // Pad Pull-up Status Register
  129. AT91_REG Reserved10[1]; //
  130. AT91_REG SYSC_PIOA_ASR; // Select A Register
  131. AT91_REG SYSC_PIOA_BSR; // Select B Register
  132. AT91_REG SYSC_PIOA_ABSR; // AB Select Status Register
  133. AT91_REG Reserved11[9]; //
  134. AT91_REG SYSC_PIOA_OWER; // Output Write Enable Register
  135. AT91_REG SYSC_PIOA_OWDR; // Output Write Disable Register
  136. AT91_REG SYSC_PIOA_OWSR; // Output Write Status Register
  137. AT91_REG Reserved12[469]; //
  138. AT91_REG SYSC_PMC_SCER; // System Clock Enable Register
  139. AT91_REG SYSC_PMC_SCDR; // System Clock Disable Register
  140. AT91_REG SYSC_PMC_SCSR; // System Clock Status Register
  141. AT91_REG Reserved13[1]; //
  142. AT91_REG SYSC_PMC_PCER; // Peripheral Clock Enable Register
  143. AT91_REG SYSC_PMC_PCDR; // Peripheral Clock Disable Register
  144. AT91_REG SYSC_PMC_PCSR; // Peripheral Clock Status Register
  145. AT91_REG Reserved14[1]; //
  146. AT91_REG SYSC_PMC_MOR; // Main Oscillator Register
  147. AT91_REG SYSC_PMC_MCFR; // Main Clock Frequency Register
  148. AT91_REG Reserved15[1]; //
  149. AT91_REG SYSC_PMC_PLLR; // PLL Register
  150. AT91_REG SYSC_PMC_MCKR; // Master Clock Register
  151. AT91_REG Reserved16[3]; //
  152. AT91_REG SYSC_PMC_PCKR[8]; // Programmable Clock Register
  153. AT91_REG SYSC_PMC_IER; // Interrupt Enable Register
  154. AT91_REG SYSC_PMC_IDR; // Interrupt Disable Register
  155. AT91_REG SYSC_PMC_SR; // Status Register
  156. AT91_REG SYSC_PMC_IMR; // Interrupt Mask Register
  157. AT91_REG Reserved17[36]; //
  158. AT91_REG SYSC_RSTC_RCR; // Reset Control Register
  159. AT91_REG SYSC_RSTC_RSR; // Reset Status Register
  160. AT91_REG SYSC_RSTC_RMR; // Reset Mode Register
  161. AT91_REG Reserved18[5]; //
  162. AT91_REG SYSC_RTTC_RTMR; // Real-time Mode Register
  163. AT91_REG SYSC_RTTC_RTAR; // Real-time Alarm Register
  164. AT91_REG SYSC_RTTC_RTVR; // Real-time Value Register
  165. AT91_REG SYSC_RTTC_RTSR; // Real-time Status Register
  166. AT91_REG SYSC_PITC_PIMR; // Period Interval Mode Register
  167. AT91_REG SYSC_PITC_PISR; // Period Interval Status Register
  168. AT91_REG SYSC_PITC_PIVR; // Period Interval Value Register
  169. AT91_REG SYSC_PITC_PIIR; // Period Interval Image Register
  170. AT91_REG SYSC_WDTC_WDCR; // Watchdog Control Register
  171. AT91_REG SYSC_WDTC_WDMR; // Watchdog Mode Register
  172. AT91_REG SYSC_WDTC_WDSR; // Watchdog Status Register
  173. AT91_REG Reserved19[5]; //
  174. AT91_REG SYSC_SYSC_VREG; // Voltage Regulator Mode Register
  175. } AT91S_SYSC, *AT91PS_SYSC;
  176. // -------- VREG : (SYSC Offset: 0xd60) Voltage Regulator Mode Register --------
  177. # define AT91C_SYSC_PSTDBY ((unsigned int) 0x1 << 0) // (SYSC) Voltage Regulator Power Mode
  178. // *****************************************************************************
  179. // SOFTWARE API DEFINITION FOR Advanced Interrupt Controller
  180. // *****************************************************************************
  181. typedef struct _AT91S_AIC {
  182. AT91_REG AIC_SMR[32]; // Source Mode Register
  183. AT91_REG AIC_SVR[32]; // Source Vector Register
  184. AT91_REG AIC_IVR; // IRQ Vector Register
  185. AT91_REG AIC_FVR; // FIQ Vector Register
  186. AT91_REG AIC_ISR; // Interrupt Status Register
  187. AT91_REG AIC_IPR; // Interrupt Pending Register
  188. AT91_REG AIC_IMR; // Interrupt Mask Register
  189. AT91_REG AIC_CISR; // Core Interrupt Status Register
  190. AT91_REG Reserved0[2]; //
  191. AT91_REG AIC_IECR; // Interrupt Enable Command Register
  192. AT91_REG AIC_IDCR; // Interrupt Disable Command Register
  193. AT91_REG AIC_ICCR; // Interrupt Clear Command Register
  194. AT91_REG AIC_ISCR; // Interrupt Set Command Register
  195. AT91_REG AIC_EOICR; // End of Interrupt Command Register
  196. AT91_REG AIC_SPU; // Spurious Vector Register
  197. AT91_REG AIC_DCR; // Debug Control Register (Protect)
  198. AT91_REG Reserved1[1]; //
  199. AT91_REG AIC_FFER; // Fast Forcing Enable Register
  200. AT91_REG AIC_FFDR; // Fast Forcing Disable Register
  201. AT91_REG AIC_FFSR; // Fast Forcing Status Register
  202. } AT91S_AIC, *AT91PS_AIC;
  203. // -------- AIC_SMR : (AIC Offset: 0x0) Control Register --------
  204. # define AT91C_AIC_PRIOR ((unsigned int) 0x7 << 0) // (AIC) Priority Level
  205. # define AT91C_AIC_PRIOR_LOWEST ((unsigned int) 0x0) // (AIC) Lowest priority level
  206. # define AT91C_AIC_PRIOR_HIGHEST ((unsigned int) 0x7) // (AIC) Highest priority level
  207. # define AT91C_AIC_SRCTYPE ((unsigned int) 0x3 << 5) // (AIC) Interrupt Source Type
  208. # define AT91C_AIC_SRCTYPE_INT_LEVEL_SENSITIVE ((unsigned int) 0x0 << 5) // (AIC) Internal Sources Code Label Level Sensitive
  209. # define AT91C_AIC_SRCTYPE_INT_EDGE_TRIGGERED ((unsigned int) 0x1 << 5) // (AIC) Internal Sources Code Label Edge triggered
  210. # define AT91C_AIC_SRCTYPE_EXT_HIGH_LEVEL ((unsigned int) 0x2 << 5) // (AIC) External Sources Code Label High-level Sensitive
  211. # define AT91C_AIC_SRCTYPE_EXT_POSITIVE_EDGE ((unsigned int) 0x3 << 5) // (AIC) External Sources Code Label Positive Edge triggered
  212. // -------- AIC_CISR : (AIC Offset: 0x114) AIC Core Interrupt Status Register --------
  213. # define AT91C_AIC_NFIQ ((unsigned int) 0x1 << 0) // (AIC) NFIQ Status
  214. # define AT91C_AIC_NIRQ ((unsigned int) 0x1 << 1) // (AIC) NIRQ Status
  215. // -------- AIC_DCR : (AIC Offset: 0x138) AIC Debug Control Register (Protect) --------
  216. # define AT91C_AIC_DCR_PROT ((unsigned int) 0x1 << 0) // (AIC) Protection Mode
  217. # define AT91C_AIC_DCR_GMSK ((unsigned int) 0x1 << 1) // (AIC) General Mask
  218. // *****************************************************************************
  219. // SOFTWARE API DEFINITION FOR Debug Unit
  220. // *****************************************************************************
  221. typedef struct _AT91S_DBGU {
  222. AT91_REG DBGU_CR; // Control Register
  223. AT91_REG DBGU_MR; // Mode Register
  224. AT91_REG DBGU_IER; // Interrupt Enable Register
  225. AT91_REG DBGU_IDR; // Interrupt Disable Register
  226. AT91_REG DBGU_IMR; // Interrupt Mask Register
  227. AT91_REG DBGU_CSR; // Channel Status Register
  228. AT91_REG DBGU_RHR; // Receiver Holding Register
  229. AT91_REG DBGU_THR; // Transmitter Holding Register
  230. AT91_REG DBGU_BRGR; // Baud Rate Generator Register
  231. AT91_REG Reserved0[7]; //
  232. AT91_REG DBGU_C1R; // Chip ID1 Register
  233. AT91_REG DBGU_C2R; // Chip ID2 Register
  234. AT91_REG DBGU_FNTR; // Force NTRST Register
  235. AT91_REG Reserved1[45]; //
  236. AT91_REG DBGU_RPR; // Receive Pointer Register
  237. AT91_REG DBGU_RCR; // Receive Counter Register
  238. AT91_REG DBGU_TPR; // Transmit Pointer Register
  239. AT91_REG DBGU_TCR; // Transmit Counter Register
  240. AT91_REG DBGU_RNPR; // Receive Next Pointer Register
  241. AT91_REG DBGU_RNCR; // Receive Next Counter Register
  242. AT91_REG DBGU_TNPR; // Transmit Next Pointer Register
  243. AT91_REG DBGU_TNCR; // Transmit Next Counter Register
  244. AT91_REG DBGU_PTCR; // PDC Transfer Control Register
  245. AT91_REG DBGU_PTSR; // PDC Transfer Status Register
  246. } AT91S_DBGU, *AT91PS_DBGU;
  247. // -------- DBGU_CR : (DBGU Offset: 0x0) Debug Unit Control Register --------
  248. # define AT91C_US_RSTRX ((unsigned int) 0x1 << 2) // (DBGU) Reset Receiver
  249. # define AT91C_US_RSTTX ((unsigned int) 0x1 << 3) // (DBGU) Reset Transmitter
  250. # define AT91C_US_RXEN ((unsigned int) 0x1 << 4) // (DBGU) Receiver Enable
  251. # define AT91C_US_RXDIS ((unsigned int) 0x1 << 5) // (DBGU) Receiver Disable
  252. # define AT91C_US_TXEN ((unsigned int) 0x1 << 6) // (DBGU) Transmitter Enable
  253. # define AT91C_US_TXDIS ((unsigned int) 0x1 << 7) // (DBGU) Transmitter Disable
  254. // -------- DBGU_MR : (DBGU Offset: 0x4) Debug Unit Mode Register --------
  255. # define AT91C_US_PAR ((unsigned int) 0x7 << 9) // (DBGU) Parity type
  256. # define AT91C_US_PAR_EVEN ((unsigned int) 0x0 << 9) // (DBGU) Even Parity
  257. # define AT91C_US_PAR_ODD ((unsigned int) 0x1 << 9) // (DBGU) Odd Parity
  258. # define AT91C_US_PAR_SPACE ((unsigned int) 0x2 << 9) // (DBGU) Parity forced to 0 (Space)
  259. # define AT91C_US_PAR_MARK ((unsigned int) 0x3 << 9) // (DBGU) Parity forced to 1 (Mark)
  260. # define AT91C_US_PAR_NONE ((unsigned int) 0x4 << 9) // (DBGU) No Parity
  261. # define AT91C_US_PAR_MULTI_DROP ((unsigned int) 0x6 << 9) // (DBGU) Multi-drop mode
  262. # define AT91C_US_CHMODE ((unsigned int) 0x3 << 14) // (DBGU) Channel Mode
  263. # define AT91C_US_CHMODE_NORMAL ((unsigned int) 0x0 << 14) // (DBGU) Normal Mode: The USART channel operates as an RX/TX USART.
  264. # define AT91C_US_CHMODE_AUTO ((unsigned int) 0x1 << 14) // (DBGU) Automatic Echo: Receiver Data Input is connected to the TXD pin.
  265. # define AT91C_US_CHMODE_LOCAL ((unsigned int) 0x2 << 14) // (DBGU) Local Loopback: Transmitter Output Signal is connected to Receiver Input Signal.
  266. # define AT91C_US_CHMODE_REMOTE ((unsigned int) 0x3 << 14) // (DBGU) Remote Loopback: RXD pin is internally connected to TXD pin.
  267. // -------- DBGU_IER : (DBGU Offset: 0x8) Debug Unit Interrupt Enable Register --------
  268. # define AT91C_US_RXRDY ((unsigned int) 0x1 << 0) // (DBGU) RXRDY Interrupt
  269. # define AT91C_US_TXRDY ((unsigned int) 0x1 << 1) // (DBGU) TXRDY Interrupt
  270. # define AT91C_US_ENDRX ((unsigned int) 0x1 << 3) // (DBGU) End of Receive Transfer Interrupt
  271. # define AT91C_US_ENDTX ((unsigned int) 0x1 << 4) // (DBGU) End of Transmit Interrupt
  272. # define AT91C_US_OVRE ((unsigned int) 0x1 << 5) // (DBGU) Overrun Interrupt
  273. # define AT91C_US_FRAME ((unsigned int) 0x1 << 6) // (DBGU) Framing Error Interrupt
  274. # define AT91C_US_PARE ((unsigned int) 0x1 << 7) // (DBGU) Parity Error Interrupt
  275. # define AT91C_US_TXEMPTY ((unsigned int) 0x1 << 9) // (DBGU) TXEMPTY Interrupt
  276. # define AT91C_US_TXBUFE ((unsigned int) 0x1 << 11) // (DBGU) TXBUFE Interrupt
  277. # define AT91C_US_RXBUFF ((unsigned int) 0x1 << 12) // (DBGU) RXBUFF Interrupt
  278. # define AT91C_US_COMM_TX ((unsigned int) 0x1 << 30) // (DBGU) COMM_TX Interrupt
  279. # define AT91C_US_COMM_RX ((unsigned int) 0x1 << 31) // (DBGU) COMM_RX Interrupt
  280. // -------- DBGU_IDR : (DBGU Offset: 0xc) Debug Unit Interrupt Disable Register --------
  281. // -------- DBGU_IMR : (DBGU Offset: 0x10) Debug Unit Interrupt Mask Register --------
  282. // -------- DBGU_CSR : (DBGU Offset: 0x14) Debug Unit Channel Status Register --------
  283. // -------- DBGU_FNTR : (DBGU Offset: 0x48) Debug Unit FORCE_NTRST Register --------
  284. # define AT91C_US_FORCE_NTRST ((unsigned int) 0x1 << 0) // (DBGU) Force NTRST in JTAG
  285. // *****************************************************************************
  286. // SOFTWARE API DEFINITION FOR Peripheral Data Controller
  287. // *****************************************************************************
  288. typedef struct _AT91S_PDC {
  289. AT91_REG PDC_RPR; // Receive Pointer Register
  290. AT91_REG PDC_RCR; // Receive Counter Register
  291. AT91_REG PDC_TPR; // Transmit Pointer Register
  292. AT91_REG PDC_TCR; // Transmit Counter Register
  293. AT91_REG PDC_RNPR; // Receive Next Pointer Register
  294. AT91_REG PDC_RNCR; // Receive Next Counter Register
  295. AT91_REG PDC_TNPR; // Transmit Next Pointer Register
  296. AT91_REG PDC_TNCR; // Transmit Next Counter Register
  297. AT91_REG PDC_PTCR; // PDC Transfer Control Register
  298. AT91_REG PDC_PTSR; // PDC Transfer Status Register
  299. } AT91S_PDC, *AT91PS_PDC;
  300. // -------- PDC_PTCR : (PDC Offset: 0x20) PDC Transfer Control Register --------
  301. # define AT91C_PDC_RXTEN ((unsigned int) 0x1 << 0) // (PDC) Receiver Transfer Enable
  302. # define AT91C_PDC_RXTDIS ((unsigned int) 0x1 << 1) // (PDC) Receiver Transfer Disable
  303. # define AT91C_PDC_TXTEN ((unsigned int) 0x1 << 8) // (PDC) Transmitter Transfer Enable
  304. # define AT91C_PDC_TXTDIS ((unsigned int) 0x1 << 9) // (PDC) Transmitter Transfer Disable
  305. // -------- PDC_PTSR : (PDC Offset: 0x24) PDC Transfer Status Register --------
  306. // *****************************************************************************
  307. // SOFTWARE API DEFINITION FOR Parallel Input Output Controler
  308. // *****************************************************************************
  309. typedef struct _AT91S_PIO {
  310. AT91_REG PIO_PER; // PIO Enable Register
  311. AT91_REG PIO_PDR; // PIO Disable Register
  312. AT91_REG PIO_PSR; // PIO Status Register
  313. AT91_REG Reserved0[1]; //
  314. AT91_REG PIO_OER; // Output Enable Register
  315. AT91_REG PIO_ODR; // Output Disable Registerr
  316. AT91_REG PIO_OSR; // Output Status Register
  317. AT91_REG Reserved1[1]; //
  318. AT91_REG PIO_IFER; // Input Filter Enable Register
  319. AT91_REG PIO_IFDR; // Input Filter Disable Register
  320. AT91_REG PIO_IFSR; // Input Filter Status Register
  321. AT91_REG Reserved2[1]; //
  322. AT91_REG PIO_SODR; // Set Output Data Register
  323. AT91_REG PIO_CODR; // Clear Output Data Register
  324. AT91_REG PIO_ODSR; // Output Data Status Register
  325. AT91_REG PIO_PDSR; // Pin Data Status Register
  326. AT91_REG PIO_IER; // Interrupt Enable Register
  327. AT91_REG PIO_IDR; // Interrupt Disable Register
  328. AT91_REG PIO_IMR; // Interrupt Mask Register
  329. AT91_REG PIO_ISR; // Interrupt Status Register
  330. AT91_REG PIO_MDER; // Multi-driver Enable Register
  331. AT91_REG PIO_MDDR; // Multi-driver Disable Register
  332. AT91_REG PIO_MDSR; // Multi-driver Status Register
  333. AT91_REG Reserved3[1]; //
  334. AT91_REG PIO_PPUDR; // Pull-up Disable Register
  335. AT91_REG PIO_PPUER; // Pull-up Enable Register
  336. AT91_REG PIO_PPUSR; // Pad Pull-up Status Register
  337. AT91_REG Reserved4[1]; //
  338. AT91_REG PIO_ASR; // Select A Register
  339. AT91_REG PIO_BSR; // Select B Register
  340. AT91_REG PIO_ABSR; // AB Select Status Register
  341. AT91_REG Reserved5[9]; //
  342. AT91_REG PIO_OWER; // Output Write Enable Register
  343. AT91_REG PIO_OWDR; // Output Write Disable Register
  344. AT91_REG PIO_OWSR; // Output Write Status Register
  345. } AT91S_PIO, *AT91PS_PIO;
  346. // *****************************************************************************
  347. // SOFTWARE API DEFINITION FOR Clock Generator Controler
  348. // *****************************************************************************
  349. typedef struct _AT91S_CKGR {
  350. AT91_REG CKGR_MOR; // Main Oscillator Register
  351. AT91_REG CKGR_MCFR; // Main Clock Frequency Register
  352. AT91_REG Reserved0[1]; //
  353. AT91_REG CKGR_PLLR; // PLL Register
  354. } AT91S_CKGR, *AT91PS_CKGR;
  355. // -------- CKGR_MOR : (CKGR Offset: 0x0) Main Oscillator Register --------
  356. # define AT91C_CKGR_MOSCEN ((unsigned int) 0x1 << 0) // (CKGR) Main Oscillator Enable
  357. # define AT91C_CKGR_OSCBYPASS ((unsigned int) 0x1 << 1) // (CKGR) Main Oscillator Bypass
  358. # define AT91C_CKGR_OSCOUNT ((unsigned int) 0xFF << 8) // (CKGR) Main Oscillator Start-up Time
  359. // -------- CKGR_MCFR : (CKGR Offset: 0x4) Main Clock Frequency Register --------
  360. # define AT91C_CKGR_MAINF ((unsigned int) 0xFFFF << 0) // (CKGR) Main Clock Frequency
  361. # define AT91C_CKGR_MAINRDY ((unsigned int) 0x1 << 16) // (CKGR) Main Clock Ready
  362. // -------- CKGR_PLLR : (CKGR Offset: 0xc) PLL B Register --------
  363. # define AT91C_CKGR_DIV ((unsigned int) 0xFF << 0) // (CKGR) Divider Selected
  364. # define AT91C_CKGR_DIV_0 ((unsigned int) 0x0) // (CKGR) Divider output is 0
  365. # define AT91C_CKGR_DIV_BYPASS ((unsigned int) 0x1) // (CKGR) Divider is bypassed
  366. # define AT91C_CKGR_PLLCOUNT ((unsigned int) 0x3F << 8) // (CKGR) PLL Counter
  367. # define AT91C_CKGR_OUT ((unsigned int) 0x3 << 14) // (CKGR) PLL Output Frequency Range
  368. # define AT91C_CKGR_OUT_0 ((unsigned int) 0x0 << 14) // (CKGR) Please refer to the PLL datasheet
  369. # define AT91C_CKGR_OUT_1 ((unsigned int) 0x1 << 14) // (CKGR) Please refer to the PLL datasheet
  370. # define AT91C_CKGR_OUT_2 ((unsigned int) 0x2 << 14) // (CKGR) Please refer to the PLL datasheet
  371. # define AT91C_CKGR_OUT_3 ((unsigned int) 0x3 << 14) // (CKGR) Please refer to the PLL datasheet
  372. # define AT91C_CKGR_MUL ((unsigned int) 0x7FF << 16) // (CKGR) PLL Multiplier
  373. # define AT91C_CKGR_USBDIV ((unsigned int) 0x3 << 28) // (CKGR) Divider for USB Clocks
  374. # define AT91C_CKGR_USBDIV_0 ((unsigned int) 0x0 << 28) // (CKGR) Divider output is PLL clock output
  375. # define AT91C_CKGR_USBDIV_1 ((unsigned int) 0x1 << 28) // (CKGR) Divider output is PLL clock output divided by 2
  376. # define AT91C_CKGR_USBDIV_2 ((unsigned int) 0x2 << 28) // (CKGR) Divider output is PLL clock output divided by 4
  377. // *****************************************************************************
  378. // SOFTWARE API DEFINITION FOR Power Management Controler
  379. // *****************************************************************************
  380. typedef struct _AT91S_PMC {
  381. AT91_REG PMC_SCER; // System Clock Enable Register
  382. AT91_REG PMC_SCDR; // System Clock Disable Register
  383. AT91_REG PMC_SCSR; // System Clock Status Register
  384. AT91_REG Reserved0[1]; //
  385. AT91_REG PMC_PCER; // Peripheral Clock Enable Register
  386. AT91_REG PMC_PCDR; // Peripheral Clock Disable Register
  387. AT91_REG PMC_PCSR; // Peripheral Clock Status Register
  388. AT91_REG Reserved1[1]; //
  389. AT91_REG PMC_MOR; // Main Oscillator Register
  390. AT91_REG PMC_MCFR; // Main Clock Frequency Register
  391. AT91_REG Reserved2[1]; //
  392. AT91_REG PMC_PLLR; // PLL Register
  393. AT91_REG PMC_MCKR; // Master Clock Register
  394. AT91_REG Reserved3[3]; //
  395. AT91_REG PMC_PCKR[8]; // Programmable Clock Register
  396. AT91_REG PMC_IER; // Interrupt Enable Register
  397. AT91_REG PMC_IDR; // Interrupt Disable Register
  398. AT91_REG PMC_SR; // Status Register
  399. AT91_REG PMC_IMR; // Interrupt Mask Register
  400. } AT91S_PMC, *AT91PS_PMC;
  401. // -------- PMC_SCER : (PMC Offset: 0x0) System Clock Enable Register --------
  402. # define AT91C_PMC_PCK ((unsigned int) 0x1 << 0) // (PMC) Processor Clock
  403. # define AT91C_PMC_UDP ((unsigned int) 0x1 << 7) // (PMC) USB Device Port Clock
  404. # define AT91C_PMC_PCK0 ((unsigned int) 0x1 << 8) // (PMC) Programmable Clock Output
  405. # define AT91C_PMC_PCK1 ((unsigned int) 0x1 << 9) // (PMC) Programmable Clock Output
  406. # define AT91C_PMC_PCK2 ((unsigned int) 0x1 << 10) // (PMC) Programmable Clock Output
  407. # define AT91C_PMC_PCK3 ((unsigned int) 0x1 << 11) // (PMC) Programmable Clock Output
  408. // -------- PMC_SCDR : (PMC Offset: 0x4) System Clock Disable Register --------
  409. // -------- PMC_SCSR : (PMC Offset: 0x8) System Clock Status Register --------
  410. // -------- CKGR_MOR : (PMC Offset: 0x20) Main Oscillator Register --------
  411. // -------- CKGR_MCFR : (PMC Offset: 0x24) Main Clock Frequency Register --------
  412. // -------- CKGR_PLLR : (PMC Offset: 0x2c) PLL B Register --------
  413. // -------- PMC_MCKR : (PMC Offset: 0x30) Master Clock Register --------
  414. # define AT91C_PMC_CSS ((unsigned int) 0x3 << 0) // (PMC) Programmable Clock Selection
  415. # define AT91C_PMC_CSS_SLOW_CLK ((unsigned int) 0x0) // (PMC) Slow Clock is selected
  416. # define AT91C_PMC_CSS_MAIN_CLK ((unsigned int) 0x1) // (PMC) Main Clock is selected
  417. # define AT91C_PMC_CSS_PLL_CLK ((unsigned int) 0x3) // (PMC) Clock from PLL is selected
  418. # define AT91C_PMC_PRES ((unsigned int) 0x7 << 2) // (PMC) Programmable Clock Prescaler
  419. # define AT91C_PMC_PRES_CLK ((unsigned int) 0x0 << 2) // (PMC) Selected clock
  420. # define AT91C_PMC_PRES_CLK_2 ((unsigned int) 0x1 << 2) // (PMC) Selected clock divided by 2
  421. # define AT91C_PMC_PRES_CLK_4 ((unsigned int) 0x2 << 2) // (PMC) Selected clock divided by 4
  422. # define AT91C_PMC_PRES_CLK_8 ((unsigned int) 0x3 << 2) // (PMC) Selected clock divided by 8
  423. # define AT91C_PMC_PRES_CLK_16 ((unsigned int) 0x4 << 2) // (PMC) Selected clock divided by 16
  424. # define AT91C_PMC_PRES_CLK_32 ((unsigned int) 0x5 << 2) // (PMC) Selected clock divided by 32
  425. # define AT91C_PMC_PRES_CLK_64 ((unsigned int) 0x6 << 2) // (PMC) Selected clock divided by 64
  426. // -------- PMC_PCKR : (PMC Offset: 0x40) Programmable Clock Register --------
  427. // -------- PMC_IER : (PMC Offset: 0x60) PMC Interrupt Enable Register --------
  428. # define AT91C_PMC_MOSCS ((unsigned int) 0x1 << 0) // (PMC) MOSC Status/Enable/Disable/Mask
  429. # define AT91C_PMC_LOCK ((unsigned int) 0x1 << 2) // (PMC) PLL Status/Enable/Disable/Mask
  430. # define AT91C_PMC_MCKRDY ((unsigned int) 0x1 << 3) // (PMC) MCK_RDY Status/Enable/Disable/Mask
  431. # define AT91C_PMC_PCK0RDY ((unsigned int) 0x1 << 8) // (PMC) PCK0_RDY Status/Enable/Disable/Mask
  432. # define AT91C_PMC_PCK1RDY ((unsigned int) 0x1 << 9) // (PMC) PCK1_RDY Status/Enable/Disable/Mask
  433. # define AT91C_PMC_PCK2RDY ((unsigned int) 0x1 << 10) // (PMC) PCK2_RDY Status/Enable/Disable/Mask
  434. # define AT91C_PMC_PCK3RDY ((unsigned int) 0x1 << 11) // (PMC) PCK3_RDY Status/Enable/Disable/Mask
  435. // -------- PMC_IDR : (PMC Offset: 0x64) PMC Interrupt Disable Register --------
  436. // -------- PMC_SR : (PMC Offset: 0x68) PMC Status Register --------
  437. // -------- PMC_IMR : (PMC Offset: 0x6c) PMC Interrupt Mask Register --------
  438. // *****************************************************************************
  439. // SOFTWARE API DEFINITION FOR Reset Controller Interface
  440. // *****************************************************************************
  441. typedef struct _AT91S_RSTC {
  442. AT91_REG RSTC_RCR; // Reset Control Register
  443. AT91_REG RSTC_RSR; // Reset Status Register
  444. AT91_REG RSTC_RMR; // Reset Mode Register
  445. } AT91S_RSTC, *AT91PS_RSTC;
  446. // -------- SYSC_RCR : (RSTC Offset: 0x0) Reset Control Register --------
  447. # define AT91C_SYSC_PROCRST ((unsigned int) 0x1 << 0) // (RSTC) Processor Reset
  448. # define AT91C_SYSC_ICERST ((unsigned int) 0x1 << 1) // (RSTC) ICE Interface Reset
  449. # define AT91C_SYSC_PERRST ((unsigned int) 0x1 << 2) // (RSTC) Peripheral Reset
  450. # define AT91C_SYSC_EXTRST ((unsigned int) 0x1 << 3) // (RSTC) External Reset
  451. # define AT91C_SYSC_KEY ((unsigned int) 0xFF << 24) // (RSTC) Password
  452. // -------- SYSC_RSR : (RSTC Offset: 0x4) Reset Status Register --------
  453. # define AT91C_SYSC_URSTS ((unsigned int) 0x1 << 0) // (RSTC) User Reset Status
  454. # define AT91C_SYSC_BODSTS ((unsigned int) 0x1 << 1) // (RSTC) Brown-out Detection Status
  455. # define AT91C_SYSC_RSTTYP ((unsigned int) 0x7 << 8) // (RSTC) Reset Type
  456. # define AT91C_SYSC_RSTTYP_POWERUP ((unsigned int) 0x0 << 8) // (RSTC) Power-up Reset. VDDCORE rising.
  457. # define AT91C_SYSC_RSTTYP_WATCHDOG ((unsigned int) 0x2 << 8) // (RSTC) Watchdog Reset. Watchdog overflow occured.
  458. # define AT91C_SYSC_RSTTYP_SOFTWARE ((unsigned int) 0x3 << 8) // (RSTC) Software Reset. Processor reset required by the software.
  459. # define AT91C_SYSC_RSTTYP_USER ((unsigned int) 0x4 << 8) // (RSTC) User Reset. NRST pin detected low.
  460. # define AT91C_SYSC_RSTTYP_BROWNOUT ((unsigned int) 0x5 << 8) // (RSTC) Brown-out Reset.
  461. # define AT91C_SYSC_NRSTL ((unsigned int) 0x1 << 16) // (RSTC) NRST pin level
  462. # define AT91C_SYSC_SRCMP ((unsigned int) 0x1 << 17) // (RSTC) Software Reset Command in Progress.
  463. // -------- SYSC_RMR : (RSTC Offset: 0x8) Reset Mode Register --------
  464. # define AT91C_SYSC_URSTEN ((unsigned int) 0x1 << 0) // (RSTC) User Reset Enable
  465. # define AT91C_SYSC_URSTIEN ((unsigned int) 0x1 << 4) // (RSTC) User Reset Interrupt Enable
  466. # define AT91C_SYSC_ERSTL ((unsigned int) 0xF << 8) // (RSTC) User Reset Enable
  467. # define AT91C_SYSC_BODIEN ((unsigned int) 0x1 << 16) // (RSTC) Brown-out Detection Interrupt Enable
  468. // *****************************************************************************
  469. // SOFTWARE API DEFINITION FOR Real Time Timer Controller Interface
  470. // *****************************************************************************
  471. typedef struct _AT91S_RTTC {
  472. AT91_REG RTTC_RTMR; // Real-time Mode Register
  473. AT91_REG RTTC_RTAR; // Real-time Alarm Register
  474. AT91_REG RTTC_RTVR; // Real-time Value Register
  475. AT91_REG RTTC_RTSR; // Real-time Status Register
  476. } AT91S_RTTC, *AT91PS_RTTC;
  477. // -------- SYSC_RTMR : (RTTC Offset: 0x0) Real-time Mode Register --------
  478. # define AT91C_SYSC_RTPRES ((unsigned int) 0xFFFF << 0) // (RTTC) Real-time Timer Prescaler Value
  479. # define AT91C_SYSC_ALMIEN ((unsigned int) 0x1 << 16) // (RTTC) Alarm Interrupt Enable
  480. # define AT91C_SYSC_RTTINCIEN ((unsigned int) 0x1 << 17) // (RTTC) Real Time Timer Increment Interrupt Enable
  481. # define AT91C_SYSC_RTTRST ((unsigned int) 0x1 << 18) // (RTTC) Real Time Timer Restart
  482. // -------- SYSC_RTAR : (RTTC Offset: 0x4) Real-time Alarm Register --------
  483. # define AT91C_SYSC_ALMV ((unsigned int) 0x0 << 0) // (RTTC) Alarm Value
  484. // -------- SYSC_RTVR : (RTTC Offset: 0x8) Current Real-time Value Register --------
  485. # define AT91C_SYSC_CRTV ((unsigned int) 0x0 << 0) // (RTTC) Current Real-time Value
  486. // -------- SYSC_RTSR : (RTTC Offset: 0xc) Real-time Status Register --------
  487. # define AT91C_SYSC_ALMS ((unsigned int) 0x1 << 0) // (RTTC) Real-time Alarm Status
  488. # define AT91C_SYSC_RTTINC ((unsigned int) 0x1 << 1) // (RTTC) Real-time Timer Increment
  489. // *****************************************************************************
  490. // SOFTWARE API DEFINITION FOR Periodic Interval Timer Controller Interface
  491. // *****************************************************************************
  492. typedef struct _AT91S_PITC {
  493. AT91_REG PITC_PIMR; // Period Interval Mode Register
  494. AT91_REG PITC_PISR; // Period Interval Status Register
  495. AT91_REG PITC_PIVR; // Period Interval Value Register
  496. AT91_REG PITC_PIIR; // Period Interval Image Register
  497. } AT91S_PITC, *AT91PS_PITC;
  498. // -------- SYSC_PIMR : (PITC Offset: 0x0) Periodic Interval Mode Register --------
  499. # define AT91C_SYSC_PIV ((unsigned int) 0xFFFFF << 0) // (PITC) Periodic Interval Value
  500. # define AT91C_SYSC_PITEN ((unsigned int) 0x1 << 24) // (PITC) Periodic Interval Timer Enabled
  501. # define AT91C_SYSC_PITIEN ((unsigned int) 0x1 << 25) // (PITC) Periodic Interval Timer Interrupt Enable
  502. // -------- SYSC_PISR : (PITC Offset: 0x4) Periodic Interval Status Register --------
  503. # define AT91C_SYSC_PITS ((unsigned int) 0x1 << 0) // (PITC) Periodic Interval Timer Status
  504. // -------- SYSC_PIVR : (PITC Offset: 0x8) Periodic Interval Value Register --------
  505. # define AT91C_SYSC_CPIV ((unsigned int) 0xFFFFF << 0) // (PITC) Current Periodic Interval Value
  506. # define AT91C_SYSC_PICNT ((unsigned int) 0xFFF << 20) // (PITC) Periodic Interval Counter
  507. // -------- SYSC_PIIR : (PITC Offset: 0xc) Periodic Interval Image Register --------
  508. // *****************************************************************************
  509. // SOFTWARE API DEFINITION FOR Watchdog Timer Controller Interface
  510. // *****************************************************************************
  511. typedef struct _AT91S_WDTC {
  512. AT91_REG WDTC_WDCR; // Watchdog Control Register
  513. AT91_REG WDTC_WDMR; // Watchdog Mode Register
  514. AT91_REG WDTC_WDSR; // Watchdog Status Register
  515. } AT91S_WDTC, *AT91PS_WDTC;
  516. // -------- SYSC_WDCR : (WDTC Offset: 0x0) Periodic Interval Image Register --------
  517. # define AT91C_SYSC_WDRSTT ((unsigned int) 0x1 << 0) // (WDTC) Watchdog Restart
  518. // -------- SYSC_WDMR : (WDTC Offset: 0x4) Watchdog Mode Register --------
  519. # define AT91C_SYSC_WDV ((unsigned int) 0xFFF << 0) // (WDTC) Watchdog Timer Restart
  520. # define AT91C_SYSC_WDFIEN ((unsigned int) 0x1 << 12) // (WDTC) Watchdog Fault Interrupt Enable
  521. # define AT91C_SYSC_WDRSTEN ((unsigned int) 0x1 << 13) // (WDTC) Watchdog Reset Enable
  522. # define AT91C_SYSC_WDRPROC ((unsigned int) 0x1 << 14) // (WDTC) Watchdog Timer Restart
  523. # define AT91C_SYSC_WDDIS ((unsigned int) 0x1 << 15) // (WDTC) Watchdog Disable
  524. # define AT91C_SYSC_WDD ((unsigned int) 0xFFF << 16) // (WDTC) Watchdog Delta Value
  525. # define AT91C_SYSC_WDDBGHLT ((unsigned int) 0x1 << 28) // (WDTC) Watchdog Debug Halt
  526. # define AT91C_SYSC_WDIDLEHLT ((unsigned int) 0x1 << 29) // (WDTC) Watchdog Idle Halt
  527. // -------- SYSC_WDSR : (WDTC Offset: 0x8) Watchdog Status Register --------
  528. # define AT91C_SYSC_WDUNF ((unsigned int) 0x1 << 0) // (WDTC) Watchdog Underflow
  529. # define AT91C_SYSC_WDERR ((unsigned int) 0x1 << 1) // (WDTC) Watchdog Error
  530. // *****************************************************************************
  531. // SOFTWARE API DEFINITION FOR Memory Controller Interface
  532. // *****************************************************************************
  533. typedef struct _AT91S_MC {
  534. AT91_REG MC_RCR; // MC Remap Control Register
  535. AT91_REG MC_ASR; // MC Abort Status Register
  536. AT91_REG MC_AASR; // MC Abort Address Status Register
  537. AT91_REG Reserved0[21]; //
  538. AT91_REG MC_FMR; // MC Flash Mode Register
  539. AT91_REG MC_FCR; // MC Flash Command Register
  540. AT91_REG MC_FSR; // MC Flash Status Register
  541. } AT91S_MC, *AT91PS_MC;
  542. // -------- MC_RCR : (MC Offset: 0x0) MC Remap Control Register --------
  543. # define AT91C_MC_RCB ((unsigned int) 0x1 << 0) // (MC) Remap Command Bit
  544. // -------- MC_ASR : (MC Offset: 0x4) MC Abort Status Register --------
  545. # define AT91C_MC_UNDADD ((unsigned int) 0x1 << 0) // (MC) Undefined Addess Abort Status
  546. # define AT91C_MC_MISADD ((unsigned int) 0x1 << 1) // (MC) Misaligned Addess Abort Status
  547. # define AT91C_MC_ABTSZ ((unsigned int) 0x3 << 8) // (MC) Abort Size Status
  548. # define AT91C_MC_ABTSZ_BYTE ((unsigned int) 0x0 << 8) // (MC) Byte
  549. # define AT91C_MC_ABTSZ_HWORD ((unsigned int) 0x1 << 8) // (MC) Half-word
  550. # define AT91C_MC_ABTSZ_WORD ((unsigned int) 0x2 << 8) // (MC) Word
  551. # define AT91C_MC_ABTTYP ((unsigned int) 0x3 << 10) // (MC) Abort Type Status
  552. # define AT91C_MC_ABTTYP_DATAR ((unsigned int) 0x0 << 10) // (MC) Data Read
  553. # define AT91C_MC_ABTTYP_DATAW ((unsigned int) 0x1 << 10) // (MC) Data Write
  554. # define AT91C_MC_ABTTYP_FETCH ((unsigned int) 0x2 << 10) // (MC) Code Fetch
  555. # define AT91C_MC_MST0 ((unsigned int) 0x1 << 16) // (MC) Master 0 Abort Source
  556. # define AT91C_MC_MST1 ((unsigned int) 0x1 << 17) // (MC) Master 1 Abort Source
  557. # define AT91C_MC_SVMST0 ((unsigned int) 0x1 << 24) // (MC) Saved Master 0 Abort Source
  558. # define AT91C_MC_SVMST1 ((unsigned int) 0x1 << 25) // (MC) Saved Master 1 Abort Source
  559. // -------- MC_FMR : (MC Offset: 0x60) MC Flash Mode Register --------
  560. # define AT91C_MC_FRDY ((unsigned int) 0x1 << 0) // (MC) Flash Ready
  561. # define AT91C_MC_LOCKE ((unsigned int) 0x1 << 2) // (MC) Lock Error
  562. # define AT91C_MC_PROGE ((unsigned int) 0x1 << 3) // (MC) Programming Error
  563. # define AT91C_MC_NEBP ((unsigned int) 0x1 << 7) // (MC) No Erase Before Programming
  564. # define AT91C_MC_FWS ((unsigned int) 0x3 << 8) // (MC) Flash Wait State
  565. # define AT91C_MC_FWS_0FWS ((unsigned int) 0x0 << 8) // (MC) 1 cycle for Read, 2 for Write operations
  566. # define AT91C_MC_FWS_1FWS ((unsigned int) 0x1 << 8) // (MC) 2 cycles for Read, 3 for Write operations
  567. # define AT91C_MC_FWS_2FWS ((unsigned int) 0x2 << 8) // (MC) 3 cycles for Read, 4 for Write operations
  568. # define AT91C_MC_FWS_3FWS ((unsigned int) 0x3 << 8) // (MC) 4 cycles for Read, 4 for Write operations
  569. # define AT91C_MC_FMCN ((unsigned int) 0xFF << 16) // (MC) Flash Microsecond Cycle Number
  570. // -------- MC_FCR : (MC Offset: 0x64) MC Flash Command Register --------
  571. # define AT91C_MC_FCMD ((unsigned int) 0xF << 0) // (MC) Flash Command
  572. # define AT91C_MC_FCMD_START_PROG ((unsigned int) 0x1) // (MC) Starts the programming of th epage specified by PAGEN.
  573. # define AT91C_MC_FCMD_LOCK ((unsigned int) 0x2) // (MC) Starts a lock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.
  574. # define AT91C_MC_FCMD_PROG_AND_LOCK ((unsigned int) 0x3) // (MC) The lock sequence automatically happens after the programming sequence is completed.
  575. # define AT91C_MC_FCMD_UNLOCK ((unsigned int) 0x4) // (MC) Starts an unlock sequence of the sector defined by the bits 4 to 7 of the field PAGEN.
  576. # define AT91C_MC_FCMD_ERASE_ALL ((unsigned int) 0x8) // (MC) Starts the erase of the entire flash.If at least a page is locked, the command is cancelled.
  577. # define AT91C_MC_FCMD_SET_GP_NVM ((unsigned int) 0xB) // (MC) Set General Purpose NVM bits.
  578. # define AT91C_MC_FCMD_CLR_GP_NVM ((unsigned int) 0xD) // (MC) Clear General Purpose NVM bits.
  579. # define AT91C_MC_FCMD_SET_SECURITY ((unsigned int) 0xF) // (MC) Set Security Bit.
  580. # define AT91C_MC_PAGEN ((unsigned int) 0x3FF << 8) // (MC) Page Number
  581. # define AT91C_MC_KEY ((unsigned int) 0xFF << 24) // (MC) Writing Protect Key
  582. // -------- MC_FSR : (MC Offset: 0x68) MC Flash Command Register --------
  583. # define AT91C_MC_SECURITY ((unsigned int) 0x1 << 4) // (MC) Security Bit Status
  584. # define AT91C_MC_GPNVM0 ((unsigned int) 0x1 << 8) // (MC) Sector 0 Lock Status
  585. # define AT91C_MC_GPNVM1 ((unsigned int) 0x1 << 9) // (MC) Sector 1 Lock Status
  586. # define AT91C_MC_GPNVM2 ((unsigned int) 0x1 << 10) // (MC) Sector 2 Lock Status
  587. # define AT91C_MC_GPNVM3 ((unsigned int) 0x1 << 11) // (MC) Sector 3 Lock Status
  588. # define AT91C_MC_GPNVM4 ((unsigned int) 0x1 << 12) // (MC) Sector 4 Lock Status
  589. # define AT91C_MC_GPNVM5 ((unsigned int) 0x1 << 13) // (MC) Sector 5 Lock Status
  590. # define AT91C_MC_GPNVM6 ((unsigned int) 0x1 << 14) // (MC) Sector 6 Lock Status
  591. # define AT91C_MC_GPNVM7 ((unsigned int) 0x1 << 15) // (MC) Sector 7 Lock Status
  592. # define AT91C_MC_LOCKS0 ((unsigned int) 0x1 << 16) // (MC) Sector 0 Lock Status
  593. # define AT91C_MC_LOCKS1 ((unsigned int) 0x1 << 17) // (MC) Sector 1 Lock Status
  594. # define AT91C_MC_LOCKS2 ((unsigned int) 0x1 << 18) // (MC) Sector 2 Lock Status
  595. # define AT91C_MC_LOCKS3 ((unsigned int) 0x1 << 19) // (MC) Sector 3 Lock Status
  596. # define AT91C_MC_LOCKS4 ((unsigned int) 0x1 << 20) // (MC) Sector 4 Lock Status
  597. # define AT91C_MC_LOCKS5 ((unsigned int) 0x1 << 21) // (MC) Sector 5 Lock Status
  598. # define AT91C_MC_LOCKS6 ((unsigned int) 0x1 << 22) // (MC) Sector 6 Lock Status
  599. # define AT91C_MC_LOCKS7 ((unsigned int) 0x1 << 23) // (MC) Sector 7 Lock Status
  600. # define AT91C_MC_LOCKS8 ((unsigned int) 0x1 << 24) // (MC) Sector 8 Lock Status
  601. # define AT91C_MC_LOCKS9 ((unsigned int) 0x1 << 25) // (MC) Sector 9 Lock Status
  602. # define AT91C_MC_LOCKS10 ((unsigned int) 0x1 << 26) // (MC) Sector 10 Lock Status
  603. # define AT91C_MC_LOCKS11 ((unsigned int) 0x1 << 27) // (MC) Sector 11 Lock Status
  604. # define AT91C_MC_LOCKS12 ((unsigned int) 0x1 << 28) // (MC) Sector 12 Lock Status
  605. # define AT91C_MC_LOCKS13 ((unsigned int) 0x1 << 29) // (MC) Sector 13 Lock Status
  606. # define AT91C_MC_LOCKS14 ((unsigned int) 0x1 << 30) // (MC) Sector 14 Lock Status
  607. # define AT91C_MC_LOCKS15 ((unsigned int) 0x1 << 31) // (MC) Sector 15 Lock Status
  608. // *****************************************************************************
  609. // SOFTWARE API DEFINITION FOR Serial Parallel Interface
  610. // *****************************************************************************
  611. typedef struct _AT91S_SPI {
  612. AT91_REG SPI_CR; // Control Register
  613. AT91_REG SPI_MR; // Mode Register
  614. AT91_REG SPI_RDR; // Receive Data Register
  615. AT91_REG SPI_TDR; // Transmit Data Register
  616. AT91_REG SPI_SR; // Status Register
  617. AT91_REG SPI_IER; // Interrupt Enable Register
  618. AT91_REG SPI_IDR; // Interrupt Disable Register
  619. AT91_REG SPI_IMR; // Interrupt Mask Register
  620. AT91_REG Reserved0[4]; //
  621. AT91_REG SPI_CSR[4]; // Chip Select Register
  622. AT91_REG Reserved1[48]; //
  623. AT91_REG SPI_RPR; // Receive Pointer Register
  624. AT91_REG SPI_RCR; // Receive Counter Register
  625. AT91_REG SPI_TPR; // Transmit Pointer Register
  626. AT91_REG SPI_TCR; // Transmit Counter Register
  627. AT91_REG SPI_RNPR; // Receive Next Pointer Register
  628. AT91_REG SPI_RNCR; // Receive Next Counter Register
  629. AT91_REG SPI_TNPR; // Transmit Next Pointer Register
  630. AT91_REG SPI_TNCR; // Transmit Next Counter Register
  631. AT91_REG SPI_PTCR; // PDC Transfer Control Register
  632. AT91_REG SPI_PTSR; // PDC Transfer Status Register
  633. } AT91S_SPI, *AT91PS_SPI;
  634. // -------- SPI_CR : (SPI Offset: 0x0) SPI Control Register --------
  635. # define AT91C_SPI_SPIEN ((unsigned int) 0x1 << 0) // (SPI) SPI Enable
  636. # define AT91C_SPI_SPIDIS ((unsigned int) 0x1 << 1) // (SPI) SPI Disable
  637. # define AT91C_SPI_SWRST ((unsigned int) 0x1 << 7) // (SPI) SPI Software reset
  638. # define AT91C_SPI_LASTXFER ((unsigned int) 0x1 << 24) // (SPI) SPI Last Transfer
  639. // -------- SPI_MR : (SPI Offset: 0x4) SPI Mode Register --------
  640. # define AT91C_SPI_MSTR ((unsigned int) 0x1 << 0) // (SPI) Master/Slave Mode
  641. # define AT91C_SPI_PS ((unsigned int) 0x1 << 1) // (SPI) Peripheral Select
  642. # define AT91C_SPI_PS_FIXED ((unsigned int) 0x0 << 1) // (SPI) Fixed Peripheral Select
  643. # define AT91C_SPI_PS_VARIABLE ((unsigned int) 0x1 << 1) // (SPI) Variable Peripheral Select
  644. # define AT91C_SPI_PCSDEC ((unsigned int) 0x1 << 2) // (SPI) Chip Select Decode
  645. # define AT91C_SPI_FDIV ((unsigned int) 0x1 << 3) // (SPI) Clock Selection
  646. # define AT91C_SPI_MODFDIS ((unsigned int) 0x1 << 4) // (SPI) Mode Fault Detection
  647. # define AT91C_SPI_LLB ((unsigned int) 0x1 << 7) // (SPI) Clock Selection
  648. # define AT91C_SPI_PCS ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select
  649. # define AT91C_SPI_DLYBCS ((unsigned int) 0xFF << 24) // (SPI) Delay Between Chip Selects
  650. // -------- SPI_RDR : (SPI Offset: 0x8) Receive Data Register --------
  651. # define AT91C_SPI_RD ((unsigned int) 0xFFFF << 0) // (SPI) Receive Data
  652. # define AT91C_SPI_RPCS ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status
  653. // -------- SPI_TDR : (SPI Offset: 0xc) Transmit Data Register --------
  654. # define AT91C_SPI_TD ((unsigned int) 0xFFFF << 0) // (SPI) Transmit Data
  655. # define AT91C_SPI_TPCS ((unsigned int) 0xF << 16) // (SPI) Peripheral Chip Select Status
  656. // -------- SPI_SR : (SPI Offset: 0x10) Status Register --------
  657. # define AT91C_SPI_RDRF ((unsigned int) 0x1 << 0) // (SPI) Receive Data Register Full
  658. # define AT91C_SPI_TDRE ((unsigned int) 0x1 << 1) // (SPI) Transmit Data Register Empty
  659. # define AT91C_SPI_MODF ((unsigned int) 0x1 << 2) // (SPI) Mode Fault Error
  660. # define AT91C_SPI_OVRES ((unsigned int) 0x1 << 3) // (SPI) Overrun Error Status
  661. # define AT91C_SPI_ENDRX ((unsigned int) 0x1 << 4) // (SPI) End of Receiver Transfer
  662. # define AT91C_SPI_ENDTX ((unsigned int) 0x1 << 5) // (SPI) End of Receiver Transfer
  663. # define AT91C_SPI_RXBUFF ((unsigned int) 0x1 << 6) // (SPI) RXBUFF Interrupt
  664. # define AT91C_SPI_TXBUFE ((unsigned int) 0x1 << 7) // (SPI) TXBUFE Interrupt
  665. # define AT91C_SPI_NSSR ((unsigned int) 0x1 << 8) // (SPI) NSSR Interrupt
  666. # define AT91C_SPI_TXEMPTY ((unsigned int) 0x1 << 9) // (SPI) TXEMPTY Interrupt
  667. # define AT91C_SPI_SPIENS ((unsigned int) 0x1 << 16) // (SPI) Enable Status
  668. // -------- SPI_IER : (SPI Offset: 0x14) Interrupt Enable Register --------
  669. // -------- SPI_IDR : (SPI Offset: 0x18) Interrupt Disable Register --------
  670. // -------- SPI_IMR : (SPI Offset: 0x1c) Interrupt Mask Register --------
  671. // -------- SPI_CSR : (SPI Offset: 0x30) Chip Select Register --------
  672. # define AT91C_SPI_CPOL ((unsigned int) 0x1 << 0) // (SPI) Clock Polarity
  673. # define AT91C_SPI_NCPHA ((unsigned int) 0x1 << 1) // (SPI) Clock Phase
  674. # define AT91C_SPI_CSAAT ((unsigned int) 0x1 << 2) // (SPI) Chip Select Active After Transfer
  675. # define AT91C_SPI_BITS ((unsigned int) 0xF << 4) // (SPI) Bits Per Transfer
  676. # define AT91C_SPI_BITS_8 ((unsigned int) 0x0 << 4) // (SPI) 8 Bits Per transfer
  677. # define AT91C_SPI_BITS_9 ((unsigned int) 0x1 << 4) // (SPI) 9 Bits Per transfer
  678. # define AT91C_SPI_BITS_10 ((unsigned int) 0x2 << 4) // (SPI) 10 Bits Per transfer
  679. # define AT91C_SPI_BITS_11 ((unsigned int) 0x3 << 4) // (SPI) 11 Bits Per transfer
  680. # define AT91C_SPI_BITS_12 ((unsigned int) 0x4 << 4) // (SPI) 12 Bits Per transfer
  681. # define AT91C_SPI_BITS_13 ((unsigned int) 0x5 << 4) // (SPI) 13 Bits Per transfer
  682. # define AT91C_SPI_BITS_14 ((unsigned int) 0x6 << 4) // (SPI) 14 Bits Per transfer
  683. # define AT91C_SPI_BITS_15 ((unsigned int) 0x7 << 4) // (SPI) 15 Bits Per transfer
  684. # define AT91C_SPI_BITS_16 ((unsigned int) 0x8 << 4) // (SPI) 16 Bits Per transfer
  685. # define AT91C_SPI_SCBR ((unsigned int) 0xFF << 8) // (SPI) Serial Clock Baud Rate
  686. # define AT91C_SPI_DLYBS ((unsigned int) 0xFF << 16) // (SPI) Serial Clock Baud Rate
  687. # define AT91C_SPI_DLYBCT ((unsigned int) 0xFF << 24) // (SPI) Delay Between Consecutive Transfers
  688. // *****************************************************************************
  689. // SOFTWARE API DEFINITION FOR Analog to Digital Convertor
  690. // *****************************************************************************
  691. typedef struct _AT91S_ADC {
  692. AT91_REG ADC_CR; // ADC Control Register
  693. AT91_REG ADC_MR; // ADC Mode Register
  694. AT91_REG Reserved0[2]; //
  695. AT91_REG ADC_CHER; // ADC Channel Enable Register
  696. AT91_REG ADC_CHDR; // ADC Channel Disable Register
  697. AT91_REG ADC_CHSR; // ADC Channel Status Register
  698. AT91_REG ADC_SR; // ADC Status Register
  699. AT91_REG ADC_LCDR; // ADC Last Converted Data Register
  700. AT91_REG ADC_IER; // ADC Interrupt Enable Register
  701. AT91_REG ADC_IDR; // ADC Interrupt Disable Register
  702. AT91_REG ADC_IMR; // ADC Interrupt Mask Register
  703. AT91_REG ADC_CDR0; // ADC Channel Data Register 0
  704. AT91_REG ADC_CDR1; // ADC Channel Data Register 1
  705. AT91_REG ADC_CDR2; // ADC Channel Data Register 2
  706. AT91_REG ADC_CDR3; // ADC Channel Data Register 3
  707. AT91_REG ADC_CDR4; // ADC Channel Data Register 4
  708. AT91_REG ADC_CDR5; // ADC Channel Data Register 5
  709. AT91_REG ADC_CDR6; // ADC Channel Data Register 6
  710. AT91_REG ADC_CDR7; // ADC Channel Data Register 7
  711. AT91_REG Reserved1[44]; //
  712. AT91_REG ADC_RPR; // Receive Pointer Register
  713. AT91_REG ADC_RCR; // Receive Counter Register
  714. AT91_REG ADC_TPR; // Transmit Pointer Register
  715. AT91_REG ADC_TCR; // Transmit Counter Register
  716. AT91_REG ADC_RNPR; // Receive Next Pointer Register
  717. AT91_REG ADC_RNCR; // Receive Next Counter Register
  718. AT91_REG ADC_TNPR; // Transmit Next Pointer Register
  719. AT91_REG ADC_TNCR; // Transmit Next Counter Register
  720. AT91_REG ADC_PTCR; // PDC Transfer Control Register
  721. AT91_REG ADC_PTSR; // PDC Transfer Status Register
  722. } AT91S_ADC, *AT91PS_ADC;
  723. // -------- ADC_CR : (ADC Offset: 0x0) ADC Control Register --------
  724. # define A