mbed official / mbed

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

Committer:
AnnaBridge
Date:
Tue Mar 20 13:30:58 2018 +0000
Revision:
163:e59c8e839560
Parent:
161:aa5281ff4a02
mbed library. Release version 160

Who changed what in which revision?

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