Initial commit

Dependencies:   FastPWM

Committer:
lypinator
Date:
Wed Sep 16 01:11:49 2020 +0000
Revision:
0:bb348c97df44
Added PWM

Who changed what in which revision?

UserRevisionLine numberNew contents of line
lypinator 0:bb348c97df44 1 /**
lypinator 0:bb348c97df44 2 ******************************************************************************
lypinator 0:bb348c97df44 3 * @file stm32f4xx_hal_cryp.h
lypinator 0:bb348c97df44 4 * @author MCD Application Team
lypinator 0:bb348c97df44 5 * @brief Header file of CRYP HAL module.
lypinator 0:bb348c97df44 6 ******************************************************************************
lypinator 0:bb348c97df44 7 * @attention
lypinator 0:bb348c97df44 8 *
lypinator 0:bb348c97df44 9 * <h2><center>&copy; COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
lypinator 0:bb348c97df44 10 *
lypinator 0:bb348c97df44 11 * Redistribution and use in source and binary forms, with or without modification,
lypinator 0:bb348c97df44 12 * are permitted provided that the following conditions are met:
lypinator 0:bb348c97df44 13 * 1. Redistributions of source code must retain the above copyright notice,
lypinator 0:bb348c97df44 14 * this list of conditions and the following disclaimer.
lypinator 0:bb348c97df44 15 * 2. Redistributions in binary form must reproduce the above copyright notice,
lypinator 0:bb348c97df44 16 * this list of conditions and the following disclaimer in the documentation
lypinator 0:bb348c97df44 17 * and/or other materials provided with the distribution.
lypinator 0:bb348c97df44 18 * 3. Neither the name of STMicroelectronics nor the names of its contributors
lypinator 0:bb348c97df44 19 * may be used to endorse or promote products derived from this software
lypinator 0:bb348c97df44 20 * without specific prior written permission.
lypinator 0:bb348c97df44 21 *
lypinator 0:bb348c97df44 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
lypinator 0:bb348c97df44 23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
lypinator 0:bb348c97df44 24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
lypinator 0:bb348c97df44 25 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
lypinator 0:bb348c97df44 26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
lypinator 0:bb348c97df44 27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
lypinator 0:bb348c97df44 28 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
lypinator 0:bb348c97df44 29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
lypinator 0:bb348c97df44 30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
lypinator 0:bb348c97df44 31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
lypinator 0:bb348c97df44 32 *
lypinator 0:bb348c97df44 33 ******************************************************************************
lypinator 0:bb348c97df44 34 */
lypinator 0:bb348c97df44 35
lypinator 0:bb348c97df44 36 /* Define to prevent recursive inclusion -------------------------------------*/
lypinator 0:bb348c97df44 37 #ifndef __STM32F4xx_HAL_CRYP_H
lypinator 0:bb348c97df44 38 #define __STM32F4xx_HAL_CRYP_H
lypinator 0:bb348c97df44 39
lypinator 0:bb348c97df44 40 #ifdef __cplusplus
lypinator 0:bb348c97df44 41 extern "C" {
lypinator 0:bb348c97df44 42 #endif
lypinator 0:bb348c97df44 43
lypinator 0:bb348c97df44 44 /* Includes ------------------------------------------------------------------*/
lypinator 0:bb348c97df44 45 #include "stm32f4xx_hal_def.h"
lypinator 0:bb348c97df44 46
lypinator 0:bb348c97df44 47
lypinator 0:bb348c97df44 48 #if defined(CRYP)
lypinator 0:bb348c97df44 49
lypinator 0:bb348c97df44 50 /** @addtogroup STM32F4xx_HAL_Driver
lypinator 0:bb348c97df44 51 * @{
lypinator 0:bb348c97df44 52 */
lypinator 0:bb348c97df44 53
lypinator 0:bb348c97df44 54 /** @addtogroup CRYP
lypinator 0:bb348c97df44 55 * @{
lypinator 0:bb348c97df44 56 */
lypinator 0:bb348c97df44 57
lypinator 0:bb348c97df44 58 /* Exported types ------------------------------------------------------------*/
lypinator 0:bb348c97df44 59
lypinator 0:bb348c97df44 60 /** @defgroup CRYP_Exported_Types CRYP Exported Types
lypinator 0:bb348c97df44 61 * @{
lypinator 0:bb348c97df44 62 */
lypinator 0:bb348c97df44 63
lypinator 0:bb348c97df44 64 /** @defgroup CRYP_Exported_Types_Group1 CRYP Configuration Structure definition
lypinator 0:bb348c97df44 65 * @{
lypinator 0:bb348c97df44 66 */
lypinator 0:bb348c97df44 67
lypinator 0:bb348c97df44 68 typedef struct
lypinator 0:bb348c97df44 69 {
lypinator 0:bb348c97df44 70 uint32_t DataType; /*!< 32-bit data, 16-bit data, 8-bit data or 1-bit string.
lypinator 0:bb348c97df44 71 This parameter can be a value of @ref CRYP_Data_Type */
lypinator 0:bb348c97df44 72
lypinator 0:bb348c97df44 73 uint32_t KeySize; /*!< Used only in AES mode only : 128, 192 or 256 bit key length.
lypinator 0:bb348c97df44 74 This parameter can be a value of @ref CRYP_Key_Size */
lypinator 0:bb348c97df44 75
lypinator 0:bb348c97df44 76 uint8_t* pKey; /*!< The key used for encryption/decryption */
lypinator 0:bb348c97df44 77
lypinator 0:bb348c97df44 78 uint8_t* pInitVect; /*!< The initialization vector used also as initialization
lypinator 0:bb348c97df44 79 counter in CTR mode */
lypinator 0:bb348c97df44 80
lypinator 0:bb348c97df44 81 uint8_t IVSize; /*!< The size of initialization vector.
lypinator 0:bb348c97df44 82 This parameter (called nonce size in CCM) is used only
lypinator 0:bb348c97df44 83 in AES-128/192/256 encryption/decryption CCM mode */
lypinator 0:bb348c97df44 84
lypinator 0:bb348c97df44 85 uint8_t TagSize; /*!< The size of returned authentication TAG.
lypinator 0:bb348c97df44 86 This parameter is used only in AES-128/192/256
lypinator 0:bb348c97df44 87 encryption/decryption CCM mode */
lypinator 0:bb348c97df44 88
lypinator 0:bb348c97df44 89 uint8_t* Header; /*!< The header used in GCM and CCM modes */
lypinator 0:bb348c97df44 90
lypinator 0:bb348c97df44 91 uint32_t HeaderSize; /*!< The size of header buffer in bytes */
lypinator 0:bb348c97df44 92
lypinator 0:bb348c97df44 93 uint8_t* pScratch; /*!< Scratch buffer used to append the header. It's size must be equal to header size + 21 bytes.
lypinator 0:bb348c97df44 94 This parameter is used only in AES-128/192/256 encryption/decryption CCM mode */
lypinator 0:bb348c97df44 95 }CRYP_InitTypeDef;
lypinator 0:bb348c97df44 96
lypinator 0:bb348c97df44 97 /**
lypinator 0:bb348c97df44 98 * @}
lypinator 0:bb348c97df44 99 */
lypinator 0:bb348c97df44 100
lypinator 0:bb348c97df44 101 /** @defgroup CRYP_Exported_Types_Group2 CRYP State structures definition
lypinator 0:bb348c97df44 102 * @{
lypinator 0:bb348c97df44 103 */
lypinator 0:bb348c97df44 104
lypinator 0:bb348c97df44 105
lypinator 0:bb348c97df44 106 typedef enum
lypinator 0:bb348c97df44 107 {
lypinator 0:bb348c97df44 108 HAL_CRYP_STATE_RESET = 0x00U, /*!< CRYP not yet initialized or disabled */
lypinator 0:bb348c97df44 109 HAL_CRYP_STATE_READY = 0x01U, /*!< CRYP initialized and ready for use */
lypinator 0:bb348c97df44 110 HAL_CRYP_STATE_BUSY = 0x02U, /*!< CRYP internal processing is ongoing */
lypinator 0:bb348c97df44 111 HAL_CRYP_STATE_TIMEOUT = 0x03U, /*!< CRYP timeout state */
lypinator 0:bb348c97df44 112 HAL_CRYP_STATE_ERROR = 0x04U /*!< CRYP error state */
lypinator 0:bb348c97df44 113 }HAL_CRYP_STATETypeDef;
lypinator 0:bb348c97df44 114
lypinator 0:bb348c97df44 115 /**
lypinator 0:bb348c97df44 116 * @}
lypinator 0:bb348c97df44 117 */
lypinator 0:bb348c97df44 118
lypinator 0:bb348c97df44 119 /** @defgroup CRYP_Exported_Types_Group3 CRYP phase structures definition
lypinator 0:bb348c97df44 120 * @{
lypinator 0:bb348c97df44 121 */
lypinator 0:bb348c97df44 122
lypinator 0:bb348c97df44 123
lypinator 0:bb348c97df44 124 typedef enum
lypinator 0:bb348c97df44 125 {
lypinator 0:bb348c97df44 126 HAL_CRYP_PHASE_READY = 0x01U, /*!< CRYP peripheral is ready for initialization. */
lypinator 0:bb348c97df44 127 HAL_CRYP_PHASE_PROCESS = 0x02U, /*!< CRYP peripheral is in processing phase */
lypinator 0:bb348c97df44 128 HAL_CRYP_PHASE_FINAL = 0x03U /*!< CRYP peripheral is in final phase
lypinator 0:bb348c97df44 129 This is relevant only with CCM and GCM modes */
lypinator 0:bb348c97df44 130 }HAL_PhaseTypeDef;
lypinator 0:bb348c97df44 131
lypinator 0:bb348c97df44 132 /**
lypinator 0:bb348c97df44 133 * @}
lypinator 0:bb348c97df44 134 */
lypinator 0:bb348c97df44 135
lypinator 0:bb348c97df44 136 /** @defgroup CRYP_Exported_Types_Group4 CRYP handle Structure definition
lypinator 0:bb348c97df44 137 * @{
lypinator 0:bb348c97df44 138 */
lypinator 0:bb348c97df44 139
lypinator 0:bb348c97df44 140 typedef struct
lypinator 0:bb348c97df44 141 {
lypinator 0:bb348c97df44 142 CRYP_TypeDef *Instance; /*!< CRYP registers base address */
lypinator 0:bb348c97df44 143
lypinator 0:bb348c97df44 144 CRYP_InitTypeDef Init; /*!< CRYP required parameters */
lypinator 0:bb348c97df44 145
lypinator 0:bb348c97df44 146 uint8_t *pCrypInBuffPtr; /*!< Pointer to CRYP processing (encryption, decryption,...) buffer */
lypinator 0:bb348c97df44 147
lypinator 0:bb348c97df44 148 uint8_t *pCrypOutBuffPtr; /*!< Pointer to CRYP processing (encryption, decryption,...) buffer */
lypinator 0:bb348c97df44 149
lypinator 0:bb348c97df44 150 __IO uint16_t CrypInCount; /*!< Counter of inputed data */
lypinator 0:bb348c97df44 151
lypinator 0:bb348c97df44 152 __IO uint16_t CrypOutCount; /*!< Counter of output data */
lypinator 0:bb348c97df44 153
lypinator 0:bb348c97df44 154 HAL_StatusTypeDef Status; /*!< CRYP peripheral status */
lypinator 0:bb348c97df44 155
lypinator 0:bb348c97df44 156 HAL_PhaseTypeDef Phase; /*!< CRYP peripheral phase */
lypinator 0:bb348c97df44 157
lypinator 0:bb348c97df44 158 DMA_HandleTypeDef *hdmain; /*!< CRYP In DMA handle parameters */
lypinator 0:bb348c97df44 159
lypinator 0:bb348c97df44 160 DMA_HandleTypeDef *hdmaout; /*!< CRYP Out DMA handle parameters */
lypinator 0:bb348c97df44 161
lypinator 0:bb348c97df44 162 HAL_LockTypeDef Lock; /*!< CRYP locking object */
lypinator 0:bb348c97df44 163
lypinator 0:bb348c97df44 164 __IO HAL_CRYP_STATETypeDef State; /*!< CRYP peripheral state */
lypinator 0:bb348c97df44 165 }CRYP_HandleTypeDef;
lypinator 0:bb348c97df44 166
lypinator 0:bb348c97df44 167 /**
lypinator 0:bb348c97df44 168 * @}
lypinator 0:bb348c97df44 169 */
lypinator 0:bb348c97df44 170
lypinator 0:bb348c97df44 171 /**
lypinator 0:bb348c97df44 172 * @}
lypinator 0:bb348c97df44 173 */
lypinator 0:bb348c97df44 174
lypinator 0:bb348c97df44 175 /* Exported constants --------------------------------------------------------*/
lypinator 0:bb348c97df44 176 /** @defgroup CRYP_Exported_Constants CRYP Exported Constants
lypinator 0:bb348c97df44 177 * @{
lypinator 0:bb348c97df44 178 */
lypinator 0:bb348c97df44 179
lypinator 0:bb348c97df44 180 /** @defgroup CRYP_Key_Size CRYP Key Size
lypinator 0:bb348c97df44 181 * @{
lypinator 0:bb348c97df44 182 */
lypinator 0:bb348c97df44 183 #define CRYP_KEYSIZE_128B 0x00000000U
lypinator 0:bb348c97df44 184 #define CRYP_KEYSIZE_192B CRYP_CR_KEYSIZE_0
lypinator 0:bb348c97df44 185 #define CRYP_KEYSIZE_256B CRYP_CR_KEYSIZE_1
lypinator 0:bb348c97df44 186 /**
lypinator 0:bb348c97df44 187 * @}
lypinator 0:bb348c97df44 188 */
lypinator 0:bb348c97df44 189
lypinator 0:bb348c97df44 190 /** @defgroup CRYP_Data_Type CRYP Data Type
lypinator 0:bb348c97df44 191 * @{
lypinator 0:bb348c97df44 192 */
lypinator 0:bb348c97df44 193 #define CRYP_DATATYPE_32B 0x00000000U
lypinator 0:bb348c97df44 194 #define CRYP_DATATYPE_16B CRYP_CR_DATATYPE_0
lypinator 0:bb348c97df44 195 #define CRYP_DATATYPE_8B CRYP_CR_DATATYPE_1
lypinator 0:bb348c97df44 196 #define CRYP_DATATYPE_1B CRYP_CR_DATATYPE
lypinator 0:bb348c97df44 197 /**
lypinator 0:bb348c97df44 198 * @}
lypinator 0:bb348c97df44 199 */
lypinator 0:bb348c97df44 200
lypinator 0:bb348c97df44 201 /** @defgroup CRYP_Exported_Constants_Group3 CRYP CRYP_AlgoModeDirection
lypinator 0:bb348c97df44 202 * @{
lypinator 0:bb348c97df44 203 */
lypinator 0:bb348c97df44 204 #define CRYP_CR_ALGOMODE_DIRECTION 0x0008003CU
lypinator 0:bb348c97df44 205 #define CRYP_CR_ALGOMODE_TDES_ECB_ENCRYPT 0x00000000U
lypinator 0:bb348c97df44 206 #define CRYP_CR_ALGOMODE_TDES_ECB_DECRYPT 0x00000004U
lypinator 0:bb348c97df44 207 #define CRYP_CR_ALGOMODE_TDES_CBC_ENCRYPT 0x00000008U
lypinator 0:bb348c97df44 208 #define CRYP_CR_ALGOMODE_TDES_CBC_DECRYPT 0x0000000CU
lypinator 0:bb348c97df44 209 #define CRYP_CR_ALGOMODE_DES_ECB_ENCRYPT 0x00000010U
lypinator 0:bb348c97df44 210 #define CRYP_CR_ALGOMODE_DES_ECB_DECRYPT 0x00000014U
lypinator 0:bb348c97df44 211 #define CRYP_CR_ALGOMODE_DES_CBC_ENCRYPT 0x00000018U
lypinator 0:bb348c97df44 212 #define CRYP_CR_ALGOMODE_DES_CBC_DECRYPT 0x0000001CU
lypinator 0:bb348c97df44 213 #define CRYP_CR_ALGOMODE_AES_ECB_ENCRYPT 0x00000020U
lypinator 0:bb348c97df44 214 #define CRYP_CR_ALGOMODE_AES_ECB_DECRYPT 0x00000024U
lypinator 0:bb348c97df44 215 #define CRYP_CR_ALGOMODE_AES_CBC_ENCRYPT 0x00000028U
lypinator 0:bb348c97df44 216 #define CRYP_CR_ALGOMODE_AES_CBC_DECRYPT 0x0000002CU
lypinator 0:bb348c97df44 217 #define CRYP_CR_ALGOMODE_AES_CTR_ENCRYPT 0x00000030U
lypinator 0:bb348c97df44 218 #define CRYP_CR_ALGOMODE_AES_CTR_DECRYPT 0x00000034U
lypinator 0:bb348c97df44 219 /**
lypinator 0:bb348c97df44 220 * @}
lypinator 0:bb348c97df44 221 */
lypinator 0:bb348c97df44 222
lypinator 0:bb348c97df44 223 /** @defgroup CRYP_Exported_Constants_Group4 CRYP CRYP_Interrupt
lypinator 0:bb348c97df44 224 * @{
lypinator 0:bb348c97df44 225 */
lypinator 0:bb348c97df44 226 #define CRYP_IT_INI ((uint32_t)CRYP_IMSCR_INIM) /*!< Input FIFO Interrupt */
lypinator 0:bb348c97df44 227 #define CRYP_IT_OUTI ((uint32_t)CRYP_IMSCR_OUTIM) /*!< Output FIFO Interrupt */
lypinator 0:bb348c97df44 228 /**
lypinator 0:bb348c97df44 229 * @}
lypinator 0:bb348c97df44 230 */
lypinator 0:bb348c97df44 231
lypinator 0:bb348c97df44 232 /** @defgroup CRYP_Exported_Constants_Group5 CRYP CRYP_Flags
lypinator 0:bb348c97df44 233 * @{
lypinator 0:bb348c97df44 234 */
lypinator 0:bb348c97df44 235 #define CRYP_FLAG_BUSY 0x00000010U /*!< The CRYP core is currently
lypinator 0:bb348c97df44 236 processing a block of data
lypinator 0:bb348c97df44 237 or a key preparation (for
lypinator 0:bb348c97df44 238 AES decryption). */
lypinator 0:bb348c97df44 239 #define CRYP_FLAG_IFEM 0x00000001U /*!< Input FIFO is empty */
lypinator 0:bb348c97df44 240 #define CRYP_FLAG_IFNF 0x00000002U /*!< Input FIFO is not Full */
lypinator 0:bb348c97df44 241 #define CRYP_FLAG_OFNE 0x00000004U /*!< Output FIFO is not empty */
lypinator 0:bb348c97df44 242 #define CRYP_FLAG_OFFU 0x00000008U /*!< Output FIFO is Full */
lypinator 0:bb348c97df44 243 #define CRYP_FLAG_OUTRIS 0x01000002U /*!< Output FIFO service raw
lypinator 0:bb348c97df44 244 interrupt status */
lypinator 0:bb348c97df44 245 #define CRYP_FLAG_INRIS 0x01000001U /*!< Input FIFO service raw
lypinator 0:bb348c97df44 246 interrupt status */
lypinator 0:bb348c97df44 247 /**
lypinator 0:bb348c97df44 248 * @}
lypinator 0:bb348c97df44 249 */
lypinator 0:bb348c97df44 250
lypinator 0:bb348c97df44 251 /**
lypinator 0:bb348c97df44 252 * @}
lypinator 0:bb348c97df44 253 */
lypinator 0:bb348c97df44 254
lypinator 0:bb348c97df44 255 /* Exported macro ------------------------------------------------------------*/
lypinator 0:bb348c97df44 256 /** @defgroup CRYP_Exported_Macros CRYP Exported Macros
lypinator 0:bb348c97df44 257 * @{
lypinator 0:bb348c97df44 258 */
lypinator 0:bb348c97df44 259
lypinator 0:bb348c97df44 260 /** @brief Reset CRYP handle state
lypinator 0:bb348c97df44 261 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 262 * @retval None
lypinator 0:bb348c97df44 263 */
lypinator 0:bb348c97df44 264 #define __HAL_CRYP_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_CRYP_STATE_RESET)
lypinator 0:bb348c97df44 265
lypinator 0:bb348c97df44 266 /**
lypinator 0:bb348c97df44 267 * @brief Enable/Disable the CRYP peripheral.
lypinator 0:bb348c97df44 268 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 269 * @retval None
lypinator 0:bb348c97df44 270 */
lypinator 0:bb348c97df44 271 #define __HAL_CRYP_ENABLE(__HANDLE__) ((__HANDLE__)->Instance->CR |= CRYP_CR_CRYPEN)
lypinator 0:bb348c97df44 272 #define __HAL_CRYP_DISABLE(__HANDLE__) ((__HANDLE__)->Instance->CR &= ~CRYP_CR_CRYPEN)
lypinator 0:bb348c97df44 273
lypinator 0:bb348c97df44 274 /**
lypinator 0:bb348c97df44 275 * @brief Flush the data FIFO.
lypinator 0:bb348c97df44 276 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 277 * @retval None
lypinator 0:bb348c97df44 278 */
lypinator 0:bb348c97df44 279 #define __HAL_CRYP_FIFO_FLUSH(__HANDLE__) ((__HANDLE__)->Instance->CR |= CRYP_CR_FFLUSH)
lypinator 0:bb348c97df44 280
lypinator 0:bb348c97df44 281 /**
lypinator 0:bb348c97df44 282 * @brief Set the algorithm mode: AES-ECB, AES-CBC, AES-CTR, DES-ECB, DES-CBC.
lypinator 0:bb348c97df44 283 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 284 * @param MODE The algorithm mode.
lypinator 0:bb348c97df44 285 * @retval None
lypinator 0:bb348c97df44 286 */
lypinator 0:bb348c97df44 287 #define __HAL_CRYP_SET_MODE(__HANDLE__, MODE) ((__HANDLE__)->Instance->CR |= (uint32_t)(MODE))
lypinator 0:bb348c97df44 288
lypinator 0:bb348c97df44 289 /** @brief Check whether the specified CRYP flag is set or not.
lypinator 0:bb348c97df44 290 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 291 * @param __FLAG__ specifies the flag to check.
lypinator 0:bb348c97df44 292 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 293 * @arg CRYP_FLAG_BUSY: The CRYP core is currently processing a block of data
lypinator 0:bb348c97df44 294 * or a key preparation (for AES decryption).
lypinator 0:bb348c97df44 295 * @arg CRYP_FLAG_IFEM: Input FIFO is empty
lypinator 0:bb348c97df44 296 * @arg CRYP_FLAG_IFNF: Input FIFO is not full
lypinator 0:bb348c97df44 297 * @arg CRYP_FLAG_INRIS: Input FIFO service raw interrupt is pending
lypinator 0:bb348c97df44 298 * @arg CRYP_FLAG_OFNE: Output FIFO is not empty
lypinator 0:bb348c97df44 299 * @arg CRYP_FLAG_OFFU: Output FIFO is full
lypinator 0:bb348c97df44 300 * @arg CRYP_FLAG_OUTRIS: Input FIFO service raw interrupt is pending
lypinator 0:bb348c97df44 301 * @retval The new state of __FLAG__ (TRUE or FALSE).
lypinator 0:bb348c97df44 302 */
lypinator 0:bb348c97df44 303
lypinator 0:bb348c97df44 304 #define __HAL_CRYP_GET_FLAG(__HANDLE__, __FLAG__) ((((uint8_t)((__FLAG__) >> 24U)) == 0x01U)?((((__HANDLE__)->Instance->RISR) & ((__FLAG__) & CRYP_FLAG_MASK)) == ((__FLAG__) & CRYP_FLAG_MASK)): \
lypinator 0:bb348c97df44 305 ((((__HANDLE__)->Instance->RISR) & ((__FLAG__) & CRYP_FLAG_MASK)) == ((__FLAG__) & CRYP_FLAG_MASK)))
lypinator 0:bb348c97df44 306
lypinator 0:bb348c97df44 307 /** @brief Check whether the specified CRYP interrupt is set or not.
lypinator 0:bb348c97df44 308 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 309 * @param __INTERRUPT__ specifies the interrupt to check.
lypinator 0:bb348c97df44 310 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 311 * @arg CRYP_IT_INRIS: Input FIFO service raw interrupt is pending
lypinator 0:bb348c97df44 312 * @arg CRYP_IT_OUTRIS: Output FIFO service raw interrupt is pending
lypinator 0:bb348c97df44 313 * @retval The new state of __INTERRUPT__ (TRUE or FALSE).
lypinator 0:bb348c97df44 314 */
lypinator 0:bb348c97df44 315 #define __HAL_CRYP_GET_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->MISR & (__INTERRUPT__)) == (__INTERRUPT__))
lypinator 0:bb348c97df44 316
lypinator 0:bb348c97df44 317 /**
lypinator 0:bb348c97df44 318 * @brief Enable the CRYP interrupt.
lypinator 0:bb348c97df44 319 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 320 * @param __INTERRUPT__ CRYP Interrupt.
lypinator 0:bb348c97df44 321 * @retval None
lypinator 0:bb348c97df44 322 */
lypinator 0:bb348c97df44 323 #define __HAL_CRYP_ENABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->IMSCR) |= (__INTERRUPT__))
lypinator 0:bb348c97df44 324
lypinator 0:bb348c97df44 325 /**
lypinator 0:bb348c97df44 326 * @brief Disable the CRYP interrupt.
lypinator 0:bb348c97df44 327 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 328 * @param __INTERRUPT__ CRYP interrupt.
lypinator 0:bb348c97df44 329 * @retval None
lypinator 0:bb348c97df44 330 */
lypinator 0:bb348c97df44 331 #define __HAL_CRYP_DISABLE_IT(__HANDLE__, __INTERRUPT__) (((__HANDLE__)->Instance->IMSCR) &= ~(__INTERRUPT__))
lypinator 0:bb348c97df44 332
lypinator 0:bb348c97df44 333 /**
lypinator 0:bb348c97df44 334 * @}
lypinator 0:bb348c97df44 335 */
lypinator 0:bb348c97df44 336
lypinator 0:bb348c97df44 337 /* Include CRYP HAL Extension module */
lypinator 0:bb348c97df44 338 #include "stm32f4xx_hal_cryp_ex.h"
lypinator 0:bb348c97df44 339
lypinator 0:bb348c97df44 340 /* Exported functions --------------------------------------------------------*/
lypinator 0:bb348c97df44 341 /** @defgroup CRYP_Exported_Functions CRYP Exported Functions
lypinator 0:bb348c97df44 342 * @{
lypinator 0:bb348c97df44 343 */
lypinator 0:bb348c97df44 344
lypinator 0:bb348c97df44 345 /** @addtogroup CRYP_Exported_Functions_Group1
lypinator 0:bb348c97df44 346 * @{
lypinator 0:bb348c97df44 347 */
lypinator 0:bb348c97df44 348 HAL_StatusTypeDef HAL_CRYP_Init(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 349 HAL_StatusTypeDef HAL_CRYP_DeInit(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 350 void HAL_CRYP_MspInit(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 351 void HAL_CRYP_MspDeInit(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 352 /**
lypinator 0:bb348c97df44 353 * @}
lypinator 0:bb348c97df44 354 */
lypinator 0:bb348c97df44 355
lypinator 0:bb348c97df44 356 /** @addtogroup CRYP_Exported_Functions_Group2
lypinator 0:bb348c97df44 357 * @{
lypinator 0:bb348c97df44 358 */
lypinator 0:bb348c97df44 359 /* AES encryption/decryption using polling ***********************************/
lypinator 0:bb348c97df44 360 HAL_StatusTypeDef HAL_CRYP_AESECB_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 361 HAL_StatusTypeDef HAL_CRYP_AESECB_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 362 HAL_StatusTypeDef HAL_CRYP_AESCBC_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 363 HAL_StatusTypeDef HAL_CRYP_AESCBC_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 364 HAL_StatusTypeDef HAL_CRYP_AESCTR_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 365 HAL_StatusTypeDef HAL_CRYP_AESCTR_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 366
lypinator 0:bb348c97df44 367 /* AES encryption/decryption using interrupt *********************************/
lypinator 0:bb348c97df44 368 HAL_StatusTypeDef HAL_CRYP_AESECB_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 369 HAL_StatusTypeDef HAL_CRYP_AESCBC_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 370 HAL_StatusTypeDef HAL_CRYP_AESCTR_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 371 HAL_StatusTypeDef HAL_CRYP_AESECB_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 372 HAL_StatusTypeDef HAL_CRYP_AESCTR_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 373 HAL_StatusTypeDef HAL_CRYP_AESCBC_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 374
lypinator 0:bb348c97df44 375 /* AES encryption/decryption using DMA ***************************************/
lypinator 0:bb348c97df44 376 HAL_StatusTypeDef HAL_CRYP_AESECB_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 377 HAL_StatusTypeDef HAL_CRYP_AESECB_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 378 HAL_StatusTypeDef HAL_CRYP_AESCBC_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 379 HAL_StatusTypeDef HAL_CRYP_AESCBC_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 380 HAL_StatusTypeDef HAL_CRYP_AESCTR_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 381 HAL_StatusTypeDef HAL_CRYP_AESCTR_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 382 /**
lypinator 0:bb348c97df44 383 * @}
lypinator 0:bb348c97df44 384 */
lypinator 0:bb348c97df44 385
lypinator 0:bb348c97df44 386 /** @addtogroup CRYP_Exported_Functions_Group3
lypinator 0:bb348c97df44 387 * @{
lypinator 0:bb348c97df44 388 */
lypinator 0:bb348c97df44 389 /* DES encryption/decryption using polling ***********************************/
lypinator 0:bb348c97df44 390 HAL_StatusTypeDef HAL_CRYP_DESECB_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 391 HAL_StatusTypeDef HAL_CRYP_DESCBC_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 392 HAL_StatusTypeDef HAL_CRYP_DESECB_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 393 HAL_StatusTypeDef HAL_CRYP_DESCBC_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 394
lypinator 0:bb348c97df44 395 /* DES encryption/decryption using interrupt *********************************/
lypinator 0:bb348c97df44 396 HAL_StatusTypeDef HAL_CRYP_DESECB_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 397 HAL_StatusTypeDef HAL_CRYP_DESECB_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 398 HAL_StatusTypeDef HAL_CRYP_DESCBC_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 399 HAL_StatusTypeDef HAL_CRYP_DESCBC_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 400
lypinator 0:bb348c97df44 401 /* DES encryption/decryption using DMA ***************************************/
lypinator 0:bb348c97df44 402 HAL_StatusTypeDef HAL_CRYP_DESECB_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 403 HAL_StatusTypeDef HAL_CRYP_DESECB_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 404 HAL_StatusTypeDef HAL_CRYP_DESCBC_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 405 HAL_StatusTypeDef HAL_CRYP_DESCBC_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 406 /**
lypinator 0:bb348c97df44 407 * @}
lypinator 0:bb348c97df44 408 */
lypinator 0:bb348c97df44 409
lypinator 0:bb348c97df44 410 /** @addtogroup CRYP_Exported_Functions_Group4
lypinator 0:bb348c97df44 411 * @{
lypinator 0:bb348c97df44 412 */
lypinator 0:bb348c97df44 413 /* TDES encryption/decryption using polling **********************************/
lypinator 0:bb348c97df44 414 HAL_StatusTypeDef HAL_CRYP_TDESECB_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 415 HAL_StatusTypeDef HAL_CRYP_TDESCBC_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 416 HAL_StatusTypeDef HAL_CRYP_TDESECB_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 417 HAL_StatusTypeDef HAL_CRYP_TDESCBC_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 418
lypinator 0:bb348c97df44 419 /* TDES encryption/decryption using interrupt ********************************/
lypinator 0:bb348c97df44 420 HAL_StatusTypeDef HAL_CRYP_TDESECB_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 421 HAL_StatusTypeDef HAL_CRYP_TDESECB_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 422 HAL_StatusTypeDef HAL_CRYP_TDESCBC_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 423 HAL_StatusTypeDef HAL_CRYP_TDESCBC_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 424
lypinator 0:bb348c97df44 425 /* TDES encryption/decryption using DMA **************************************/
lypinator 0:bb348c97df44 426 HAL_StatusTypeDef HAL_CRYP_TDESECB_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 427 HAL_StatusTypeDef HAL_CRYP_TDESECB_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 428 HAL_StatusTypeDef HAL_CRYP_TDESCBC_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 429 HAL_StatusTypeDef HAL_CRYP_TDESCBC_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 430 /**
lypinator 0:bb348c97df44 431 * @}
lypinator 0:bb348c97df44 432 */
lypinator 0:bb348c97df44 433
lypinator 0:bb348c97df44 434 /** @addtogroup CRYP_Exported_Functions_Group5
lypinator 0:bb348c97df44 435 * @{
lypinator 0:bb348c97df44 436 */
lypinator 0:bb348c97df44 437 void HAL_CRYP_InCpltCallback(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 438 void HAL_CRYP_OutCpltCallback(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 439 void HAL_CRYP_ErrorCallback(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 440 /**
lypinator 0:bb348c97df44 441 * @}
lypinator 0:bb348c97df44 442 */
lypinator 0:bb348c97df44 443
lypinator 0:bb348c97df44 444 /** @addtogroup CRYP_Exported_Functions_Group6
lypinator 0:bb348c97df44 445 * @{
lypinator 0:bb348c97df44 446 */
lypinator 0:bb348c97df44 447 void HAL_CRYP_IRQHandler(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 448 /**
lypinator 0:bb348c97df44 449 * @}
lypinator 0:bb348c97df44 450 */
lypinator 0:bb348c97df44 451
lypinator 0:bb348c97df44 452 /** @addtogroup CRYP_Exported_Functions_Group7
lypinator 0:bb348c97df44 453 * @{
lypinator 0:bb348c97df44 454 */
lypinator 0:bb348c97df44 455 HAL_CRYP_STATETypeDef HAL_CRYP_GetState(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 456 /**
lypinator 0:bb348c97df44 457 * @}
lypinator 0:bb348c97df44 458 */
lypinator 0:bb348c97df44 459
lypinator 0:bb348c97df44 460 /**
lypinator 0:bb348c97df44 461 * @}
lypinator 0:bb348c97df44 462 */
lypinator 0:bb348c97df44 463
lypinator 0:bb348c97df44 464 /* Private types -------------------------------------------------------------*/
lypinator 0:bb348c97df44 465 /** @defgroup CRYP_Private_Types CRYP Private Types
lypinator 0:bb348c97df44 466 * @{
lypinator 0:bb348c97df44 467 */
lypinator 0:bb348c97df44 468
lypinator 0:bb348c97df44 469 /**
lypinator 0:bb348c97df44 470 * @}
lypinator 0:bb348c97df44 471 */
lypinator 0:bb348c97df44 472
lypinator 0:bb348c97df44 473 /* Private variables ---------------------------------------------------------*/
lypinator 0:bb348c97df44 474 /** @defgroup CRYP_Private_Variables CRYP Private Variables
lypinator 0:bb348c97df44 475 * @{
lypinator 0:bb348c97df44 476 */
lypinator 0:bb348c97df44 477
lypinator 0:bb348c97df44 478 /**
lypinator 0:bb348c97df44 479 * @}
lypinator 0:bb348c97df44 480 */
lypinator 0:bb348c97df44 481
lypinator 0:bb348c97df44 482 /* Private constants ---------------------------------------------------------*/
lypinator 0:bb348c97df44 483 /** @defgroup CRYP_Private_Constants CRYP Private Constants
lypinator 0:bb348c97df44 484 * @{
lypinator 0:bb348c97df44 485 */
lypinator 0:bb348c97df44 486 #define CRYP_FLAG_MASK 0x0000001FU
lypinator 0:bb348c97df44 487 /**
lypinator 0:bb348c97df44 488 * @}
lypinator 0:bb348c97df44 489 */
lypinator 0:bb348c97df44 490
lypinator 0:bb348c97df44 491 /* Private macros ------------------------------------------------------------*/
lypinator 0:bb348c97df44 492 /** @defgroup CRYP_Private_Macros CRYP Private Macros
lypinator 0:bb348c97df44 493 * @{
lypinator 0:bb348c97df44 494 */
lypinator 0:bb348c97df44 495
lypinator 0:bb348c97df44 496 #define IS_CRYP_KEYSIZE(__KEYSIZE__) (((__KEYSIZE__) == CRYP_KEYSIZE_128B) || \
lypinator 0:bb348c97df44 497 ((__KEYSIZE__) == CRYP_KEYSIZE_192B) || \
lypinator 0:bb348c97df44 498 ((__KEYSIZE__) == CRYP_KEYSIZE_256B))
lypinator 0:bb348c97df44 499
lypinator 0:bb348c97df44 500
lypinator 0:bb348c97df44 501 #define IS_CRYP_DATATYPE(__DATATYPE__) (((__DATATYPE__) == CRYP_DATATYPE_32B) || \
lypinator 0:bb348c97df44 502 ((__DATATYPE__) == CRYP_DATATYPE_16B) || \
lypinator 0:bb348c97df44 503 ((__DATATYPE__) == CRYP_DATATYPE_8B) || \
lypinator 0:bb348c97df44 504 ((__DATATYPE__) == CRYP_DATATYPE_1B))
lypinator 0:bb348c97df44 505
lypinator 0:bb348c97df44 506
lypinator 0:bb348c97df44 507 /**
lypinator 0:bb348c97df44 508 * @}
lypinator 0:bb348c97df44 509 */
lypinator 0:bb348c97df44 510
lypinator 0:bb348c97df44 511 /* Private functions ---------------------------------------------------------*/
lypinator 0:bb348c97df44 512 /** @defgroup CRYP_Private_Functions CRYP Private Functions
lypinator 0:bb348c97df44 513 * @{
lypinator 0:bb348c97df44 514 */
lypinator 0:bb348c97df44 515
lypinator 0:bb348c97df44 516 /**
lypinator 0:bb348c97df44 517 * @}
lypinator 0:bb348c97df44 518 */
lypinator 0:bb348c97df44 519
lypinator 0:bb348c97df44 520 #endif /* CRYP */
lypinator 0:bb348c97df44 521
lypinator 0:bb348c97df44 522 #if defined (AES)
lypinator 0:bb348c97df44 523
lypinator 0:bb348c97df44 524 /** @addtogroup STM32F4xx_HAL_Driver
lypinator 0:bb348c97df44 525 * @{
lypinator 0:bb348c97df44 526 */
lypinator 0:bb348c97df44 527
lypinator 0:bb348c97df44 528 /** @addtogroup CRYP
lypinator 0:bb348c97df44 529 * @{
lypinator 0:bb348c97df44 530 */
lypinator 0:bb348c97df44 531
lypinator 0:bb348c97df44 532 /* Exported types ------------------------------------------------------------*/
lypinator 0:bb348c97df44 533 /** @defgroup CRYP_Exported_Types CRYP Exported Types
lypinator 0:bb348c97df44 534 * @{
lypinator 0:bb348c97df44 535 */
lypinator 0:bb348c97df44 536
lypinator 0:bb348c97df44 537 /**
lypinator 0:bb348c97df44 538 * @brief CRYP Configuration Structure definition
lypinator 0:bb348c97df44 539 */
lypinator 0:bb348c97df44 540 typedef struct
lypinator 0:bb348c97df44 541 {
lypinator 0:bb348c97df44 542 uint32_t DataType; /*!< 32-bit data, 16-bit data, 8-bit data or 1-bit string.
lypinator 0:bb348c97df44 543 This parameter can be a value of @ref CRYP_Data_Type */
lypinator 0:bb348c97df44 544
lypinator 0:bb348c97df44 545 uint32_t KeySize; /*!< 128 or 256-bit key length.
lypinator 0:bb348c97df44 546 This parameter can be a value of @ref CRYP_Key_Size */
lypinator 0:bb348c97df44 547
lypinator 0:bb348c97df44 548 uint32_t OperatingMode; /*!< AES operating mode.
lypinator 0:bb348c97df44 549 This parameter can be a value of @ref CRYP_AES_OperatingMode */
lypinator 0:bb348c97df44 550
lypinator 0:bb348c97df44 551 uint32_t ChainingMode; /*!< AES chaining mode.
lypinator 0:bb348c97df44 552 This parameter can be a value of @ref CRYP_AES_ChainingMode */
lypinator 0:bb348c97df44 553
lypinator 0:bb348c97df44 554 uint32_t KeyWriteFlag; /*!< Allows to bypass or not key write-up before decryption.
lypinator 0:bb348c97df44 555 This parameter can be a value of @ref CRYP_Key_Write */
lypinator 0:bb348c97df44 556
lypinator 0:bb348c97df44 557 uint32_t GCMCMACPhase; /*!< Indicates the processing phase of the Galois Counter Mode (GCM),
lypinator 0:bb348c97df44 558 Galois Message Authentication Code (GMAC) or Cipher Message
lypinator 0:bb348c97df44 559 Authentication Code (CMAC) or Counter with Cipher Mode (CCM) when
lypinator 0:bb348c97df44 560 the latter is applicable.
lypinator 0:bb348c97df44 561 This parameter can be a value of @ref CRYP_GCM_CMAC_Phase */
lypinator 0:bb348c97df44 562
lypinator 0:bb348c97df44 563 uint8_t* pKey; /*!< Encryption/Decryption Key */
lypinator 0:bb348c97df44 564
lypinator 0:bb348c97df44 565 uint8_t* pInitVect; /*!< Initialization Vector used for CTR, CBC, GCM/GMAC, CMAC,
lypinator 0:bb348c97df44 566 (and CCM when applicable) modes */
lypinator 0:bb348c97df44 567
lypinator 0:bb348c97df44 568 uint8_t* Header; /*!< Header used in GCM/GMAC, CMAC (and CCM when applicable) modes */
lypinator 0:bb348c97df44 569
lypinator 0:bb348c97df44 570 uint64_t HeaderSize; /*!< Header size in bytes */
lypinator 0:bb348c97df44 571
lypinator 0:bb348c97df44 572 }CRYP_InitTypeDef;
lypinator 0:bb348c97df44 573
lypinator 0:bb348c97df44 574 /**
lypinator 0:bb348c97df44 575 * @brief HAL CRYP State structures definition
lypinator 0:bb348c97df44 576 */
lypinator 0:bb348c97df44 577 typedef enum
lypinator 0:bb348c97df44 578 {
lypinator 0:bb348c97df44 579 HAL_CRYP_STATE_RESET = 0x00U, /*!< CRYP not yet initialized or disabled */
lypinator 0:bb348c97df44 580 HAL_CRYP_STATE_READY = 0x01U, /*!< CRYP initialized and ready for use */
lypinator 0:bb348c97df44 581 HAL_CRYP_STATE_BUSY = 0x02U, /*!< CRYP internal processing is ongoing */
lypinator 0:bb348c97df44 582 HAL_CRYP_STATE_TIMEOUT = 0x03U, /*!< CRYP timeout state */
lypinator 0:bb348c97df44 583 HAL_CRYP_STATE_ERROR = 0x04U, /*!< CRYP error state */
lypinator 0:bb348c97df44 584 HAL_CRYP_STATE_SUSPENDED = 0x05U /*!< CRYP suspended */
lypinator 0:bb348c97df44 585 }HAL_CRYP_STATETypeDef;
lypinator 0:bb348c97df44 586
lypinator 0:bb348c97df44 587 /**
lypinator 0:bb348c97df44 588 * @brief HAL CRYP phase structures definition
lypinator 0:bb348c97df44 589 */
lypinator 0:bb348c97df44 590 typedef enum
lypinator 0:bb348c97df44 591 {
lypinator 0:bb348c97df44 592 HAL_CRYP_PHASE_READY = 0x01U, /*!< CRYP peripheral is ready for initialization. */
lypinator 0:bb348c97df44 593 HAL_CRYP_PHASE_PROCESS = 0x02U, /*!< CRYP peripheral is in processing phase */
lypinator 0:bb348c97df44 594 HAL_CRYP_PHASE_START = 0x03U, /*!< CRYP peripheral has been initialized but
lypinator 0:bb348c97df44 595 GCM/GMAC/CMAC(/CCM) initialization phase has not started */
lypinator 0:bb348c97df44 596 HAL_CRYP_PHASE_INIT_OVER = 0x04U, /*!< GCM/GMAC/CMAC(/CCM) init phase has been carried out */
lypinator 0:bb348c97df44 597 HAL_CRYP_PHASE_HEADER_OVER = 0x05U, /*!< GCM/GMAC/CMAC(/CCM) header phase has been carried out */
lypinator 0:bb348c97df44 598 HAL_CRYP_PHASE_PAYLOAD_OVER = 0x06U, /*!< GCM(/CCM) payload phase has been carried out */
lypinator 0:bb348c97df44 599 HAL_CRYP_PHASE_FINAL_OVER = 0x07U, /*!< GCM/GMAC/CMAC(/CCM) final phase has been carried out */
lypinator 0:bb348c97df44 600 HAL_CRYP_PHASE_HEADER_SUSPENDED = 0x08U, /*!< GCM/GMAC/CMAC(/CCM) header phase has been suspended */
lypinator 0:bb348c97df44 601 HAL_CRYP_PHASE_PAYLOAD_SUSPENDED = 0x09U, /*!< GCM(/CCM) payload phase has been suspended */
lypinator 0:bb348c97df44 602 HAL_CRYP_PHASE_NOT_USED = 0x0AU /*!< Phase is irrelevant to the current chaining mode */
lypinator 0:bb348c97df44 603 }HAL_PhaseTypeDef;
lypinator 0:bb348c97df44 604
lypinator 0:bb348c97df44 605 /**
lypinator 0:bb348c97df44 606 * @brief HAL CRYP mode suspend definitions
lypinator 0:bb348c97df44 607 */
lypinator 0:bb348c97df44 608 typedef enum
lypinator 0:bb348c97df44 609 {
lypinator 0:bb348c97df44 610 HAL_CRYP_SUSPEND_NONE = 0x00U, /*!< CRYP peripheral suspension not requested */
lypinator 0:bb348c97df44 611 HAL_CRYP_SUSPEND = 0x01U /*!< CRYP peripheral suspension requested */
lypinator 0:bb348c97df44 612 }HAL_SuspendTypeDef;
lypinator 0:bb348c97df44 613
lypinator 0:bb348c97df44 614
lypinator 0:bb348c97df44 615 /**
lypinator 0:bb348c97df44 616 * @brief HAL CRYP Error Codes definition
lypinator 0:bb348c97df44 617 */
lypinator 0:bb348c97df44 618 #define HAL_CRYP_ERROR_NONE 0x00000000U /*!< No error */
lypinator 0:bb348c97df44 619 #define HAL_CRYP_WRITE_ERROR 0x00000001U /*!< Write error */
lypinator 0:bb348c97df44 620 #define HAL_CRYP_READ_ERROR 0x00000002U /*!< Read error */
lypinator 0:bb348c97df44 621 #define HAL_CRYP_DMA_ERROR 0x00000004U /*!< DMA error */
lypinator 0:bb348c97df44 622 #define HAL_CRYP_BUSY_ERROR 0x00000008U /*!< Busy flag error */
lypinator 0:bb348c97df44 623
lypinator 0:bb348c97df44 624 /**
lypinator 0:bb348c97df44 625 * @brief CRYP handle Structure definition
lypinator 0:bb348c97df44 626 */
lypinator 0:bb348c97df44 627 typedef struct
lypinator 0:bb348c97df44 628 {
lypinator 0:bb348c97df44 629 AES_TypeDef *Instance; /*!< Register base address */
lypinator 0:bb348c97df44 630
lypinator 0:bb348c97df44 631 CRYP_InitTypeDef Init; /*!< CRYP initialization parameters */
lypinator 0:bb348c97df44 632
lypinator 0:bb348c97df44 633 uint8_t *pCrypInBuffPtr; /*!< Pointer to CRYP processing (encryption, decryption,...) input buffer */
lypinator 0:bb348c97df44 634
lypinator 0:bb348c97df44 635 uint8_t *pCrypOutBuffPtr; /*!< Pointer to CRYP processing (encryption, decryption,...) output buffer */
lypinator 0:bb348c97df44 636
lypinator 0:bb348c97df44 637 uint32_t CrypInCount; /*!< Input data size in bytes or, after suspension, the remaining
lypinator 0:bb348c97df44 638 number of bytes to process */
lypinator 0:bb348c97df44 639
lypinator 0:bb348c97df44 640 uint32_t CrypOutCount; /*!< Output data size in bytes */
lypinator 0:bb348c97df44 641
lypinator 0:bb348c97df44 642 HAL_PhaseTypeDef Phase; /*!< CRYP peripheral processing phase for GCM, GMAC, CMAC
lypinator 0:bb348c97df44 643 (or CCM when applicable) modes.
lypinator 0:bb348c97df44 644 Indicates the last phase carried out to ease
lypinator 0:bb348c97df44 645 phase transitions */
lypinator 0:bb348c97df44 646
lypinator 0:bb348c97df44 647 DMA_HandleTypeDef *hdmain; /*!< CRYP peripheral Input DMA handle parameters */
lypinator 0:bb348c97df44 648
lypinator 0:bb348c97df44 649 DMA_HandleTypeDef *hdmaout; /*!< CRYP peripheral Output DMA handle parameters */
lypinator 0:bb348c97df44 650
lypinator 0:bb348c97df44 651 HAL_LockTypeDef Lock; /*!< CRYP locking object */
lypinator 0:bb348c97df44 652
lypinator 0:bb348c97df44 653 __IO HAL_CRYP_STATETypeDef State; /*!< CRYP peripheral state */
lypinator 0:bb348c97df44 654
lypinator 0:bb348c97df44 655 __IO uint32_t ErrorCode; /*!< CRYP peripheral error code */
lypinator 0:bb348c97df44 656
lypinator 0:bb348c97df44 657 HAL_SuspendTypeDef SuspendRequest; /*!< CRYP peripheral suspension request flag */
lypinator 0:bb348c97df44 658 }CRYP_HandleTypeDef;
lypinator 0:bb348c97df44 659
lypinator 0:bb348c97df44 660 /**
lypinator 0:bb348c97df44 661 * @}
lypinator 0:bb348c97df44 662 */
lypinator 0:bb348c97df44 663
lypinator 0:bb348c97df44 664
lypinator 0:bb348c97df44 665 /* Exported constants --------------------------------------------------------*/
lypinator 0:bb348c97df44 666 /** @defgroup CRYP_Exported_Constants CRYP Exported Constants
lypinator 0:bb348c97df44 667 * @{
lypinator 0:bb348c97df44 668 */
lypinator 0:bb348c97df44 669
lypinator 0:bb348c97df44 670 /** @defgroup CRYP_Key_Size Key size selection
lypinator 0:bb348c97df44 671 * @{
lypinator 0:bb348c97df44 672 */
lypinator 0:bb348c97df44 673 #define CRYP_KEYSIZE_128B 0x00000000U /*!< 128-bit long key */
lypinator 0:bb348c97df44 674 #define CRYP_KEYSIZE_256B AES_CR_KEYSIZE /*!< 256-bit long key */
lypinator 0:bb348c97df44 675 /**
lypinator 0:bb348c97df44 676 * @}
lypinator 0:bb348c97df44 677 */
lypinator 0:bb348c97df44 678
lypinator 0:bb348c97df44 679 /** @defgroup CRYP_Data_Type AES Data Type selection
lypinator 0:bb348c97df44 680 * @{
lypinator 0:bb348c97df44 681 */
lypinator 0:bb348c97df44 682 #define CRYP_DATATYPE_32B 0x00000000U /*!< 32-bit data type (no swapping) */
lypinator 0:bb348c97df44 683 #define CRYP_DATATYPE_16B AES_CR_DATATYPE_0 /*!< 16-bit data type (half-word swapping) */
lypinator 0:bb348c97df44 684 #define CRYP_DATATYPE_8B AES_CR_DATATYPE_1 /*!< 8-bit data type (byte swapping) */
lypinator 0:bb348c97df44 685 #define CRYP_DATATYPE_1B AES_CR_DATATYPE /*!< 1-bit data type (bit swapping) */
lypinator 0:bb348c97df44 686 /**
lypinator 0:bb348c97df44 687 * @}
lypinator 0:bb348c97df44 688 */
lypinator 0:bb348c97df44 689
lypinator 0:bb348c97df44 690 /** @defgroup CRYP_AES_State AES Enable state
lypinator 0:bb348c97df44 691 * @{
lypinator 0:bb348c97df44 692 */
lypinator 0:bb348c97df44 693 #define CRYP_AES_DISABLE 0x00000000U /*!< Disable AES */
lypinator 0:bb348c97df44 694 #define CRYP_AES_ENABLE AES_CR_EN /*!< Enable AES */
lypinator 0:bb348c97df44 695 /**
lypinator 0:bb348c97df44 696 * @}
lypinator 0:bb348c97df44 697 */
lypinator 0:bb348c97df44 698
lypinator 0:bb348c97df44 699 /** @defgroup CRYP_AES_OperatingMode AES operating mode
lypinator 0:bb348c97df44 700 * @{
lypinator 0:bb348c97df44 701 */
lypinator 0:bb348c97df44 702 #define CRYP_ALGOMODE_ENCRYPT 0x00000000U /*!< Encryption mode */
lypinator 0:bb348c97df44 703 #define CRYP_ALGOMODE_KEYDERIVATION AES_CR_MODE_0 /*!< Key derivation mode */
lypinator 0:bb348c97df44 704 #define CRYP_ALGOMODE_DECRYPT AES_CR_MODE_1 /*!< Decryption */
lypinator 0:bb348c97df44 705 #define CRYP_ALGOMODE_KEYDERIVATION_DECRYPT AES_CR_MODE /*!< Key derivation and decryption */
lypinator 0:bb348c97df44 706 #define CRYP_ALGOMODE_TAG_GENERATION 0x00000000U /*!< GMAC or CMAC authentication tag generation */
lypinator 0:bb348c97df44 707 /**
lypinator 0:bb348c97df44 708 * @}
lypinator 0:bb348c97df44 709 */
lypinator 0:bb348c97df44 710
lypinator 0:bb348c97df44 711 /** @defgroup CRYP_AES_ChainingMode AES chaining mode
lypinator 0:bb348c97df44 712 * @{
lypinator 0:bb348c97df44 713 */
lypinator 0:bb348c97df44 714 #define CRYP_CHAINMODE_AES_ECB 0x00000000U /*!< Electronic codebook chaining algorithm */
lypinator 0:bb348c97df44 715 #define CRYP_CHAINMODE_AES_CBC AES_CR_CHMOD_0 /*!< Cipher block chaining algorithm */
lypinator 0:bb348c97df44 716 #define CRYP_CHAINMODE_AES_CTR AES_CR_CHMOD_1 /*!< Counter mode chaining algorithm */
lypinator 0:bb348c97df44 717 #define CRYP_CHAINMODE_AES_GCM_GMAC (AES_CR_CHMOD_0 | AES_CR_CHMOD_1) /*!< Galois counter mode - Galois message authentication code */
lypinator 0:bb348c97df44 718 #define CRYP_CHAINMODE_AES_CMAC AES_CR_CHMOD_2 /*!< Cipher message authentication code */
lypinator 0:bb348c97df44 719 #if defined(AES_CR_NPBLB)
lypinator 0:bb348c97df44 720 #define CRYP_CHAINMODE_AES_CCM_CMAC AES_CR_CHMOD_2 /*!< Counter with Cipher Mode - Cipher message authentication code */
lypinator 0:bb348c97df44 721 #endif
lypinator 0:bb348c97df44 722 /**
lypinator 0:bb348c97df44 723 * @}
lypinator 0:bb348c97df44 724 */
lypinator 0:bb348c97df44 725
lypinator 0:bb348c97df44 726 /** @defgroup CRYP_Key_Write AES decryption key write-up flag
lypinator 0:bb348c97df44 727 * @{
lypinator 0:bb348c97df44 728 */
lypinator 0:bb348c97df44 729 #define CRYP_KEY_WRITE_ENABLE 0x00000000U /*!< Enable decryption key writing */
lypinator 0:bb348c97df44 730 #define CRYP_KEY_WRITE_DISABLE 0x00000001U /*!< Disable decryption key writing */
lypinator 0:bb348c97df44 731 /**
lypinator 0:bb348c97df44 732 * @}
lypinator 0:bb348c97df44 733 */
lypinator 0:bb348c97df44 734
lypinator 0:bb348c97df44 735 /** @defgroup CRYP_DMAIN DMA Input phase management enable state
lypinator 0:bb348c97df44 736 * @{
lypinator 0:bb348c97df44 737 */
lypinator 0:bb348c97df44 738 #define CRYP_DMAIN_DISABLE 0x00000000U /*!< Disable DMA Input phase management */
lypinator 0:bb348c97df44 739 #define CRYP_DMAIN_ENABLE AES_CR_DMAINEN /*!< Enable DMA Input phase management */
lypinator 0:bb348c97df44 740 /**
lypinator 0:bb348c97df44 741 * @}
lypinator 0:bb348c97df44 742 */
lypinator 0:bb348c97df44 743
lypinator 0:bb348c97df44 744 /** @defgroup CRYP_DMAOUT DMA Output phase management enable state
lypinator 0:bb348c97df44 745 * @{
lypinator 0:bb348c97df44 746 */
lypinator 0:bb348c97df44 747 #define CRYP_DMAOUT_DISABLE 0x00000000U /*!< Disable DMA Output phase management */
lypinator 0:bb348c97df44 748 #define CRYP_DMAOUT_ENABLE AES_CR_DMAOUTEN /*!< Enable DMA Output phase management */
lypinator 0:bb348c97df44 749 /**
lypinator 0:bb348c97df44 750 * @}
lypinator 0:bb348c97df44 751 */
lypinator 0:bb348c97df44 752
lypinator 0:bb348c97df44 753
lypinator 0:bb348c97df44 754 /** @defgroup CRYP_GCM_CMAC_Phase GCM/GMAC and CMAC processing phase selection
lypinator 0:bb348c97df44 755 * @{
lypinator 0:bb348c97df44 756 */
lypinator 0:bb348c97df44 757 #define CRYP_GCM_INIT_PHASE 0x00000000U /*!< GCM/GMAC (or CCM) init phase */
lypinator 0:bb348c97df44 758 #define CRYP_GCMCMAC_HEADER_PHASE AES_CR_GCMPH_0 /*!< GCM/GMAC or (CCM/)CMAC header phase */
lypinator 0:bb348c97df44 759 #define CRYP_GCM_PAYLOAD_PHASE AES_CR_GCMPH_1 /*!< GCM(/CCM) payload phase */
lypinator 0:bb348c97df44 760 #define CRYP_GCMCMAC_FINAL_PHASE AES_CR_GCMPH /*!< GCM/GMAC or (CCM/)CMAC final phase */
lypinator 0:bb348c97df44 761 /* Definitions duplication for code readibility's sake:
lypinator 0:bb348c97df44 762 supported or not supported chain modes are not specified for each phase */
lypinator 0:bb348c97df44 763 #define CRYP_INIT_PHASE 0x00000000U /*!< Init phase */
lypinator 0:bb348c97df44 764 #define CRYP_HEADER_PHASE AES_CR_GCMPH_0 /*!< Header phase */
lypinator 0:bb348c97df44 765 #define CRYP_PAYLOAD_PHASE AES_CR_GCMPH_1 /*!< Payload phase */
lypinator 0:bb348c97df44 766 #define CRYP_FINAL_PHASE AES_CR_GCMPH /*!< Final phase */
lypinator 0:bb348c97df44 767 /**
lypinator 0:bb348c97df44 768 * @}
lypinator 0:bb348c97df44 769 */
lypinator 0:bb348c97df44 770
lypinator 0:bb348c97df44 771 /** @defgroup CRYP_Flags AES status flags
lypinator 0:bb348c97df44 772 * @{
lypinator 0:bb348c97df44 773 */
lypinator 0:bb348c97df44 774
lypinator 0:bb348c97df44 775 #define CRYP_FLAG_BUSY AES_SR_BUSY /*!< GCM process suspension forbidden */
lypinator 0:bb348c97df44 776 #define CRYP_FLAG_WRERR AES_SR_WRERR /*!< Write Error */
lypinator 0:bb348c97df44 777 #define CRYP_FLAG_RDERR AES_SR_RDERR /*!< Read error */
lypinator 0:bb348c97df44 778 #define CRYP_FLAG_CCF AES_SR_CCF /*!< Computation completed */
lypinator 0:bb348c97df44 779 /**
lypinator 0:bb348c97df44 780 * @}
lypinator 0:bb348c97df44 781 */
lypinator 0:bb348c97df44 782
lypinator 0:bb348c97df44 783 /** @defgroup CRYP_Clear_Flags AES clearing flags
lypinator 0:bb348c97df44 784 * @{
lypinator 0:bb348c97df44 785 */
lypinator 0:bb348c97df44 786
lypinator 0:bb348c97df44 787 #define CRYP_CCF_CLEAR AES_CR_CCFC /*!< Computation Complete Flag Clear */
lypinator 0:bb348c97df44 788 #define CRYP_ERR_CLEAR AES_CR_ERRC /*!< Error Flag Clear */
lypinator 0:bb348c97df44 789 /**
lypinator 0:bb348c97df44 790 * @}
lypinator 0:bb348c97df44 791 */
lypinator 0:bb348c97df44 792
lypinator 0:bb348c97df44 793 /** @defgroup AES_Interrupts_Enable AES Interrupts Enable bits
lypinator 0:bb348c97df44 794 * @{
lypinator 0:bb348c97df44 795 */
lypinator 0:bb348c97df44 796 #define CRYP_IT_CCFIE AES_CR_CCFIE /*!< Computation Complete interrupt enable */
lypinator 0:bb348c97df44 797 #define CRYP_IT_ERRIE AES_CR_ERRIE /*!< Error interrupt enable */
lypinator 0:bb348c97df44 798 /**
lypinator 0:bb348c97df44 799 * @}
lypinator 0:bb348c97df44 800 */
lypinator 0:bb348c97df44 801
lypinator 0:bb348c97df44 802 /** @defgroup CRYP_Interrupts_Flags AES Interrupts flags
lypinator 0:bb348c97df44 803 * @{
lypinator 0:bb348c97df44 804 */
lypinator 0:bb348c97df44 805 #define CRYP_IT_WRERR AES_SR_WRERR /*!< Write Error */
lypinator 0:bb348c97df44 806 #define CRYP_IT_RDERR AES_SR_RDERR /*!< Read Error */
lypinator 0:bb348c97df44 807 #define CRYP_IT_CCF AES_SR_CCF /*!< Computation completed */
lypinator 0:bb348c97df44 808 /**
lypinator 0:bb348c97df44 809 * @}
lypinator 0:bb348c97df44 810 */
lypinator 0:bb348c97df44 811
lypinator 0:bb348c97df44 812 /**
lypinator 0:bb348c97df44 813 * @}
lypinator 0:bb348c97df44 814 */
lypinator 0:bb348c97df44 815
lypinator 0:bb348c97df44 816 /* Exported macros -----------------------------------------------------------*/
lypinator 0:bb348c97df44 817 /** @defgroup CRYP_Exported_Macros CRYP Exported Macros
lypinator 0:bb348c97df44 818 * @{
lypinator 0:bb348c97df44 819 */
lypinator 0:bb348c97df44 820
lypinator 0:bb348c97df44 821 /** @brief Reset CRYP handle state.
lypinator 0:bb348c97df44 822 * @param __HANDLE__ specifies the CRYP handle.
lypinator 0:bb348c97df44 823 * @retval None
lypinator 0:bb348c97df44 824 */
lypinator 0:bb348c97df44 825 #define __HAL_CRYP_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_CRYP_STATE_RESET)
lypinator 0:bb348c97df44 826
lypinator 0:bb348c97df44 827 /**
lypinator 0:bb348c97df44 828 * @brief Enable the CRYP AES peripheral.
lypinator 0:bb348c97df44 829 * @retval None
lypinator 0:bb348c97df44 830 */
lypinator 0:bb348c97df44 831 #define __HAL_CRYP_ENABLE() (AES->CR |= AES_CR_EN)
lypinator 0:bb348c97df44 832
lypinator 0:bb348c97df44 833 /**
lypinator 0:bb348c97df44 834 * @brief Disable the CRYP AES peripheral.
lypinator 0:bb348c97df44 835 * @retval None
lypinator 0:bb348c97df44 836 */
lypinator 0:bb348c97df44 837 #define __HAL_CRYP_DISABLE() (AES->CR &= ~AES_CR_EN)
lypinator 0:bb348c97df44 838
lypinator 0:bb348c97df44 839 /**
lypinator 0:bb348c97df44 840 * @brief Set the algorithm operating mode.
lypinator 0:bb348c97df44 841 * @param __OPERATING_MODE__ specifies the operating mode
lypinator 0:bb348c97df44 842 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 843 * @arg @ref CRYP_ALGOMODE_ENCRYPT encryption
lypinator 0:bb348c97df44 844 * @arg @ref CRYP_ALGOMODE_KEYDERIVATION key derivation
lypinator 0:bb348c97df44 845 * @arg @ref CRYP_ALGOMODE_DECRYPT decryption
lypinator 0:bb348c97df44 846 * @arg @ref CRYP_ALGOMODE_KEYDERIVATION_DECRYPT key derivation and decryption
lypinator 0:bb348c97df44 847 * @retval None
lypinator 0:bb348c97df44 848 */
lypinator 0:bb348c97df44 849 #define __HAL_CRYP_SET_OPERATINGMODE(__OPERATING_MODE__) MODIFY_REG(AES->CR, AES_CR_MODE, (__OPERATING_MODE__))
lypinator 0:bb348c97df44 850
lypinator 0:bb348c97df44 851
lypinator 0:bb348c97df44 852 /**
lypinator 0:bb348c97df44 853 * @brief Set the algorithm chaining mode.
lypinator 0:bb348c97df44 854 * @param __CHAINING_MODE__ specifies the chaining mode
lypinator 0:bb348c97df44 855 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 856 * @arg @ref CRYP_CHAINMODE_AES_ECB Electronic CodeBook
lypinator 0:bb348c97df44 857 * @arg @ref CRYP_CHAINMODE_AES_CBC Cipher Block Chaining
lypinator 0:bb348c97df44 858 * @arg @ref CRYP_CHAINMODE_AES_CTR CounTeR mode
lypinator 0:bb348c97df44 859 * @arg @ref CRYP_CHAINMODE_AES_GCM_GMAC Galois Counter Mode or Galois Message Authentication Code
lypinator 0:bb348c97df44 860 * @arg @ref CRYP_CHAINMODE_AES_CMAC Cipher Message Authentication Code (or Counter with Cipher Mode when applicable)
lypinator 0:bb348c97df44 861 * @retval None
lypinator 0:bb348c97df44 862 */
lypinator 0:bb348c97df44 863 #define __HAL_CRYP_SET_CHAININGMODE(__CHAINING_MODE__) MODIFY_REG(AES->CR, AES_CR_CHMOD, (__CHAINING_MODE__))
lypinator 0:bb348c97df44 864
lypinator 0:bb348c97df44 865
lypinator 0:bb348c97df44 866
lypinator 0:bb348c97df44 867 /** @brief Check whether the specified CRYP status flag is set or not.
lypinator 0:bb348c97df44 868 * @param __FLAG__ specifies the flag to check.
lypinator 0:bb348c97df44 869 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 870 * @arg @ref CRYP_FLAG_BUSY GCM process suspension forbidden
lypinator 0:bb348c97df44 871 * @arg @ref CRYP_IT_WRERR Write Error
lypinator 0:bb348c97df44 872 * @arg @ref CRYP_IT_RDERR Read Error
lypinator 0:bb348c97df44 873 * @arg @ref CRYP_IT_CCF Computation Complete
lypinator 0:bb348c97df44 874 * @retval The state of __FLAG__ (TRUE or FALSE).
lypinator 0:bb348c97df44 875 */
lypinator 0:bb348c97df44 876 #define __HAL_CRYP_GET_FLAG(__FLAG__) ((AES->SR & (__FLAG__)) == (__FLAG__))
lypinator 0:bb348c97df44 877
lypinator 0:bb348c97df44 878
lypinator 0:bb348c97df44 879 /** @brief Clear the CRYP pending status flag.
lypinator 0:bb348c97df44 880 * @param __FLAG__ specifies the flag to clear.
lypinator 0:bb348c97df44 881 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 882 * @arg @ref CRYP_ERR_CLEAR Read (RDERR) or Write Error (WRERR) Flag Clear
lypinator 0:bb348c97df44 883 * @arg @ref CRYP_CCF_CLEAR Computation Complete Flag (CCF) Clear
lypinator 0:bb348c97df44 884 * @retval None
lypinator 0:bb348c97df44 885 */
lypinator 0:bb348c97df44 886 #define __HAL_CRYP_CLEAR_FLAG(__FLAG__) SET_BIT(AES->CR, (__FLAG__))
lypinator 0:bb348c97df44 887
lypinator 0:bb348c97df44 888
lypinator 0:bb348c97df44 889
lypinator 0:bb348c97df44 890 /** @brief Check whether the specified CRYP interrupt source is enabled or not.
lypinator 0:bb348c97df44 891 * @param __INTERRUPT__ CRYP interrupt source to check
lypinator 0:bb348c97df44 892 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 893 * @arg @ref CRYP_IT_ERRIE Error interrupt (used for RDERR and WRERR)
lypinator 0:bb348c97df44 894 * @arg @ref CRYP_IT_CCFIE Computation Complete interrupt
lypinator 0:bb348c97df44 895 * @retval State of interruption (TRUE or FALSE).
lypinator 0:bb348c97df44 896 */
lypinator 0:bb348c97df44 897 #define __HAL_CRYP_GET_IT_SOURCE(__INTERRUPT__) ((AES->CR & (__INTERRUPT__)) == (__INTERRUPT__))
lypinator 0:bb348c97df44 898
lypinator 0:bb348c97df44 899
lypinator 0:bb348c97df44 900 /** @brief Check whether the specified CRYP interrupt is set or not.
lypinator 0:bb348c97df44 901 * @param __INTERRUPT__ specifies the interrupt to check.
lypinator 0:bb348c97df44 902 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 903 * @arg @ref CRYP_IT_WRERR Write Error
lypinator 0:bb348c97df44 904 * @arg @ref CRYP_IT_RDERR Read Error
lypinator 0:bb348c97df44 905 * @arg @ref CRYP_IT_CCF Computation Complete
lypinator 0:bb348c97df44 906 * @retval The state of __INTERRUPT__ (TRUE or FALSE).
lypinator 0:bb348c97df44 907 */
lypinator 0:bb348c97df44 908 #define __HAL_CRYP_GET_IT(__INTERRUPT__) ((AES->SR & (__INTERRUPT__)) == (__INTERRUPT__))
lypinator 0:bb348c97df44 909
lypinator 0:bb348c97df44 910
lypinator 0:bb348c97df44 911
lypinator 0:bb348c97df44 912 /** @brief Clear the CRYP pending interrupt.
lypinator 0:bb348c97df44 913 * @param __INTERRUPT__ specifies the IT to clear.
lypinator 0:bb348c97df44 914 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 915 * @arg @ref CRYP_ERR_CLEAR Read (RDERR) or Write Error (WRERR) Flag Clear
lypinator 0:bb348c97df44 916 * @arg @ref CRYP_CCF_CLEAR Computation Complete Flag (CCF) Clear
lypinator 0:bb348c97df44 917 * @retval None
lypinator 0:bb348c97df44 918 */
lypinator 0:bb348c97df44 919 #define __HAL_CRYP_CLEAR_IT(__INTERRUPT__) SET_BIT(AES->CR, (__INTERRUPT__))
lypinator 0:bb348c97df44 920
lypinator 0:bb348c97df44 921
lypinator 0:bb348c97df44 922 /**
lypinator 0:bb348c97df44 923 * @brief Enable the CRYP interrupt.
lypinator 0:bb348c97df44 924 * @param __INTERRUPT__ CRYP Interrupt.
lypinator 0:bb348c97df44 925 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 926 * @arg @ref CRYP_IT_ERRIE Error interrupt (used for RDERR and WRERR)
lypinator 0:bb348c97df44 927 * @arg @ref CRYP_IT_CCFIE Computation Complete interrupt
lypinator 0:bb348c97df44 928 * @retval None
lypinator 0:bb348c97df44 929 */
lypinator 0:bb348c97df44 930 #define __HAL_CRYP_ENABLE_IT(__INTERRUPT__) ((AES->CR) |= (__INTERRUPT__))
lypinator 0:bb348c97df44 931
lypinator 0:bb348c97df44 932
lypinator 0:bb348c97df44 933 /**
lypinator 0:bb348c97df44 934 * @brief Disable the CRYP interrupt.
lypinator 0:bb348c97df44 935 * @param __INTERRUPT__ CRYP Interrupt.
lypinator 0:bb348c97df44 936 * This parameter can be one of the following values:
lypinator 0:bb348c97df44 937 * @arg @ref CRYP_IT_ERRIE Error interrupt (used for RDERR and WRERR)
lypinator 0:bb348c97df44 938 * @arg @ref CRYP_IT_CCFIE Computation Complete interrupt
lypinator 0:bb348c97df44 939 * @retval None
lypinator 0:bb348c97df44 940 */
lypinator 0:bb348c97df44 941 #define __HAL_CRYP_DISABLE_IT(__INTERRUPT__) ((AES->CR) &= ~(__INTERRUPT__))
lypinator 0:bb348c97df44 942
lypinator 0:bb348c97df44 943 /**
lypinator 0:bb348c97df44 944 * @}
lypinator 0:bb348c97df44 945 */
lypinator 0:bb348c97df44 946
lypinator 0:bb348c97df44 947 /* Private macros --------------------------------------------------------*/
lypinator 0:bb348c97df44 948 /** @addtogroup CRYP_Private_Macros CRYP Private Macros
lypinator 0:bb348c97df44 949 * @{
lypinator 0:bb348c97df44 950 */
lypinator 0:bb348c97df44 951
lypinator 0:bb348c97df44 952 /**
lypinator 0:bb348c97df44 953 * @brief Verify the key size length.
lypinator 0:bb348c97df44 954 * @param __KEYSIZE__ Ciphering/deciphering algorithm key size.
lypinator 0:bb348c97df44 955 * @retval SET (__KEYSIZE__ is a valid value) or RESET (__KEYSIZE__ is invalid)
lypinator 0:bb348c97df44 956 */
lypinator 0:bb348c97df44 957 #define IS_CRYP_KEYSIZE(__KEYSIZE__) (((__KEYSIZE__) == CRYP_KEYSIZE_128B) || \
lypinator 0:bb348c97df44 958 ((__KEYSIZE__) == CRYP_KEYSIZE_256B))
lypinator 0:bb348c97df44 959
lypinator 0:bb348c97df44 960 /**
lypinator 0:bb348c97df44 961 * @brief Verify the input data type.
lypinator 0:bb348c97df44 962 * @param __DATATYPE__ Ciphering/deciphering algorithm input data type.
lypinator 0:bb348c97df44 963 * @retval SET (__DATATYPE__ is valid) or RESET (__DATATYPE__ is invalid)
lypinator 0:bb348c97df44 964 */
lypinator 0:bb348c97df44 965 #define IS_CRYP_DATATYPE(__DATATYPE__) (((__DATATYPE__) == CRYP_DATATYPE_32B) || \
lypinator 0:bb348c97df44 966 ((__DATATYPE__) == CRYP_DATATYPE_16B) || \
lypinator 0:bb348c97df44 967 ((__DATATYPE__) == CRYP_DATATYPE_8B) || \
lypinator 0:bb348c97df44 968 ((__DATATYPE__) == CRYP_DATATYPE_1B))
lypinator 0:bb348c97df44 969
lypinator 0:bb348c97df44 970 /**
lypinator 0:bb348c97df44 971 * @brief Verify the CRYP AES IP running mode.
lypinator 0:bb348c97df44 972 * @param __MODE__ CRYP AES IP running mode.
lypinator 0:bb348c97df44 973 * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
lypinator 0:bb348c97df44 974 */
lypinator 0:bb348c97df44 975 #define IS_CRYP_AES(__MODE__) (((__MODE__) == CRYP_AES_DISABLE) || \
lypinator 0:bb348c97df44 976 ((__MODE__) == CRYP_AES_ENABLE))
lypinator 0:bb348c97df44 977
lypinator 0:bb348c97df44 978 /**
lypinator 0:bb348c97df44 979 * @brief Verify the selected CRYP algorithm.
lypinator 0:bb348c97df44 980 * @param __ALGOMODE__ Selected CRYP algorithm (ciphering, deciphering, key derivation or a combination of the latter).
lypinator 0:bb348c97df44 981 * @retval SET (__ALGOMODE__ is valid) or RESET (__ALGOMODE__ is invalid)
lypinator 0:bb348c97df44 982 */
lypinator 0:bb348c97df44 983 #define IS_CRYP_ALGOMODE(__ALGOMODE__) (((__ALGOMODE__) == CRYP_ALGOMODE_ENCRYPT) || \
lypinator 0:bb348c97df44 984 ((__ALGOMODE__) == CRYP_ALGOMODE_KEYDERIVATION) || \
lypinator 0:bb348c97df44 985 ((__ALGOMODE__) == CRYP_ALGOMODE_DECRYPT) || \
lypinator 0:bb348c97df44 986 ((__ALGOMODE__) == CRYP_ALGOMODE_TAG_GENERATION) || \
lypinator 0:bb348c97df44 987 ((__ALGOMODE__) == CRYP_ALGOMODE_KEYDERIVATION_DECRYPT))
lypinator 0:bb348c97df44 988
lypinator 0:bb348c97df44 989 /**
lypinator 0:bb348c97df44 990 * @brief Verify the selected CRYP chaining algorithm.
lypinator 0:bb348c97df44 991 * @param __CHAINMODE__ Selected CRYP chaining algorithm.
lypinator 0:bb348c97df44 992 * @retval SET (__CHAINMODE__ is valid) or RESET (__CHAINMODE__ is invalid)
lypinator 0:bb348c97df44 993 */
lypinator 0:bb348c97df44 994 #if defined(AES_CR_NPBLB)
lypinator 0:bb348c97df44 995 #define IS_CRYP_CHAINMODE(__CHAINMODE__) (((__CHAINMODE__) == CRYP_CHAINMODE_AES_ECB) || \
lypinator 0:bb348c97df44 996 ((__CHAINMODE__) == CRYP_CHAINMODE_AES_CBC) || \
lypinator 0:bb348c97df44 997 ((__CHAINMODE__) == CRYP_CHAINMODE_AES_CTR) || \
lypinator 0:bb348c97df44 998 ((__CHAINMODE__) == CRYP_CHAINMODE_AES_GCM_GMAC) || \
lypinator 0:bb348c97df44 999 ((__CHAINMODE__) == CRYP_CHAINMODE_AES_CCM_CMAC))
lypinator 0:bb348c97df44 1000 #else
lypinator 0:bb348c97df44 1001 #define IS_CRYP_CHAINMODE(__CHAINMODE__) (((__CHAINMODE__) == CRYP_CHAINMODE_AES_ECB) || \
lypinator 0:bb348c97df44 1002 ((__CHAINMODE__) == CRYP_CHAINMODE_AES_CBC) || \
lypinator 0:bb348c97df44 1003 ((__CHAINMODE__) == CRYP_CHAINMODE_AES_CTR) || \
lypinator 0:bb348c97df44 1004 ((__CHAINMODE__) == CRYP_CHAINMODE_AES_GCM_GMAC) || \
lypinator 0:bb348c97df44 1005 ((__CHAINMODE__) == CRYP_CHAINMODE_AES_CMAC))
lypinator 0:bb348c97df44 1006 #endif
lypinator 0:bb348c97df44 1007
lypinator 0:bb348c97df44 1008 /**
lypinator 0:bb348c97df44 1009 * @brief Verify the deciphering key write option.
lypinator 0:bb348c97df44 1010 * @param __WRITE__ deciphering key write option.
lypinator 0:bb348c97df44 1011 * @retval SET (__WRITE__ is valid) or RESET (__WRITE__ is invalid)
lypinator 0:bb348c97df44 1012 */
lypinator 0:bb348c97df44 1013 #define IS_CRYP_WRITE(__WRITE__) (((__WRITE__) == CRYP_KEY_WRITE_ENABLE) || \
lypinator 0:bb348c97df44 1014 ((__WRITE__) == CRYP_KEY_WRITE_DISABLE))
lypinator 0:bb348c97df44 1015
lypinator 0:bb348c97df44 1016 /**
lypinator 0:bb348c97df44 1017 * @brief Verify the CRYP input data DMA mode.
lypinator 0:bb348c97df44 1018 * @param __MODE__ CRYP input data DMA mode.
lypinator 0:bb348c97df44 1019 * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
lypinator 0:bb348c97df44 1020 */
lypinator 0:bb348c97df44 1021 #define IS_CRYP_DMAIN(__MODE__) (((__MODE__) == CRYP_DMAIN_DISABLE) || \
lypinator 0:bb348c97df44 1022 ((__MODE__) == CRYP_DMAIN_ENABLE))
lypinator 0:bb348c97df44 1023
lypinator 0:bb348c97df44 1024 /**
lypinator 0:bb348c97df44 1025 * @brief Verify the CRYP output data DMA mode.
lypinator 0:bb348c97df44 1026 * @param __MODE__ CRYP output data DMA mode.
lypinator 0:bb348c97df44 1027 * @retval SET (__MODE__ is valid) or RESET (__MODE__ is invalid)
lypinator 0:bb348c97df44 1028 */
lypinator 0:bb348c97df44 1029 #define IS_CRYP_DMAOUT(__MODE__) (((__MODE__) == CRYP_DMAOUT_DISABLE) || \
lypinator 0:bb348c97df44 1030 ((__MODE__) == CRYP_DMAOUT_ENABLE))
lypinator 0:bb348c97df44 1031
lypinator 0:bb348c97df44 1032 /**
lypinator 0:bb348c97df44 1033 * @brief Verify the CRYP AES ciphering/deciphering/authentication algorithm phase.
lypinator 0:bb348c97df44 1034 * @param __PHASE__ CRYP AES ciphering/deciphering/authentication algorithm phase.
lypinator 0:bb348c97df44 1035 * @retval SET (__PHASE__ is valid) or RESET (__PHASE__ is invalid)
lypinator 0:bb348c97df44 1036 */
lypinator 0:bb348c97df44 1037 #define IS_CRYP_GCMCMAC_PHASE(__PHASE__) (((__PHASE__) == CRYP_GCM_INIT_PHASE) || \
lypinator 0:bb348c97df44 1038 ((__PHASE__) == CRYP_GCMCMAC_HEADER_PHASE) || \
lypinator 0:bb348c97df44 1039 ((__PHASE__) == CRYP_GCM_PAYLOAD_PHASE) || \
lypinator 0:bb348c97df44 1040 ((__PHASE__) == CRYP_GCMCMAC_FINAL_PHASE))
lypinator 0:bb348c97df44 1041
lypinator 0:bb348c97df44 1042 /**
lypinator 0:bb348c97df44 1043 * @}
lypinator 0:bb348c97df44 1044 */
lypinator 0:bb348c97df44 1045
lypinator 0:bb348c97df44 1046 /* Include CRYP HAL Extended module */
lypinator 0:bb348c97df44 1047 #include "stm32f4xx_hal_cryp_ex.h"
lypinator 0:bb348c97df44 1048
lypinator 0:bb348c97df44 1049 /* Exported functions --------------------------------------------------------*/
lypinator 0:bb348c97df44 1050 /** @addtogroup CRYP_Exported_Functions CRYP Exported Functions
lypinator 0:bb348c97df44 1051 * @{
lypinator 0:bb348c97df44 1052 */
lypinator 0:bb348c97df44 1053
lypinator 0:bb348c97df44 1054 /** @addtogroup CRYP_Exported_Functions_Group1 Initialization and deinitialization functions
lypinator 0:bb348c97df44 1055 * @{
lypinator 0:bb348c97df44 1056 */
lypinator 0:bb348c97df44 1057
lypinator 0:bb348c97df44 1058 /* Initialization/de-initialization functions ********************************/
lypinator 0:bb348c97df44 1059 HAL_StatusTypeDef HAL_CRYP_Init(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1060 HAL_StatusTypeDef HAL_CRYP_DeInit(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1061
lypinator 0:bb348c97df44 1062 /* MSP initialization/de-initialization functions ****************************/
lypinator 0:bb348c97df44 1063 void HAL_CRYP_MspInit(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1064 void HAL_CRYP_MspDeInit(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1065
lypinator 0:bb348c97df44 1066 /**
lypinator 0:bb348c97df44 1067 * @}
lypinator 0:bb348c97df44 1068 */
lypinator 0:bb348c97df44 1069
lypinator 0:bb348c97df44 1070 /** @addtogroup CRYP_Exported_Functions_Group2 AES processing functions
lypinator 0:bb348c97df44 1071 * @{
lypinator 0:bb348c97df44 1072 */
lypinator 0:bb348c97df44 1073
lypinator 0:bb348c97df44 1074 /* AES encryption/decryption processing functions ****************************/
lypinator 0:bb348c97df44 1075
lypinator 0:bb348c97df44 1076 /* AES encryption/decryption using polling ***********************************/
lypinator 0:bb348c97df44 1077 HAL_StatusTypeDef HAL_CRYP_AESECB_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 1078 HAL_StatusTypeDef HAL_CRYP_AESECB_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 1079 HAL_StatusTypeDef HAL_CRYP_AESCBC_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 1080 HAL_StatusTypeDef HAL_CRYP_AESCBC_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 1081 HAL_StatusTypeDef HAL_CRYP_AESCTR_Encrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData, uint32_t Timeout);
lypinator 0:bb348c97df44 1082 HAL_StatusTypeDef HAL_CRYP_AESCTR_Decrypt(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData, uint32_t Timeout);
lypinator 0:bb348c97df44 1083
lypinator 0:bb348c97df44 1084 /* AES encryption/decryption using interrupt *********************************/
lypinator 0:bb348c97df44 1085 HAL_StatusTypeDef HAL_CRYP_AESECB_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 1086 HAL_StatusTypeDef HAL_CRYP_AESCBC_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 1087 HAL_StatusTypeDef HAL_CRYP_AESCTR_Encrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 1088 HAL_StatusTypeDef HAL_CRYP_AESECB_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 1089 HAL_StatusTypeDef HAL_CRYP_AESCTR_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 1090 HAL_StatusTypeDef HAL_CRYP_AESCBC_Decrypt_IT(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 1091
lypinator 0:bb348c97df44 1092 /* AES encryption/decryption using DMA ***************************************/
lypinator 0:bb348c97df44 1093 HAL_StatusTypeDef HAL_CRYP_AESECB_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 1094 HAL_StatusTypeDef HAL_CRYP_AESECB_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 1095 HAL_StatusTypeDef HAL_CRYP_AESCBC_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 1096 HAL_StatusTypeDef HAL_CRYP_AESCBC_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 1097 HAL_StatusTypeDef HAL_CRYP_AESCTR_Encrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pPlainData, uint16_t Size, uint8_t *pCypherData);
lypinator 0:bb348c97df44 1098 HAL_StatusTypeDef HAL_CRYP_AESCTR_Decrypt_DMA(CRYP_HandleTypeDef *hcryp, uint8_t *pCypherData, uint16_t Size, uint8_t *pPlainData);
lypinator 0:bb348c97df44 1099
lypinator 0:bb348c97df44 1100 /**
lypinator 0:bb348c97df44 1101 * @}
lypinator 0:bb348c97df44 1102 */
lypinator 0:bb348c97df44 1103
lypinator 0:bb348c97df44 1104 /** @addtogroup CRYP_Exported_Functions_Group3 Callback functions
lypinator 0:bb348c97df44 1105 * @{
lypinator 0:bb348c97df44 1106 */
lypinator 0:bb348c97df44 1107 /* CallBack functions ********************************************************/
lypinator 0:bb348c97df44 1108 void HAL_CRYP_InCpltCallback(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1109 void HAL_CRYP_OutCpltCallback(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1110 void HAL_CRYP_ErrorCallback(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1111
lypinator 0:bb348c97df44 1112 /**
lypinator 0:bb348c97df44 1113 * @}
lypinator 0:bb348c97df44 1114 */
lypinator 0:bb348c97df44 1115
lypinator 0:bb348c97df44 1116 /** @addtogroup CRYP_Exported_Functions_Group4 CRYP IRQ handler
lypinator 0:bb348c97df44 1117 * @{
lypinator 0:bb348c97df44 1118 */
lypinator 0:bb348c97df44 1119
lypinator 0:bb348c97df44 1120 /* AES interrupt handling function *******************************************/
lypinator 0:bb348c97df44 1121 void HAL_CRYP_IRQHandler(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1122
lypinator 0:bb348c97df44 1123 /**
lypinator 0:bb348c97df44 1124 * @}
lypinator 0:bb348c97df44 1125 */
lypinator 0:bb348c97df44 1126
lypinator 0:bb348c97df44 1127 /** @addtogroup CRYP_Exported_Functions_Group5 Peripheral State functions
lypinator 0:bb348c97df44 1128 * @{
lypinator 0:bb348c97df44 1129 */
lypinator 0:bb348c97df44 1130
lypinator 0:bb348c97df44 1131 /* Peripheral State functions ************************************************/
lypinator 0:bb348c97df44 1132 HAL_CRYP_STATETypeDef HAL_CRYP_GetState(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1133 uint32_t HAL_CRYP_GetError(CRYP_HandleTypeDef *hcryp);
lypinator 0:bb348c97df44 1134
lypinator 0:bb348c97df44 1135 /**
lypinator 0:bb348c97df44 1136 * @}
lypinator 0:bb348c97df44 1137 */
lypinator 0:bb348c97df44 1138
lypinator 0:bb348c97df44 1139 /**
lypinator 0:bb348c97df44 1140 * @}
lypinator 0:bb348c97df44 1141 */
lypinator 0:bb348c97df44 1142
lypinator 0:bb348c97df44 1143
lypinator 0:bb348c97df44 1144 #endif /* AES */
lypinator 0:bb348c97df44 1145
lypinator 0:bb348c97df44 1146 /**
lypinator 0:bb348c97df44 1147 * @}
lypinator 0:bb348c97df44 1148 */
lypinator 0:bb348c97df44 1149
lypinator 0:bb348c97df44 1150 /**
lypinator 0:bb348c97df44 1151 * @}
lypinator 0:bb348c97df44 1152 */
lypinator 0:bb348c97df44 1153
lypinator 0:bb348c97df44 1154 #ifdef __cplusplus
lypinator 0:bb348c97df44 1155 }
lypinator 0:bb348c97df44 1156 #endif
lypinator 0:bb348c97df44 1157
lypinator 0:bb348c97df44 1158 #endif /* __STM32F4xx_HAL_CRYP_H */
lypinator 0:bb348c97df44 1159
lypinator 0:bb348c97df44 1160 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/