hw_aes.h 26 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545
  1. //*****************************************************************************
  2. //
  3. // hw_aes.h - Macros used when accessing the AES hardware.
  4. //
  5. // Copyright (c) 2012-2014 Texas Instruments Incorporated. All rights reserved.
  6. // Software License Agreement
  7. //
  8. // Redistribution and use in source and binary forms, with or without
  9. // modification, are permitted provided that the following conditions
  10. // are met:
  11. //
  12. // Redistributions of source code must retain the above copyright
  13. // notice, this list of conditions and the following disclaimer.
  14. //
  15. // Redistributions in binary form must reproduce the above copyright
  16. // notice, this list of conditions and the following disclaimer in the
  17. // documentation and/or other materials provided with the
  18. // distribution.
  19. //
  20. // Neither the name of Texas Instruments Incorporated nor the names of
  21. // its contributors may be used to endorse or promote products derived
  22. // from this software without specific prior written permission.
  23. //
  24. // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
  25. // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
  26. // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
  27. // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
  28. // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  29. // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  30. // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
  31. // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
  32. // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
  33. // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
  34. // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  35. //
  36. // This is part of revision 2.1.0.12573 of the Tiva Firmware Development Package.
  37. //
  38. //*****************************************************************************
  39. #ifndef __HW_AES_H__
  40. #define __HW_AES_H__
  41. //*****************************************************************************
  42. //
  43. // The following are defines for the AES register offsets.
  44. //
  45. //*****************************************************************************
  46. #define AES_O_KEY2_6 0x00000000 // AES Key 2_6
  47. #define AES_O_KEY2_7 0x00000004 // AES Key 2_7
  48. #define AES_O_KEY2_4 0x00000008 // AES Key 2_4
  49. #define AES_O_KEY2_5 0x0000000C // AES Key 2_5
  50. #define AES_O_KEY2_2 0x00000010 // AES Key 2_2
  51. #define AES_O_KEY2_3 0x00000014 // AES Key 2_3
  52. #define AES_O_KEY2_0 0x00000018 // AES Key 2_0
  53. #define AES_O_KEY2_1 0x0000001C // AES Key 2_1
  54. #define AES_O_KEY1_6 0x00000020 // AES Key 1_6
  55. #define AES_O_KEY1_7 0x00000024 // AES Key 1_7
  56. #define AES_O_KEY1_4 0x00000028 // AES Key 1_4
  57. #define AES_O_KEY1_5 0x0000002C // AES Key 1_5
  58. #define AES_O_KEY1_2 0x00000030 // AES Key 1_2
  59. #define AES_O_KEY1_3 0x00000034 // AES Key 1_3
  60. #define AES_O_KEY1_0 0x00000038 // AES Key 1_0
  61. #define AES_O_KEY1_1 0x0000003C // AES Key 1_1
  62. #define AES_O_IV_IN_0 0x00000040 // AES Initialization Vector Input
  63. // 0
  64. #define AES_O_IV_IN_1 0x00000044 // AES Initialization Vector Input
  65. // 1
  66. #define AES_O_IV_IN_2 0x00000048 // AES Initialization Vector Input
  67. // 2
  68. #define AES_O_IV_IN_3 0x0000004C // AES Initialization Vector Input
  69. // 3
  70. #define AES_O_CTRL 0x00000050 // AES Control
  71. #define AES_O_C_LENGTH_0 0x00000054 // AES Crypto Data Length 0
  72. #define AES_O_C_LENGTH_1 0x00000058 // AES Crypto Data Length 1
  73. #define AES_O_AUTH_LENGTH 0x0000005C // AES Authentication Data Length
  74. #define AES_O_DATA_IN_0 0x00000060 // AES Data RW Plaintext/Ciphertext
  75. // 0
  76. #define AES_O_DATA_IN_1 0x00000064 // AES Data RW Plaintext/Ciphertext
  77. // 1
  78. #define AES_O_DATA_IN_2 0x00000068 // AES Data RW Plaintext/Ciphertext
  79. // 2
  80. #define AES_O_DATA_IN_3 0x0000006C // AES Data RW Plaintext/Ciphertext
  81. // 3
  82. #define AES_O_TAG_OUT_0 0x00000070 // AES Hash Tag Out 0
  83. #define AES_O_TAG_OUT_1 0x00000074 // AES Hash Tag Out 1
  84. #define AES_O_TAG_OUT_2 0x00000078 // AES Hash Tag Out 2
  85. #define AES_O_TAG_OUT_3 0x0000007C // AES Hash Tag Out 3
  86. #define AES_O_REVISION 0x00000080 // AES IP Revision Identifier
  87. #define AES_O_SYSCONFIG 0x00000084 // AES System Configuration
  88. #define AES_O_SYSSTATUS 0x00000088 // AES System Status
  89. #define AES_O_IRQSTATUS 0x0000008C // AES Interrupt Status
  90. #define AES_O_IRQENABLE 0x00000090 // AES Interrupt Enable
  91. #define AES_O_DIRTYBITS 0x00000094 // AES Dirty Bits
  92. #define AES_O_DMAIM 0xFFFFA020 // AES DMA Interrupt Mask
  93. #define AES_O_DMARIS 0xFFFFA024 // AES DMA Raw Interrupt Status
  94. #define AES_O_DMAMIS 0xFFFFA028 // AES DMA Masked Interrupt Status
  95. #define AES_O_DMAIC 0xFFFFA02C // AES DMA Interrupt Clear
  96. //*****************************************************************************
  97. //
  98. // The following are defines for the bit fields in the AES_O_KEY2_6 register.
  99. //
  100. //*****************************************************************************
  101. #define AES_KEY2_6_KEY_M 0xFFFFFFFF // Key Data
  102. #define AES_KEY2_6_KEY_S 0
  103. //*****************************************************************************
  104. //
  105. // The following are defines for the bit fields in the AES_O_KEY2_7 register.
  106. //
  107. //*****************************************************************************
  108. #define AES_KEY2_7_KEY_M 0xFFFFFFFF // Key Data
  109. #define AES_KEY2_7_KEY_S 0
  110. //*****************************************************************************
  111. //
  112. // The following are defines for the bit fields in the AES_O_KEY2_4 register.
  113. //
  114. //*****************************************************************************
  115. #define AES_KEY2_4_KEY_M 0xFFFFFFFF // Key Data
  116. #define AES_KEY2_4_KEY_S 0
  117. //*****************************************************************************
  118. //
  119. // The following are defines for the bit fields in the AES_O_KEY2_5 register.
  120. //
  121. //*****************************************************************************
  122. #define AES_KEY2_5_KEY_M 0xFFFFFFFF // Key Data
  123. #define AES_KEY2_5_KEY_S 0
  124. //*****************************************************************************
  125. //
  126. // The following are defines for the bit fields in the AES_O_KEY2_2 register.
  127. //
  128. //*****************************************************************************
  129. #define AES_KEY2_2_KEY_M 0xFFFFFFFF // Key Data
  130. #define AES_KEY2_2_KEY_S 0
  131. //*****************************************************************************
  132. //
  133. // The following are defines for the bit fields in the AES_O_KEY2_3 register.
  134. //
  135. //*****************************************************************************
  136. #define AES_KEY2_3_KEY_M 0xFFFFFFFF // Key Data
  137. #define AES_KEY2_3_KEY_S 0
  138. //*****************************************************************************
  139. //
  140. // The following are defines for the bit fields in the AES_O_KEY2_0 register.
  141. //
  142. //*****************************************************************************
  143. #define AES_KEY2_0_KEY_M 0xFFFFFFFF // Key Data
  144. #define AES_KEY2_0_KEY_S 0
  145. //*****************************************************************************
  146. //
  147. // The following are defines for the bit fields in the AES_O_KEY2_1 register.
  148. //
  149. //*****************************************************************************
  150. #define AES_KEY2_1_KEY_M 0xFFFFFFFF // Key Data
  151. #define AES_KEY2_1_KEY_S 0
  152. //*****************************************************************************
  153. //
  154. // The following are defines for the bit fields in the AES_O_KEY1_6 register.
  155. //
  156. //*****************************************************************************
  157. #define AES_KEY1_6_KEY_M 0xFFFFFFFF // Key Data
  158. #define AES_KEY1_6_KEY_S 0
  159. //*****************************************************************************
  160. //
  161. // The following are defines for the bit fields in the AES_O_KEY1_7 register.
  162. //
  163. //*****************************************************************************
  164. #define AES_KEY1_7_KEY_M 0xFFFFFFFF // Key Data
  165. #define AES_KEY1_7_KEY_S 0
  166. //*****************************************************************************
  167. //
  168. // The following are defines for the bit fields in the AES_O_KEY1_4 register.
  169. //
  170. //*****************************************************************************
  171. #define AES_KEY1_4_KEY_M 0xFFFFFFFF // Key Data
  172. #define AES_KEY1_4_KEY_S 0
  173. //*****************************************************************************
  174. //
  175. // The following are defines for the bit fields in the AES_O_KEY1_5 register.
  176. //
  177. //*****************************************************************************
  178. #define AES_KEY1_5_KEY_M 0xFFFFFFFF // Key Data
  179. #define AES_KEY1_5_KEY_S 0
  180. //*****************************************************************************
  181. //
  182. // The following are defines for the bit fields in the AES_O_KEY1_2 register.
  183. //
  184. //*****************************************************************************
  185. #define AES_KEY1_2_KEY_M 0xFFFFFFFF // Key Data
  186. #define AES_KEY1_2_KEY_S 0
  187. //*****************************************************************************
  188. //
  189. // The following are defines for the bit fields in the AES_O_KEY1_3 register.
  190. //
  191. //*****************************************************************************
  192. #define AES_KEY1_3_KEY_M 0xFFFFFFFF // Key Data
  193. #define AES_KEY1_3_KEY_S 0
  194. //*****************************************************************************
  195. //
  196. // The following are defines for the bit fields in the AES_O_KEY1_0 register.
  197. //
  198. //*****************************************************************************
  199. #define AES_KEY1_0_KEY_M 0xFFFFFFFF // Key Data
  200. #define AES_KEY1_0_KEY_S 0
  201. //*****************************************************************************
  202. //
  203. // The following are defines for the bit fields in the AES_O_KEY1_1 register.
  204. //
  205. //*****************************************************************************
  206. #define AES_KEY1_1_KEY_M 0xFFFFFFFF // Key Data
  207. #define AES_KEY1_1_KEY_S 0
  208. //*****************************************************************************
  209. //
  210. // The following are defines for the bit fields in the AES_O_IV_IN_0 register.
  211. //
  212. //*****************************************************************************
  213. #define AES_IV_IN_0_DATA_M 0xFFFFFFFF // Initialization Vector Input
  214. #define AES_IV_IN_0_DATA_S 0
  215. //*****************************************************************************
  216. //
  217. // The following are defines for the bit fields in the AES_O_IV_IN_1 register.
  218. //
  219. //*****************************************************************************
  220. #define AES_IV_IN_1_DATA_M 0xFFFFFFFF // Initialization Vector Input
  221. #define AES_IV_IN_1_DATA_S 0
  222. //*****************************************************************************
  223. //
  224. // The following are defines for the bit fields in the AES_O_IV_IN_2 register.
  225. //
  226. //*****************************************************************************
  227. #define AES_IV_IN_2_DATA_M 0xFFFFFFFF // Initialization Vector Input
  228. #define AES_IV_IN_2_DATA_S 0
  229. //*****************************************************************************
  230. //
  231. // The following are defines for the bit fields in the AES_O_IV_IN_3 register.
  232. //
  233. //*****************************************************************************
  234. #define AES_IV_IN_3_DATA_M 0xFFFFFFFF // Initialization Vector Input
  235. #define AES_IV_IN_3_DATA_S 0
  236. //*****************************************************************************
  237. //
  238. // The following are defines for the bit fields in the AES_O_CTRL register.
  239. //
  240. //*****************************************************************************
  241. #define AES_CTRL_CTXTRDY 0x80000000 // Context Data Registers Ready
  242. #define AES_CTRL_SVCTXTRDY 0x40000000 // AES TAG/IV Block(s) Ready
  243. #define AES_CTRL_SAVE_CONTEXT 0x20000000 // TAG or Result IV Save
  244. #define AES_CTRL_CCM_M_M 0x01C00000 // Counter with CBC-MAC (CCM)
  245. #define AES_CTRL_CCM_L_M 0x00380000 // L Value
  246. #define AES_CTRL_CCM_L_2 0x00080000 // width = 2
  247. #define AES_CTRL_CCM_L_4 0x00180000 // width = 4
  248. #define AES_CTRL_CCM_L_8 0x00380000 // width = 8
  249. #define AES_CTRL_CCM 0x00040000 // AES-CCM Mode Enable
  250. #define AES_CTRL_GCM_M 0x00030000 // AES-GCM Mode Enable
  251. #define AES_CTRL_GCM_NOP 0x00000000 // No operation
  252. #define AES_CTRL_GCM_HLY0ZERO 0x00010000 // GHASH with H loaded and
  253. // Y0-encrypted forced to zero
  254. #define AES_CTRL_GCM_HLY0CALC 0x00020000 // GHASH with H loaded and
  255. // Y0-encrypted calculated
  256. // internally
  257. #define AES_CTRL_GCM_HY0CALC 0x00030000 // Autonomous GHASH (both H and
  258. // Y0-encrypted calculated
  259. // internally)
  260. #define AES_CTRL_CBCMAC 0x00008000 // AES-CBC MAC Enable
  261. #define AES_CTRL_F9 0x00004000 // AES f9 Mode Enable
  262. #define AES_CTRL_F8 0x00002000 // AES f8 Mode Enable
  263. #define AES_CTRL_XTS_M 0x00001800 // AES-XTS Operation Enabled
  264. #define AES_CTRL_XTS_NOP 0x00000000 // No operation
  265. #define AES_CTRL_XTS_TWEAKJL 0x00000800 // Previous/intermediate tweak
  266. // value and j loaded (value is
  267. // loaded via IV, j is loaded via
  268. // the AAD length register)
  269. #define AES_CTRL_XTS_K2IJL 0x00001000 // Key2, n and j are loaded (n is
  270. // loaded via IV, j is loaded via
  271. // the AAD length register)
  272. #define AES_CTRL_XTS_K2ILJ0 0x00001800 // Key2 and n are loaded; j=0 (n is
  273. // loaded via IV)
  274. #define AES_CTRL_CFB 0x00000400 // Full block AES cipher feedback
  275. // mode (CFB128) Enable
  276. #define AES_CTRL_ICM 0x00000200 // AES Integer Counter Mode (ICM)
  277. // Enable
  278. #define AES_CTRL_CTR_WIDTH_M 0x00000180 // AES-CTR Mode Counter Width
  279. #define AES_CTRL_CTR_WIDTH_32 0x00000000 // Counter is 32 bits
  280. #define AES_CTRL_CTR_WIDTH_64 0x00000080 // Counter is 64 bits
  281. #define AES_CTRL_CTR_WIDTH_96 0x00000100 // Counter is 96 bits
  282. #define AES_CTRL_CTR_WIDTH_128 0x00000180 // Counter is 128 bits
  283. #define AES_CTRL_CTR 0x00000040 // Counter Mode
  284. #define AES_CTRL_MODE 0x00000020 // ECB/CBC Mode
  285. #define AES_CTRL_KEY_SIZE_M 0x00000018 // Key Size
  286. #define AES_CTRL_KEY_SIZE_128 0x00000008 // Key is 128 bits
  287. #define AES_CTRL_KEY_SIZE_192 0x00000010 // Key is 192 bits
  288. #define AES_CTRL_KEY_SIZE_256 0x00000018 // Key is 256 bits
  289. #define AES_CTRL_DIRECTION 0x00000004 // Encryption/Decryption Selection
  290. #define AES_CTRL_INPUT_READY 0x00000002 // Input Ready Status
  291. #define AES_CTRL_OUTPUT_READY 0x00000001 // Output Ready Status
  292. #define AES_CTRL_CCM_M_S 22
  293. //*****************************************************************************
  294. //
  295. // The following are defines for the bit fields in the AES_O_C_LENGTH_0
  296. // register.
  297. //
  298. //*****************************************************************************
  299. #define AES_C_LENGTH_0_LENGTH_M 0xFFFFFFFF // Data Length
  300. #define AES_C_LENGTH_0_LENGTH_S 0
  301. //*****************************************************************************
  302. //
  303. // The following are defines for the bit fields in the AES_O_C_LENGTH_1
  304. // register.
  305. //
  306. //*****************************************************************************
  307. #define AES_C_LENGTH_1_LENGTH_M 0xFFFFFFFF // Data Length
  308. #define AES_C_LENGTH_1_LENGTH_S 0
  309. //*****************************************************************************
  310. //
  311. // The following are defines for the bit fields in the AES_O_AUTH_LENGTH
  312. // register.
  313. //
  314. //*****************************************************************************
  315. #define AES_AUTH_LENGTH_AUTH_M 0xFFFFFFFF // Authentication Data Length
  316. #define AES_AUTH_LENGTH_AUTH_S 0
  317. //*****************************************************************************
  318. //
  319. // The following are defines for the bit fields in the AES_O_DATA_IN_0
  320. // register.
  321. //
  322. //*****************************************************************************
  323. #define AES_DATA_IN_0_DATA_M 0xFFFFFFFF // Secure Data RW
  324. // Plaintext/Ciphertext
  325. #define AES_DATA_IN_0_DATA_S 0
  326. //*****************************************************************************
  327. //
  328. // The following are defines for the bit fields in the AES_O_DATA_IN_1
  329. // register.
  330. //
  331. //*****************************************************************************
  332. #define AES_DATA_IN_1_DATA_M 0xFFFFFFFF // Secure Data RW
  333. // Plaintext/Ciphertext
  334. #define AES_DATA_IN_1_DATA_S 0
  335. //*****************************************************************************
  336. //
  337. // The following are defines for the bit fields in the AES_O_DATA_IN_2
  338. // register.
  339. //
  340. //*****************************************************************************
  341. #define AES_DATA_IN_2_DATA_M 0xFFFFFFFF // Secure Data RW
  342. // Plaintext/Ciphertext
  343. #define AES_DATA_IN_2_DATA_S 0
  344. //*****************************************************************************
  345. //
  346. // The following are defines for the bit fields in the AES_O_DATA_IN_3
  347. // register.
  348. //
  349. //*****************************************************************************
  350. #define AES_DATA_IN_3_DATA_M 0xFFFFFFFF // Secure Data RW
  351. // Plaintext/Ciphertext
  352. #define AES_DATA_IN_3_DATA_S 0
  353. //*****************************************************************************
  354. //
  355. // The following are defines for the bit fields in the AES_O_TAG_OUT_0
  356. // register.
  357. //
  358. //*****************************************************************************
  359. #define AES_TAG_OUT_0_HASH_M 0xFFFFFFFF // Hash Result
  360. #define AES_TAG_OUT_0_HASH_S 0
  361. //*****************************************************************************
  362. //
  363. // The following are defines for the bit fields in the AES_O_TAG_OUT_1
  364. // register.
  365. //
  366. //*****************************************************************************
  367. #define AES_TAG_OUT_1_HASH_M 0xFFFFFFFF // Hash Result
  368. #define AES_TAG_OUT_1_HASH_S 0
  369. //*****************************************************************************
  370. //
  371. // The following are defines for the bit fields in the AES_O_TAG_OUT_2
  372. // register.
  373. //
  374. //*****************************************************************************
  375. #define AES_TAG_OUT_2_HASH_M 0xFFFFFFFF // Hash Result
  376. #define AES_TAG_OUT_2_HASH_S 0
  377. //*****************************************************************************
  378. //
  379. // The following are defines for the bit fields in the AES_O_TAG_OUT_3
  380. // register.
  381. //
  382. //*****************************************************************************
  383. #define AES_TAG_OUT_3_HASH_M 0xFFFFFFFF // Hash Result
  384. #define AES_TAG_OUT_3_HASH_S 0
  385. //*****************************************************************************
  386. //
  387. // The following are defines for the bit fields in the AES_O_REVISION register.
  388. //
  389. //*****************************************************************************
  390. #define AES_REVISION_M 0xFFFFFFFF // Revision number
  391. #define AES_REVISION_S 0
  392. //*****************************************************************************
  393. //
  394. // The following are defines for the bit fields in the AES_O_SYSCONFIG
  395. // register.
  396. //
  397. //*****************************************************************************
  398. #define AES_SYSCONFIG_K3 0x00001000 // K3 Select
  399. #define AES_SYSCONFIG_KEYENC 0x00000800 // Key Encoding
  400. #define AES_SYSCONFIG_MAP_CONTEXT_OUT_ON_DATA_OUT \
  401. 0x00000200 // Map Context Out on Data Out
  402. // Enable
  403. #define AES_SYSCONFIG_DMA_REQ_CONTEXT_OUT_EN \
  404. 0x00000100 // DMA Request Context Out Enable
  405. #define AES_SYSCONFIG_DMA_REQ_CONTEXT_IN_EN \
  406. 0x00000080 // DMA Request Context In Enable
  407. #define AES_SYSCONFIG_DMA_REQ_DATA_OUT_EN \
  408. 0x00000040 // DMA Request Data Out Enable
  409. #define AES_SYSCONFIG_DMA_REQ_DATA_IN_EN \
  410. 0x00000020 // DMA Request Data In Enable
  411. #define AES_SYSCONFIG_SOFTRESET 0x00000002 // Soft reset
  412. //*****************************************************************************
  413. //
  414. // The following are defines for the bit fields in the AES_O_SYSSTATUS
  415. // register.
  416. //
  417. //*****************************************************************************
  418. #define AES_SYSSTATUS_RESETDONE 0x00000001 // Reset Done
  419. //*****************************************************************************
  420. //
  421. // The following are defines for the bit fields in the AES_O_IRQSTATUS
  422. // register.
  423. //
  424. //*****************************************************************************
  425. #define AES_IRQSTATUS_CONTEXT_OUT \
  426. 0x00000008 // Context Output Interrupt Status
  427. #define AES_IRQSTATUS_DATA_OUT 0x00000004 // Data Out Interrupt Status
  428. #define AES_IRQSTATUS_DATA_IN 0x00000002 // Data In Interrupt Status
  429. #define AES_IRQSTATUS_CONTEXT_IN \
  430. 0x00000001 // Context In Interrupt Status
  431. //*****************************************************************************
  432. //
  433. // The following are defines for the bit fields in the AES_O_IRQENABLE
  434. // register.
  435. //
  436. //*****************************************************************************
  437. #define AES_IRQENABLE_CONTEXT_OUT \
  438. 0x00000008 // Context Out Interrupt Enable
  439. #define AES_IRQENABLE_DATA_OUT 0x00000004 // Data Out Interrupt Enable
  440. #define AES_IRQENABLE_DATA_IN 0x00000002 // Data In Interrupt Enable
  441. #define AES_IRQENABLE_CONTEXT_IN \
  442. 0x00000001 // Context In Interrupt Enable
  443. //*****************************************************************************
  444. //
  445. // The following are defines for the bit fields in the AES_O_DIRTYBITS
  446. // register.
  447. //
  448. //*****************************************************************************
  449. #define AES_DIRTYBITS_S_DIRTY 0x00000002 // AES Dirty Bit
  450. #define AES_DIRTYBITS_S_ACCESS 0x00000001 // AES Access Bit
  451. //*****************************************************************************
  452. //
  453. // The following are defines for the bit fields in the AES_O_DMAIM register.
  454. //
  455. //*****************************************************************************
  456. #define AES_DMAIM_DOUT 0x00000008 // Data Out DMA Done Interrupt Mask
  457. #define AES_DMAIM_DIN 0x00000004 // Data In DMA Done Interrupt Mask
  458. #define AES_DMAIM_COUT 0x00000002 // Context Out DMA Done Interrupt
  459. // Mask
  460. #define AES_DMAIM_CIN 0x00000001 // Context In DMA Done Interrupt
  461. // Mask
  462. //*****************************************************************************
  463. //
  464. // The following are defines for the bit fields in the AES_O_DMARIS register.
  465. //
  466. //*****************************************************************************
  467. #define AES_DMARIS_DOUT 0x00000008 // Data Out DMA Done Raw Interrupt
  468. // Status
  469. #define AES_DMARIS_DIN 0x00000004 // Data In DMA Done Raw Interrupt
  470. // Status
  471. #define AES_DMARIS_COUT 0x00000002 // Context Out DMA Done Raw
  472. // Interrupt Status
  473. #define AES_DMARIS_CIN 0x00000001 // Context In DMA Done Raw
  474. // Interrupt Status
  475. //*****************************************************************************
  476. //
  477. // The following are defines for the bit fields in the AES_O_DMAMIS register.
  478. //
  479. //*****************************************************************************
  480. #define AES_DMAMIS_DOUT 0x00000008 // Data Out DMA Done Masked
  481. // Interrupt Status
  482. #define AES_DMAMIS_DIN 0x00000004 // Data In DMA Done Masked
  483. // Interrupt Status
  484. #define AES_DMAMIS_COUT 0x00000002 // Context Out DMA Done Masked
  485. // Interrupt Status
  486. #define AES_DMAMIS_CIN 0x00000001 // Context In DMA Done Raw
  487. // Interrupt Status
  488. //*****************************************************************************
  489. //
  490. // The following are defines for the bit fields in the AES_O_DMAIC register.
  491. //
  492. //*****************************************************************************
  493. #define AES_DMAIC_DOUT 0x00000008 // Data Out DMA Done Interrupt
  494. // Clear
  495. #define AES_DMAIC_DIN 0x00000004 // Data In DMA Done Interrupt Clear
  496. #define AES_DMAIC_COUT 0x00000002 // Context Out DMA Done Masked
  497. // Interrupt Status
  498. #define AES_DMAIC_CIN 0x00000001 // Context In DMA Done Raw
  499. // Interrupt Status
  500. #endif // __HW_AES_H__