The official Mbed 2 C/C++ SDK provides the software platform and libraries to build your applications.

Dependents:   hello SerialTestv11 SerialTestv12 Sierpinski ... more

mbed 2

This is the mbed 2 library. If you'd like to learn about Mbed OS please see the mbed-os docs.

Committer:
AnnaBridge
Date:
Wed Feb 20 20:53:29 2019 +0000
Revision:
172:65be27845400
Parent:
171:3a7713b1edbc
mbed library release version 165

Who changed what in which revision?

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