Mercurial > public > ostc4
comparison Common/Drivers/STM32F4xx_HAL_Driver/Inc/stm32f4xx_hal_cryp_ex.h @ 160:e3ca52b8e7fa
Merge with FlipDisplay
author | heinrichsweikamp |
---|---|
date | Thu, 07 Mar 2019 15:06:43 +0100 |
parents | c78bcbd5deda |
children |
comparison
equal
deleted
inserted
replaced
80:cc2bb7bb8456 | 160:e3ca52b8e7fa |
---|---|
1 /** | |
2 ****************************************************************************** | |
3 * @file stm32f4xx_hal_cryp_ex.h | |
4 * @author MCD Application Team | |
5 * @brief Header file of CRYP HAL Extension module. | |
6 ****************************************************************************** | |
7 * @attention | |
8 * | |
9 * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2> | |
10 * | |
11 * Redistribution and use in source and binary forms, with or without modification, | |
12 * are permitted provided that the following conditions are met: | |
13 * 1. Redistributions of source code must retain the above copyright notice, | |
14 * this list of conditions and the following disclaimer. | |
15 * 2. Redistributions in binary form must reproduce the above copyright notice, | |
16 * this list of conditions and the following disclaimer in the documentation | |
17 * and/or other materials provided with the distribution. | |
18 * 3. Neither the name of STMicroelectronics nor the names of its contributors | |
19 * may be used to endorse or promote products derived from this software | |
20 * without specific prior written permission. | |
21 * | |
22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" | |
23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE | |
24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE | |
25 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE | |
26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL | |
27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR | |
28 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER | |
29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, | |
30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | |
31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
32 * | |
33 ****************************************************************************** | |
34 */ | |
35 | |
36 /* Define to prevent recursive inclusion -------------------------------------*/ | |
37 #ifndef __STM32F4xx_HAL_CRYP_EX_H | |
38 #define __STM32F4xx_HAL_CRYP_EX_H | |
39 | |
40 #ifdef __cplusplus | |
41 extern "C" { | |
42 #endif | |
43 | |
44 /* Includes ------------------------------------------------------------------*/ | |
45 #include "stm32f4xx_hal_def.h" | |
46 | |
47 | |
48 #if defined(CRYP) | |
49 | |
50 /** @addtogroup STM32F4xx_HAL_Driver | |
51 * @{ | |
52 */ | |
53 | |
54 /** @addtogroup CRYPEx | |
55 * @{ | |
56 */ | |
57 | |
58 /* Exported types ------------------------------------------------------------*/ | |
59 /* Exported constants --------------------------------------------------------*/ | |
60 | |
61 /** @defgroup CRYPEx_Exported_Constants CRYPEx Exported Constants | |
62 * @{ | |
63 */ | |
64 | |
65 /** @defgroup CRYPEx_Exported_Constants_Group1 CRYP AlgoModeDirection | |
66 * @{ | |
67 */ | |
68 #define CRYP_CR_ALGOMODE_AES_GCM_ENCRYPT 0x00080000U | |
69 #define CRYP_CR_ALGOMODE_AES_GCM_DECRYPT 0x00080004U | |
70 #define CRYP_CR_ALGOMODE_AES_CCM_ENCRYPT 0x00080008U | |
71 #define CRYP_CR_ALGOMODE_AES_CCM_DECRYPT 0x0008000CU | |
72 | |
73 /** | |
74 * @} | |
75 */ | |
76 | |
77 /** @defgroup CRYPEx_Exported_Constants_Group3 CRYP PhaseConfig | |
78 * @brief The phases are relevant only to AES-GCM and AES-CCM | |
79 * @{ | |
80 */ | |
81 #define CRYP_PHASE_INIT 0x00000000U | |
82 #define CRYP_PHASE_HEADER CRYP_CR_GCM_CCMPH_0 | |
83 #define CRYP_PHASE_PAYLOAD CRYP_CR_GCM_CCMPH_1 | |
84 #define CRYP_PHASE_FINAL CRYP_CR_GCM_CCMPH | |
85 /** | |
86 * @} | |
87 */ | |
88 | |
89 /** | |
90 * @} | |
91 */ | |
92 | |
93 /* Exported macro ------------------------------------------------------------*/ | |
94 /** @defgroup CRYPEx_Exported_Macros CRYP Exported Macros | |
95 * @{ | |
96 */ | |
97 | |
98 /** | |
99 * @brief Set the phase: Init, header, payload, final. | |
100 * This is relevant only for GCM and CCM modes. | |
101 * @param __HANDLE__ specifies the CRYP handle. | |
102 * @param __PHASE__ The phase. | |
103 * @retval None | |
104 */ | |
105 #define __HAL_CRYP_SET_PHASE(__HANDLE__, __PHASE__) do{(__HANDLE__)->Instance->CR &= (uint32_t)(~CRYP_CR_GCM_CCMPH);\ | |
106 (__HANDLE__)->Instance->CR |= (uint32_t)(__PHASE__);\ | |
107 }while(0) | |
108 | |
109 /** | |
110 * @} | |
111 */ | |
112 | |
113 /* Exported functions --------------------------------------------------------*/ | |
114 /** @defgroup CRYPEx_Exported_Functions CRYPEx Exported Functions | |
115 * @{ | |
116 */ | |
117 | |
118 /** @addtogroup CRYPEx_Exported_Functions_Group1 | |
119 * @{ | |
120 */ | |
121 | |
122 /* AES encryption/decryption using polling ***********************************/ | |
123 HAL_StatusTypeDef HAL_CRYPEx_AESGCM_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout); | |
124 HAL_StatusTypeDef HAL_CRYPEx_AESGCM_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout); | |
125 HAL_StatusTypeDef HAL_CRYPEx_AESGCM_Finish(CRYP_HandleTypeDef *hcryp, uint32_t Size, uint8_t *AuthTag, uint32_t Timeout); | |
126 HAL_StatusTypeDef HAL_CRYPEx_AESCCM_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout); | |
127 HAL_StatusTypeDef HAL_CRYPEx_AESCCM_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout); | |
128 HAL_StatusTypeDef HAL_CRYPEx_AESCCM_Finish(CRYP_HandleTypeDef *hcryp, uint8_t *AuthTag, uint32_t Timeout); | |
129 | |
130 /* AES encryption/decryption using interrupt *********************************/ | |
131 HAL_StatusTypeDef HAL_CRYPEx_AESGCM_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData); | |
132 HAL_StatusTypeDef HAL_CRYPEx_AESGCM_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData); | |
133 HAL_StatusTypeDef HAL_CRYPEx_AESCCM_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData); | |
134 HAL_StatusTypeDef HAL_CRYPEx_AESCCM_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData); | |
135 | |
136 /* AES encryption/decryption using DMA ***************************************/ | |
137 HAL_StatusTypeDef HAL_CRYPEx_AESGCM_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData); | |
138 HAL_StatusTypeDef HAL_CRYPEx_AESGCM_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData); | |
139 HAL_StatusTypeDef HAL_CRYPEx_AESCCM_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData); | |
140 HAL_StatusTypeDef HAL_CRYPEx_AESCCM_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData); | |
141 | |
142 /** | |
143 * @} | |
144 */ | |
145 | |
146 /** @addtogroup CRYPEx_Exported_Functions_Group2 | |
147 * @{ | |
148 */ | |
149 | |
150 void HAL_CRYPEx_GCMCCM_IRQHandler(CRYP_HandleTypeDef *hcryp); | |
151 | |
152 /** | |
153 * @} | |
154 */ | |
155 | |
156 /** | |
157 * @} | |
158 */ | |
159 | |
160 | |
161 /* Private types -------------------------------------------------------------*/ | |
162 /** @defgroup CRYPEx_Private_Types CRYPEx Private Types | |
163 * @{ | |
164 */ | |
165 | |
166 /** | |
167 * @} | |
168 */ | |
169 | |
170 /* Private variables ---------------------------------------------------------*/ | |
171 /** @defgroup CRYPEx_Private_Variables CRYPEx Private Variables | |
172 * @{ | |
173 */ | |
174 | |
175 /** | |
176 * @} | |
177 */ | |
178 | |
179 /* Private constants ---------------------------------------------------------*/ | |
180 /** @defgroup CRYPEx_Private_Constants CRYPEx Private Constants | |
181 * @{ | |
182 */ | |
183 | |
184 /** | |
185 * @} | |
186 */ | |
187 | |
188 /* Private macros ------------------------------------------------------------*/ | |
189 /** @defgroup CRYPEx_Private_Macros CRYPEx Private Macros | |
190 * @{ | |
191 */ | |
192 | |
193 /** | |
194 * @} | |
195 */ | |
196 | |
197 /* Private functions ---------------------------------------------------------*/ | |
198 /** @defgroup CRYPEx_Private_Functions CRYPEx Private Functions | |
199 * @{ | |
200 */ | |
201 | |
202 /** | |
203 * @} | |
204 */ | |
205 | |
206 #endif /* CRYP */ | |
207 | |
208 #if defined (AES) | |
209 | |
210 /** @addtogroup CRYPEx_Exported_Functions | |
211 * @{ | |
212 */ | |
213 | |
214 /** @addtogroup CRYPEx_Exported_Functions_Group1 | |
215 * @{ | |
216 */ | |
217 | |
218 /* CallBack functions ********************************************************/ | |
219 void HAL_CRYPEx_ComputationCpltCallback(CRYP_HandleTypeDef *hcryp); | |
220 | |
221 /** | |
222 * @} | |
223 */ | |
224 | |
225 /** @addtogroup CRYPEx_Exported_Functions_Group2 | |
226 * @{ | |
227 */ | |
228 | |
229 /* AES encryption/decryption processing functions ****************************/ | |
230 HAL_StatusTypeDef HAL_CRYPEx_AES(CRYP_HandleTypeDef *hcryp, uint8_t *pInputData, uint16_t Size, uint8_t *pOutputData, uint32_t Timeout); | |
231 HAL_StatusTypeDef HAL_CRYPEx_AES_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pInputData, uint16_t Size, uint8_t *pOutputData); | |
232 HAL_StatusTypeDef HAL_CRYPEx_AES_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pInputData, uint16_t Size, uint8_t *pOutputData); | |
233 | |
234 /* AES encryption/decryption/authentication processing functions *************/ | |
235 HAL_StatusTypeDef HAL_CRYPEx_AES_Auth(CRYP_HandleTypeDef *hcryp, uint8_t *pInputData, uint64_t Size, uint8_t *pOutputData, uint32_t Timeout); | |
236 HAL_StatusTypeDef HAL_CRYPEx_AES_Auth_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pInputData, uint64_t Size, uint8_t *pOutputData); | |
237 HAL_StatusTypeDef HAL_CRYPEx_AES_Auth_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pInputData, uint64_t Size, uint8_t *pOutputData); | |
238 | |
239 /** | |
240 * @} | |
241 */ | |
242 | |
243 /** @addtogroup CRYPEx_Exported_Functions_Group3 | |
244 * @{ | |
245 */ | |
246 | |
247 /* AES suspension/resumption functions ***************************************/ | |
248 void HAL_CRYPEx_Read_IVRegisters(CRYP_HandleTypeDef *hcryp, uint8_t* Output); | |
249 void HAL_CRYPEx_Write_IVRegisters(CRYP_HandleTypeDef *hcryp, uint8_t* Input); | |
250 void HAL_CRYPEx_Read_SuspendRegisters(CRYP_HandleTypeDef *hcryp, uint8_t* Output); | |
251 void HAL_CRYPEx_Write_SuspendRegisters(CRYP_HandleTypeDef *hcryp, uint8_t* Input); | |
252 void HAL_CRYPEx_Read_KeyRegisters(CRYP_HandleTypeDef *hcryp, uint8_t* Output, uint32_t KeySize); | |
253 void HAL_CRYPEx_Write_KeyRegisters(CRYP_HandleTypeDef *hcryp, uint8_t* Input, uint32_t KeySize); | |
254 void HAL_CRYPEx_Read_ControlRegister(CRYP_HandleTypeDef *hcryp, uint8_t* Output); | |
255 void HAL_CRYPEx_Write_ControlRegister(CRYP_HandleTypeDef *hcryp, uint8_t* Input); | |
256 void HAL_CRYPEx_ProcessSuspend(CRYP_HandleTypeDef *hcryp); | |
257 | |
258 /** | |
259 * @} | |
260 */ | |
261 | |
262 | |
263 /** | |
264 * @} | |
265 */ | |
266 | |
267 /* Private functions -----------------------------------------------------------*/ | |
268 /** @addtogroup CRYPEx_Private_Functions CRYPEx Private Functions | |
269 * @{ | |
270 */ | |
271 HAL_StatusTypeDef CRYP_AES_Auth_IT(CRYP_HandleTypeDef *hcryp); | |
272 | |
273 /** | |
274 * @} | |
275 */ | |
276 | |
277 #endif /* AES */ | |
278 | |
279 /** | |
280 * @} | |
281 */ | |
282 | |
283 /** | |
284 * @} | |
285 */ | |
286 | |
287 #ifdef __cplusplus | |
288 } | |
289 #endif | |
290 | |
291 #endif /* __STM32F4xx_HAL_CRYP_EX_H */ | |
292 | |
293 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |