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
mbed library release version 165

Who changed what in which revision?

UserRevisionLine numberNew contents of line
AnnaBridge 172:65be27845400 1 /**
AnnaBridge 172:65be27845400 2 ******************************************************************************
AnnaBridge 172:65be27845400 3 * @file stm32l4xx_hal_hash.h
AnnaBridge 172:65be27845400 4 * @author MCD Application Team
AnnaBridge 172:65be27845400 5 * @brief Header file of HASH HAL module.
AnnaBridge 172:65be27845400 6 ******************************************************************************
AnnaBridge 172:65be27845400 7 * @attention
AnnaBridge 172:65be27845400 8 *
AnnaBridge 172:65be27845400 9 * <h2><center>&copy; COPYRIGHT(c) 2017 STMicroelectronics</center></h2>
AnnaBridge 172:65be27845400 10 *
AnnaBridge 172:65be27845400 11 * Redistribution and use in source and binary forms, with or without modification,
AnnaBridge 172:65be27845400 12 * are permitted provided that the following conditions are met:
AnnaBridge 172:65be27845400 13 * 1. Redistributions of source code must retain the above copyright notice,
AnnaBridge 172:65be27845400 14 * this list of conditions and the following disclaimer.
AnnaBridge 172:65be27845400 15 * 2. Redistributions in binary form must reproduce the above copyright notice,
AnnaBridge 172:65be27845400 16 * this list of conditions and the following disclaimer in the documentation
AnnaBridge 172:65be27845400 17 * and/or other materials provided with the distribution.
AnnaBridge 172:65be27845400 18 * 3. Neither the name of STMicroelectronics nor the names of its contributors
AnnaBridge 172:65be27845400 19 * may be used to endorse or promote products derived from this software
AnnaBridge 172:65be27845400 20 * without specific prior written permission.
AnnaBridge 172:65be27845400 21 *
AnnaBridge 172:65be27845400 22 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
AnnaBridge 172:65be27845400 23 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
AnnaBridge 172:65be27845400 24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
AnnaBridge 172:65be27845400 25 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE
AnnaBridge 172:65be27845400 26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
AnnaBridge 172:65be27845400 27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
AnnaBridge 172:65be27845400 28 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER
AnnaBridge 172:65be27845400 29 * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
AnnaBridge 172:65be27845400 30 * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
AnnaBridge 172:65be27845400 31 * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
AnnaBridge 172:65be27845400 32 *
AnnaBridge 172:65be27845400 33 ******************************************************************************
AnnaBridge 172:65be27845400 34 */
AnnaBridge 172:65be27845400 35
AnnaBridge 172:65be27845400 36 /* Define to prevent recursive inclusion -------------------------------------*/
AnnaBridge 172:65be27845400 37 #ifndef __STM32L4xx_HAL_HASH_H
AnnaBridge 172:65be27845400 38 #define __STM32L4xx_HAL_HASH_H
AnnaBridge 172:65be27845400 39
AnnaBridge 172:65be27845400 40 #ifdef __cplusplus
AnnaBridge 172:65be27845400 41 extern "C" {
AnnaBridge 172:65be27845400 42 #endif
AnnaBridge 172:65be27845400 43
AnnaBridge 172:65be27845400 44 #if defined (STM32L4A6xx) || defined (STM32L4S5xx) || defined (STM32L4S7xx) || defined (STM32L4S9xx)
AnnaBridge 172:65be27845400 45
AnnaBridge 172:65be27845400 46 /* Includes ------------------------------------------------------------------*/
AnnaBridge 172:65be27845400 47 #include "stm32l4xx_hal_def.h"
AnnaBridge 172:65be27845400 48
AnnaBridge 172:65be27845400 49 /** @addtogroup STM32L4xx_HAL_Driver
AnnaBridge 172:65be27845400 50 * @{
AnnaBridge 172:65be27845400 51 */
AnnaBridge 172:65be27845400 52
AnnaBridge 172:65be27845400 53 /** @addtogroup HASH
AnnaBridge 172:65be27845400 54 * @{
AnnaBridge 172:65be27845400 55 */
AnnaBridge 172:65be27845400 56
AnnaBridge 172:65be27845400 57 /* Exported types ------------------------------------------------------------*/
AnnaBridge 172:65be27845400 58 /** @defgroup HASH_Exported_Types HASH Exported Types
AnnaBridge 172:65be27845400 59 * @{
AnnaBridge 172:65be27845400 60 */
AnnaBridge 172:65be27845400 61
AnnaBridge 172:65be27845400 62 /**
AnnaBridge 172:65be27845400 63 * @brief HASH Configuration Structure definition
AnnaBridge 172:65be27845400 64 */
AnnaBridge 172:65be27845400 65 typedef struct
AnnaBridge 172:65be27845400 66 {
AnnaBridge 172:65be27845400 67 uint32_t DataType; /*!< 32-bit data, 16-bit data, 8-bit data or 1-bit data.
AnnaBridge 172:65be27845400 68 This parameter can be a value of @ref HASH_Data_Type. */
AnnaBridge 172:65be27845400 69
AnnaBridge 172:65be27845400 70 uint32_t KeySize; /*!< The key size is used only in HMAC operation. */
AnnaBridge 172:65be27845400 71
AnnaBridge 172:65be27845400 72 uint8_t* pKey; /*!< The key is used only in HMAC operation. */
AnnaBridge 172:65be27845400 73
AnnaBridge 172:65be27845400 74 } HASH_InitTypeDef;
AnnaBridge 172:65be27845400 75
AnnaBridge 172:65be27845400 76 /**
AnnaBridge 172:65be27845400 77 * @brief HAL State structures definition
AnnaBridge 172:65be27845400 78 */
AnnaBridge 172:65be27845400 79 typedef enum
AnnaBridge 172:65be27845400 80 {
AnnaBridge 172:65be27845400 81 HAL_HASH_STATE_RESET = 0x00, /*!< Peripheral is not initialized */
AnnaBridge 172:65be27845400 82 HAL_HASH_STATE_READY = 0x01, /*!< Peripheral Initialized and ready for use */
AnnaBridge 172:65be27845400 83 HAL_HASH_STATE_BUSY = 0x02, /*!< Processing (hashing) is ongoing */
AnnaBridge 172:65be27845400 84 HAL_HASH_STATE_TIMEOUT = 0x06, /*!< Timeout state */
AnnaBridge 172:65be27845400 85 HAL_HASH_STATE_ERROR = 0x07, /*!< Error state */
AnnaBridge 172:65be27845400 86 HAL_HASH_STATE_SUSPENDED = 0x08 /*!< Suspended state */
AnnaBridge 172:65be27845400 87 }HAL_HASH_StateTypeDef;
AnnaBridge 172:65be27845400 88
AnnaBridge 172:65be27845400 89 /**
AnnaBridge 172:65be27845400 90 * @brief HAL phase structures definition
AnnaBridge 172:65be27845400 91 */
AnnaBridge 172:65be27845400 92 typedef enum
AnnaBridge 172:65be27845400 93 {
AnnaBridge 172:65be27845400 94 HAL_HASH_PHASE_READY = 0x01, /*!< HASH peripheral is ready to start */
AnnaBridge 172:65be27845400 95 HAL_HASH_PHASE_PROCESS = 0x02, /*!< HASH peripheral is in HASH processing phase */
AnnaBridge 172:65be27845400 96 HAL_HASH_PHASE_HMAC_STEP_1 = 0x03, /*!< HASH peripheral is in HMAC step 1 processing phase
AnnaBridge 172:65be27845400 97 (step 1 consists in entering the inner hash function key) */
AnnaBridge 172:65be27845400 98 HAL_HASH_PHASE_HMAC_STEP_2 = 0x04, /*!< HASH peripheral is in HMAC step 2 processing phase
AnnaBridge 172:65be27845400 99 (step 2 consists in entering the message text) */
AnnaBridge 172:65be27845400 100 HAL_HASH_PHASE_HMAC_STEP_3 = 0x05 /*!< HASH peripheral is in HMAC step 3 processing phase
AnnaBridge 172:65be27845400 101 (step 3 consists in entering the outer hash function key) */
AnnaBridge 172:65be27845400 102 }HAL_HASH_PhaseTypeDef;
AnnaBridge 172:65be27845400 103
AnnaBridge 172:65be27845400 104 /**
AnnaBridge 172:65be27845400 105 * @brief HAL HASH mode suspend definitions
AnnaBridge 172:65be27845400 106 */
AnnaBridge 172:65be27845400 107 typedef enum
AnnaBridge 172:65be27845400 108 {
AnnaBridge 172:65be27845400 109 HAL_HASH_SUSPEND_NONE = 0x00, /*!< HASH peripheral suspension not requested */
AnnaBridge 172:65be27845400 110 HAL_HASH_SUSPEND = 0x01 /*!< HASH peripheral suspension is requested */
AnnaBridge 172:65be27845400 111 }HAL_HASH_SuspendTypeDef;
AnnaBridge 172:65be27845400 112
AnnaBridge 172:65be27845400 113
AnnaBridge 172:65be27845400 114 /**
AnnaBridge 172:65be27845400 115 * @brief HASH Handle Structure definition
AnnaBridge 172:65be27845400 116 */
AnnaBridge 172:65be27845400 117 typedef struct
AnnaBridge 172:65be27845400 118 {
AnnaBridge 172:65be27845400 119 HASH_InitTypeDef Init; /*!< HASH required parameters */
AnnaBridge 172:65be27845400 120
AnnaBridge 172:65be27845400 121 uint8_t *pHashInBuffPtr; /*!< Pointer to input buffer */
AnnaBridge 172:65be27845400 122
AnnaBridge 172:65be27845400 123 uint8_t *pHashOutBuffPtr; /*!< Pointer to output buffer (digest) */
AnnaBridge 172:65be27845400 124
AnnaBridge 172:65be27845400 125 uint8_t *pHashKeyBuffPtr; /*!< Pointer to key buffer (HMAC only) */
AnnaBridge 172:65be27845400 126
AnnaBridge 172:65be27845400 127 uint8_t *pHashMsgBuffPtr; /*!< Pointer to message buffer (HMAC only) */
AnnaBridge 172:65be27845400 128
AnnaBridge 172:65be27845400 129 uint32_t HashBuffSize; /*!< Size of buffer to be processed */
AnnaBridge 172:65be27845400 130
AnnaBridge 172:65be27845400 131 __IO uint32_t HashInCount; /*!< Counter of inputted data */
AnnaBridge 172:65be27845400 132
AnnaBridge 172:65be27845400 133 __IO uint32_t HashITCounter; /*!< Counter of issued interrupts */
AnnaBridge 172:65be27845400 134
AnnaBridge 172:65be27845400 135 __IO uint32_t HashKeyCount; /*!< Counter for Key inputted data (HMAC only) */
AnnaBridge 172:65be27845400 136
AnnaBridge 172:65be27845400 137 HAL_StatusTypeDef Status; /*!< HASH peripheral status */
AnnaBridge 172:65be27845400 138
AnnaBridge 172:65be27845400 139 HAL_HASH_PhaseTypeDef Phase; /*!< HASH peripheral phase */
AnnaBridge 172:65be27845400 140
AnnaBridge 172:65be27845400 141 DMA_HandleTypeDef *hdmain; /*!< HASH In DMA Handle parameters */
AnnaBridge 172:65be27845400 142
AnnaBridge 172:65be27845400 143 HAL_LockTypeDef Lock; /*!< Locking object */
AnnaBridge 172:65be27845400 144
AnnaBridge 172:65be27845400 145 __IO HAL_HASH_StateTypeDef State; /*!< HASH peripheral state */
AnnaBridge 172:65be27845400 146
AnnaBridge 172:65be27845400 147 HAL_HASH_SuspendTypeDef SuspendRequest; /*!< HASH peripheral suspension request flag */
AnnaBridge 172:65be27845400 148
AnnaBridge 172:65be27845400 149 FlagStatus DigestCalculationDisable; /*!< Digest calculation phase skip (MDMAT bit control) for multi-buffers DMA-based HMAC computation */
AnnaBridge 172:65be27845400 150
AnnaBridge 172:65be27845400 151 __IO uint32_t NbWordsAlreadyPushed; /*!< Numbers of words already pushed in FIFO before inputting new block */
AnnaBridge 172:65be27845400 152
AnnaBridge 172:65be27845400 153 } HASH_HandleTypeDef;
AnnaBridge 172:65be27845400 154
AnnaBridge 172:65be27845400 155 /**
AnnaBridge 172:65be27845400 156 * @}
AnnaBridge 172:65be27845400 157 */
AnnaBridge 172:65be27845400 158
AnnaBridge 172:65be27845400 159 /* Exported constants --------------------------------------------------------*/
AnnaBridge 172:65be27845400 160
AnnaBridge 172:65be27845400 161 /** @defgroup HASH_Exported_Constants HASH Exported Constants
AnnaBridge 172:65be27845400 162 * @{
AnnaBridge 172:65be27845400 163 */
AnnaBridge 172:65be27845400 164
AnnaBridge 172:65be27845400 165 /** @defgroup HASH_Algo_Selection HASH algorithm selection
AnnaBridge 172:65be27845400 166 * @{
AnnaBridge 172:65be27845400 167 */
AnnaBridge 172:65be27845400 168 #define HASH_ALGOSELECTION_SHA1 ((uint32_t)0x0000) /*!< HASH function is SHA1 */
AnnaBridge 172:65be27845400 169 #define HASH_ALGOSELECTION_SHA224 HASH_CR_ALGO_1 /*!< HASH function is SHA224 */
AnnaBridge 172:65be27845400 170 #define HASH_ALGOSELECTION_SHA256 HASH_CR_ALGO /*!< HASH function is SHA256 */
AnnaBridge 172:65be27845400 171 #define HASH_ALGOSELECTION_MD5 HASH_CR_ALGO_0 /*!< HASH function is MD5 */
AnnaBridge 172:65be27845400 172 /**
AnnaBridge 172:65be27845400 173 * @}
AnnaBridge 172:65be27845400 174 */
AnnaBridge 172:65be27845400 175
AnnaBridge 172:65be27845400 176 /** @defgroup HASH_Algorithm_Mode HASH algorithm mode
AnnaBridge 172:65be27845400 177 * @{
AnnaBridge 172:65be27845400 178 */
AnnaBridge 172:65be27845400 179 #define HASH_ALGOMODE_HASH ((uint32_t)0x00000000) /*!< Algorithm is HASH */
AnnaBridge 172:65be27845400 180 #define HASH_ALGOMODE_HMAC HASH_CR_MODE /*!< Algorithm is HMAC */
AnnaBridge 172:65be27845400 181 /**
AnnaBridge 172:65be27845400 182 * @}
AnnaBridge 172:65be27845400 183 */
AnnaBridge 172:65be27845400 184
AnnaBridge 172:65be27845400 185 /** @defgroup HASH_Data_Type HASH input data type
AnnaBridge 172:65be27845400 186 * @{
AnnaBridge 172:65be27845400 187 */
AnnaBridge 172:65be27845400 188 #define HASH_DATATYPE_32B ((uint32_t)0x0000) /*!< 32-bit data. No swapping */
AnnaBridge 172:65be27845400 189 #define HASH_DATATYPE_16B HASH_CR_DATATYPE_0 /*!< 16-bit data. Each half word is swapped */
AnnaBridge 172:65be27845400 190 #define HASH_DATATYPE_8B HASH_CR_DATATYPE_1 /*!< 8-bit data. All bytes are swapped */
AnnaBridge 172:65be27845400 191 #define HASH_DATATYPE_1B HASH_CR_DATATYPE /*!< 1-bit data. In the word all bits are swapped */
AnnaBridge 172:65be27845400 192 /**
AnnaBridge 172:65be27845400 193 * @}
AnnaBridge 172:65be27845400 194 */
AnnaBridge 172:65be27845400 195
AnnaBridge 172:65be27845400 196 /** @defgroup HASH_HMAC_Long_key_only_for_HMAC_mode HMAC key length type
AnnaBridge 172:65be27845400 197 * @{
AnnaBridge 172:65be27845400 198 */
AnnaBridge 172:65be27845400 199 #define HASH_HMAC_KEYTYPE_SHORTKEY ((uint32_t)0x00000000) /*!< HMAC Key size is <= 64 bytes */
AnnaBridge 172:65be27845400 200 #define HASH_HMAC_KEYTYPE_LONGKEY HASH_CR_LKEY /*!< HMAC Key size is > 64 bytes */
AnnaBridge 172:65be27845400 201 /**
AnnaBridge 172:65be27845400 202 * @}
AnnaBridge 172:65be27845400 203 */
AnnaBridge 172:65be27845400 204
AnnaBridge 172:65be27845400 205 /** @defgroup HASH_flags_definition HASH flags definitions
AnnaBridge 172:65be27845400 206 * @{
AnnaBridge 172:65be27845400 207 */
AnnaBridge 172:65be27845400 208 #define HASH_FLAG_DINIS HASH_SR_DINIS /*!< 16 locations are free in the DIN : a new block can be entered in the IP */
AnnaBridge 172:65be27845400 209 #define HASH_FLAG_DCIS HASH_SR_DCIS /*!< Digest calculation complete */
AnnaBridge 172:65be27845400 210 #define HASH_FLAG_DMAS HASH_SR_DMAS /*!< DMA interface is enabled (DMAE=1) or a transfer is ongoing */
AnnaBridge 172:65be27845400 211 #define HASH_FLAG_BUSY HASH_SR_BUSY /*!< The hash core is Busy, processing a block of data */
AnnaBridge 172:65be27845400 212 #define HASH_FLAG_DINNE HASH_CR_DINNE /*!< DIN not empty : the input buffer contains at least one word of data */
AnnaBridge 172:65be27845400 213
AnnaBridge 172:65be27845400 214 /**
AnnaBridge 172:65be27845400 215 * @}
AnnaBridge 172:65be27845400 216 */
AnnaBridge 172:65be27845400 217
AnnaBridge 172:65be27845400 218 /** @defgroup HASH_interrupts_definition HASH interrupts definitions
AnnaBridge 172:65be27845400 219 * @{
AnnaBridge 172:65be27845400 220 */
AnnaBridge 172:65be27845400 221 #define HASH_IT_DINI HASH_IMR_DINIE /*!< A new block can be entered into the input buffer (DIN) */
AnnaBridge 172:65be27845400 222 #define HASH_IT_DCI HASH_IMR_DCIE /*!< Digest calculation complete */
AnnaBridge 172:65be27845400 223
AnnaBridge 172:65be27845400 224 /**
AnnaBridge 172:65be27845400 225 * @}
AnnaBridge 172:65be27845400 226 */
AnnaBridge 172:65be27845400 227
AnnaBridge 172:65be27845400 228 /** @defgroup HASH_alias HASH API alias
AnnaBridge 172:65be27845400 229 * @{
AnnaBridge 172:65be27845400 230 */
AnnaBridge 172:65be27845400 231 #define HAL_HASHEx_IRQHandler HAL_HASH_IRQHandler /*!< HAL_HASHEx_IRQHandler() is re-directed to HAL_HASH_IRQHandler() for compatibility with legacy code */
AnnaBridge 172:65be27845400 232 /**
AnnaBridge 172:65be27845400 233 * @}
AnnaBridge 172:65be27845400 234 */
AnnaBridge 172:65be27845400 235
AnnaBridge 172:65be27845400 236
AnnaBridge 172:65be27845400 237
AnnaBridge 172:65be27845400 238 /**
AnnaBridge 172:65be27845400 239 * @}
AnnaBridge 172:65be27845400 240 */
AnnaBridge 172:65be27845400 241
AnnaBridge 172:65be27845400 242 /* Exported macros -----------------------------------------------------------*/
AnnaBridge 172:65be27845400 243 /** @defgroup HASH_Exported_Macros HASH Exported Macros
AnnaBridge 172:65be27845400 244 * @{
AnnaBridge 172:65be27845400 245 */
AnnaBridge 172:65be27845400 246
AnnaBridge 172:65be27845400 247 /** @brief Check whether or not the specified HASH flag is set.
AnnaBridge 172:65be27845400 248 * @param __FLAG__: specifies the flag to check.
AnnaBridge 172:65be27845400 249 * This parameter can be one of the following values:
AnnaBridge 172:65be27845400 250 * @arg @ref HASH_FLAG_DINIS A new block can be entered into the input buffer.
AnnaBridge 172:65be27845400 251 * @arg @ref HASH_FLAG_DCIS Digest calculation complete.
AnnaBridge 172:65be27845400 252 * @arg @ref HASH_FLAG_DMAS DMA interface is enabled (DMAE=1) or a transfer is ongoing.
AnnaBridge 172:65be27845400 253 * @arg @ref HASH_FLAG_BUSY The hash core is Busy : processing a block of data.
AnnaBridge 172:65be27845400 254 * @arg @ref HASH_FLAG_DINNE DIN not empty : the input buffer contains at least one word of data.
AnnaBridge 172:65be27845400 255 * @retval The new state of __FLAG__ (TRUE or FALSE).
AnnaBridge 172:65be27845400 256 */
AnnaBridge 172:65be27845400 257 #define __HAL_HASH_GET_FLAG(__FLAG__) (((__FLAG__) > 8U) ? \
AnnaBridge 172:65be27845400 258 ((HASH->CR & (__FLAG__)) == (__FLAG__)) :\
AnnaBridge 172:65be27845400 259 ((HASH->SR & (__FLAG__)) == (__FLAG__)) )
AnnaBridge 172:65be27845400 260
AnnaBridge 172:65be27845400 261
AnnaBridge 172:65be27845400 262 /** @brief Clear the specified HASH flag.
AnnaBridge 172:65be27845400 263 * @param __FLAG__: specifies the flag to clear.
AnnaBridge 172:65be27845400 264 * This parameter can be one of the following values:
AnnaBridge 172:65be27845400 265 * @arg @ref HASH_FLAG_DINIS A new block can be entered into the input buffer.
AnnaBridge 172:65be27845400 266 * @arg @ref HASH_FLAG_DCIS Digest calculation complete
AnnaBridge 172:65be27845400 267 * @retval None
AnnaBridge 172:65be27845400 268 */
AnnaBridge 172:65be27845400 269 #define __HAL_HASH_CLEAR_FLAG(__FLAG__) CLEAR_BIT(HASH->SR, (__FLAG__))
AnnaBridge 172:65be27845400 270
AnnaBridge 172:65be27845400 271
AnnaBridge 172:65be27845400 272 /** @brief Enable the specified HASH interrupt.
AnnaBridge 172:65be27845400 273 * @param __INTERRUPT__: specifies the HASH interrupt source to enable.
AnnaBridge 172:65be27845400 274 * This parameter can be one of the following values:
AnnaBridge 172:65be27845400 275 * @arg @ref HASH_IT_DINI A new block can be entered into the input buffer (DIN)
AnnaBridge 172:65be27845400 276 * @arg @ref HASH_IT_DCI Digest calculation complete
AnnaBridge 172:65be27845400 277 * @retval None
AnnaBridge 172:65be27845400 278 */
AnnaBridge 172:65be27845400 279 #define __HAL_HASH_ENABLE_IT(__INTERRUPT__) SET_BIT(HASH->IMR, (__INTERRUPT__))
AnnaBridge 172:65be27845400 280
AnnaBridge 172:65be27845400 281 /** @brief Disable the specified HASH interrupt.
AnnaBridge 172:65be27845400 282 * @param __INTERRUPT__: specifies the HASH interrupt source to disable.
AnnaBridge 172:65be27845400 283 * This parameter can be one of the following values:
AnnaBridge 172:65be27845400 284 * @arg @ref HASH_IT_DINI A new block can be entered into the input buffer (DIN)
AnnaBridge 172:65be27845400 285 * @arg @ref HASH_IT_DCI Digest calculation complete
AnnaBridge 172:65be27845400 286 * @retval None
AnnaBridge 172:65be27845400 287 */
AnnaBridge 172:65be27845400 288 #define __HAL_HASH_DISABLE_IT(__INTERRUPT__) CLEAR_BIT(HASH->IMR, (__INTERRUPT__))
AnnaBridge 172:65be27845400 289
AnnaBridge 172:65be27845400 290 /** @brief Reset HASH handle state.
AnnaBridge 172:65be27845400 291 * @param __HANDLE__: HASH handle.
AnnaBridge 172:65be27845400 292 * @retval None
AnnaBridge 172:65be27845400 293 */
AnnaBridge 172:65be27845400 294 #define __HAL_HASH_RESET_HANDLE_STATE(__HANDLE__) ((__HANDLE__)->State = HAL_HASH_STATE_RESET)
AnnaBridge 172:65be27845400 295
AnnaBridge 172:65be27845400 296 /** @brief Reset HASH handle status.
AnnaBridge 172:65be27845400 297 * @param __HANDLE__: HASH handle.
AnnaBridge 172:65be27845400 298 * @retval None
AnnaBridge 172:65be27845400 299 */
AnnaBridge 172:65be27845400 300 #define __HAL_HASH_RESET_HANDLE_STATUS(__HANDLE__) ((__HANDLE__)->Status = HAL_OK)
AnnaBridge 172:65be27845400 301
AnnaBridge 172:65be27845400 302 /**
AnnaBridge 172:65be27845400 303 * @brief Enable the multi-buffer DMA transfer mode.
AnnaBridge 172:65be27845400 304 * @note This bit is set when hashing large files when multiple DMA transfers are needed.
AnnaBridge 172:65be27845400 305 * @retval None
AnnaBridge 172:65be27845400 306 */
AnnaBridge 172:65be27845400 307 #define __HAL_HASH_SET_MDMAT() SET_BIT(HASH->CR, HASH_CR_MDMAT)
AnnaBridge 172:65be27845400 308
AnnaBridge 172:65be27845400 309 /**
AnnaBridge 172:65be27845400 310 * @brief Disable the multi-buffer DMA transfer mode.
AnnaBridge 172:65be27845400 311 * @retval None
AnnaBridge 172:65be27845400 312 */
AnnaBridge 172:65be27845400 313 #define __HAL_HASH_RESET_MDMAT() CLEAR_BIT(HASH->CR, HASH_CR_MDMAT)
AnnaBridge 172:65be27845400 314
AnnaBridge 172:65be27845400 315
AnnaBridge 172:65be27845400 316
AnnaBridge 172:65be27845400 317 /**
AnnaBridge 172:65be27845400 318 * @brief Start the digest computation.
AnnaBridge 172:65be27845400 319 * @retval None
AnnaBridge 172:65be27845400 320 */
AnnaBridge 172:65be27845400 321 #define __HAL_HASH_START_DIGEST() SET_BIT(HASH->STR, HASH_STR_DCAL)
AnnaBridge 172:65be27845400 322
AnnaBridge 172:65be27845400 323 /**
AnnaBridge 172:65be27845400 324 * @brief Set the number of valid bits in the last word written in data register DIN.
AnnaBridge 172:65be27845400 325 * @param __SIZE__: size in bytes of last data written in Data register.
AnnaBridge 172:65be27845400 326 * @retval None
AnnaBridge 172:65be27845400 327 */
AnnaBridge 172:65be27845400 328 #define __HAL_HASH_SET_NBVALIDBITS(__SIZE__) MODIFY_REG(HASH->STR, HASH_STR_NBLW, 8 * ((__SIZE__) % 4))
AnnaBridge 172:65be27845400 329
AnnaBridge 172:65be27845400 330 /**
AnnaBridge 172:65be27845400 331 * @brief Reset the HASH core.
AnnaBridge 172:65be27845400 332 * @retval None
AnnaBridge 172:65be27845400 333 */
AnnaBridge 172:65be27845400 334 #define __HAL_HASH_INIT() SET_BIT(HASH->CR, HASH_CR_INIT)
AnnaBridge 172:65be27845400 335
AnnaBridge 172:65be27845400 336 /**
AnnaBridge 172:65be27845400 337 * @}
AnnaBridge 172:65be27845400 338 */
AnnaBridge 172:65be27845400 339
AnnaBridge 172:65be27845400 340
AnnaBridge 172:65be27845400 341 /* Private macros --------------------------------------------------------*/
AnnaBridge 172:65be27845400 342 /** @defgroup HASH_Private_Macros HASH Private Macros
AnnaBridge 172:65be27845400 343 * @{
AnnaBridge 172:65be27845400 344 */
AnnaBridge 172:65be27845400 345
AnnaBridge 172:65be27845400 346 /**
AnnaBridge 172:65be27845400 347 * @brief Return digest length in bytes.
AnnaBridge 172:65be27845400 348 * @retval Digest length
AnnaBridge 172:65be27845400 349 */
AnnaBridge 172:65be27845400 350 #define HASH_DIGEST_LENGTH() ((READ_BIT(HASH->CR, HASH_CR_ALGO) == HASH_ALGOSELECTION_SHA1) ? 20 : \
AnnaBridge 172:65be27845400 351 ((READ_BIT(HASH->CR, HASH_CR_ALGO) == HASH_ALGOSELECTION_SHA224) ? 28 : \
AnnaBridge 172:65be27845400 352 ((READ_BIT(HASH->CR, HASH_CR_ALGO) == HASH_ALGOSELECTION_SHA256) ? 32 : 16 ) ) )
AnnaBridge 172:65be27845400 353
AnnaBridge 172:65be27845400 354 /**
AnnaBridge 172:65be27845400 355 * @brief Return number of words already pushed in the FIFO.
AnnaBridge 172:65be27845400 356 * @retval Number of words already pushed in the FIFO
AnnaBridge 172:65be27845400 357 */
AnnaBridge 172:65be27845400 358 #define HASH_NBW_PUSHED() ((READ_BIT(HASH->CR, HASH_CR_NBW)) >> 8)
AnnaBridge 172:65be27845400 359
AnnaBridge 172:65be27845400 360 /**
AnnaBridge 172:65be27845400 361 * @brief Ensure that HASH input data type is valid.
AnnaBridge 172:65be27845400 362 * @param __DATATYPE__: HASH input data type.
AnnaBridge 172:65be27845400 363 * @retval SET (__DATATYPE__ is valid) or RESET (__DATATYPE__ is invalid)
AnnaBridge 172:65be27845400 364 */
AnnaBridge 172:65be27845400 365 #define IS_HASH_DATATYPE(__DATATYPE__) (((__DATATYPE__) == HASH_DATATYPE_32B)|| \
AnnaBridge 172:65be27845400 366 ((__DATATYPE__) == HASH_DATATYPE_16B)|| \
AnnaBridge 172:65be27845400 367 ((__DATATYPE__) == HASH_DATATYPE_8B) || \
AnnaBridge 172:65be27845400 368 ((__DATATYPE__) == HASH_DATATYPE_1B))
AnnaBridge 172:65be27845400 369
AnnaBridge 172:65be27845400 370
AnnaBridge 172:65be27845400 371
AnnaBridge 172:65be27845400 372 /**
AnnaBridge 172:65be27845400 373 * @brief Ensure that input data buffer size is valid for multi-buffer HASH
AnnaBridge 172:65be27845400 374 * processing in polling mode.
AnnaBridge 172:65be27845400 375 * @note This check is valid only for multi-buffer HASH processing in polling mode.
AnnaBridge 172:65be27845400 376 * @param __SIZE__: input data buffer size.
AnnaBridge 172:65be27845400 377 * @retval SET (__SIZE__ is valid) or RESET (__SIZE__ is invalid)
AnnaBridge 172:65be27845400 378 */
AnnaBridge 172:65be27845400 379 #define IS_HASH_POLLING_MULTIBUFFER_SIZE(__SIZE__) (((__SIZE__) % 4) == 0)
AnnaBridge 172:65be27845400 380
AnnaBridge 172:65be27845400 381 /**
AnnaBridge 172:65be27845400 382 * @brief Ensure that input data buffer size is valid for multi-buffer HASH
AnnaBridge 172:65be27845400 383 * processing in DMA mode.
AnnaBridge 172:65be27845400 384 * @note This check is valid only for multi-buffer HASH processing in DMA mode.
AnnaBridge 172:65be27845400 385 * @param __SIZE__: input data buffer size.
AnnaBridge 172:65be27845400 386 * @retval SET (__SIZE__ is valid) or RESET (__SIZE__ is invalid)
AnnaBridge 172:65be27845400 387 */
AnnaBridge 172:65be27845400 388 #define IS_HASH_DMA_MULTIBUFFER_SIZE(__SIZE__) ((READ_BIT(HASH->CR, HASH_CR_MDMAT) == RESET) || (((__SIZE__) % 4) == 0))
AnnaBridge 172:65be27845400 389
AnnaBridge 172:65be27845400 390 /**
AnnaBridge 172:65be27845400 391 * @brief Ensure that input data buffer size is valid for multi-buffer HMAC
AnnaBridge 172:65be27845400 392 * processing in DMA mode.
AnnaBridge 172:65be27845400 393 * @note This check is valid only for multi-buffer HMAC processing in DMA mode.
AnnaBridge 172:65be27845400 394 * @param __HANDLE__: HASH handle.
AnnaBridge 172:65be27845400 395 * @param __SIZE__: input data buffer size.
AnnaBridge 172:65be27845400 396 * @retval SET (__SIZE__ is valid) or RESET (__SIZE__ is invalid)
AnnaBridge 172:65be27845400 397 */
AnnaBridge 172:65be27845400 398 #define IS_HMAC_DMA_MULTIBUFFER_SIZE(__HANDLE__,__SIZE__) ((((__HANDLE__)->DigestCalculationDisable) == RESET) || (((__SIZE__) % 4) == 0))
AnnaBridge 172:65be27845400 399
AnnaBridge 172:65be27845400 400 /**
AnnaBridge 172:65be27845400 401 * @brief Ensure that handle phase is set to HASH processing.
AnnaBridge 172:65be27845400 402 * @param __HANDLE__: HASH handle.
AnnaBridge 172:65be27845400 403 * @retval SET (handle phase is set to HASH processing) or RESET (handle phase is not set to HASH processing)
AnnaBridge 172:65be27845400 404 */
AnnaBridge 172:65be27845400 405 #define IS_HASH_PROCESSING(__HANDLE__) ((__HANDLE__)->Phase == HAL_HASH_PHASE_PROCESS)
AnnaBridge 172:65be27845400 406
AnnaBridge 172:65be27845400 407 /**
AnnaBridge 172:65be27845400 408 * @brief Ensure that handle phase is set to HMAC processing.
AnnaBridge 172:65be27845400 409 * @param __HANDLE__: HASH handle.
AnnaBridge 172:65be27845400 410 * @retval SET (handle phase is set to HMAC processing) or RESET (handle phase is not set to HMAC processing)
AnnaBridge 172:65be27845400 411 */
AnnaBridge 172:65be27845400 412 #define IS_HMAC_PROCESSING(__HANDLE__) (((__HANDLE__)->Phase == HAL_HASH_PHASE_HMAC_STEP_1) || \
AnnaBridge 172:65be27845400 413 ((__HANDLE__)->Phase == HAL_HASH_PHASE_HMAC_STEP_2) || \
AnnaBridge 172:65be27845400 414 ((__HANDLE__)->Phase == HAL_HASH_PHASE_HMAC_STEP_3))
AnnaBridge 172:65be27845400 415
AnnaBridge 172:65be27845400 416 /**
AnnaBridge 172:65be27845400 417 * @}
AnnaBridge 172:65be27845400 418 */
AnnaBridge 172:65be27845400 419
AnnaBridge 172:65be27845400 420
AnnaBridge 172:65be27845400 421 /* Include HASH HAL Extended module */
AnnaBridge 172:65be27845400 422 #include "stm32l4xx_hal_hash_ex.h"
AnnaBridge 172:65be27845400 423 /* Exported functions --------------------------------------------------------*/
AnnaBridge 172:65be27845400 424
AnnaBridge 172:65be27845400 425 /** @addtogroup HASH_Exported_Functions HASH Exported Functions
AnnaBridge 172:65be27845400 426 * @{
AnnaBridge 172:65be27845400 427 */
AnnaBridge 172:65be27845400 428
AnnaBridge 172:65be27845400 429 /** @addtogroup HASH_Exported_Functions_Group1 Initialization and de-initialization functions
AnnaBridge 172:65be27845400 430 * @{
AnnaBridge 172:65be27845400 431 */
AnnaBridge 172:65be27845400 432
AnnaBridge 172:65be27845400 433 /* Initialization/de-initialization methods **********************************/
AnnaBridge 172:65be27845400 434 HAL_StatusTypeDef HAL_HASH_Init(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 435 HAL_StatusTypeDef HAL_HASH_DeInit(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 436 void HAL_HASH_MspInit(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 437 void HAL_HASH_MspDeInit(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 438 void HAL_HASH_InCpltCallback(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 439 void HAL_HASH_DgstCpltCallback(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 440 void HAL_HASH_ErrorCallback(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 441
AnnaBridge 172:65be27845400 442 /**
AnnaBridge 172:65be27845400 443 * @}
AnnaBridge 172:65be27845400 444 */
AnnaBridge 172:65be27845400 445
AnnaBridge 172:65be27845400 446 /** @addtogroup HASH_Exported_Functions_Group2 HASH processing functions in polling mode
AnnaBridge 172:65be27845400 447 * @{
AnnaBridge 172:65be27845400 448 */
AnnaBridge 172:65be27845400 449
AnnaBridge 172:65be27845400 450
AnnaBridge 172:65be27845400 451 /* HASH processing using polling *********************************************/
AnnaBridge 172:65be27845400 452 HAL_StatusTypeDef HAL_HASH_SHA1_Start(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer, uint32_t Timeout);
AnnaBridge 172:65be27845400 453 HAL_StatusTypeDef HAL_HASH_MD5_Start(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer, uint32_t Timeout);
AnnaBridge 172:65be27845400 454 HAL_StatusTypeDef HAL_HASH_MD5_Accumulate(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size);
AnnaBridge 172:65be27845400 455 HAL_StatusTypeDef HAL_HASH_SHA1_Accumulate(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size);
AnnaBridge 172:65be27845400 456
AnnaBridge 172:65be27845400 457 /**
AnnaBridge 172:65be27845400 458 * @}
AnnaBridge 172:65be27845400 459 */
AnnaBridge 172:65be27845400 460
AnnaBridge 172:65be27845400 461 /** @addtogroup HASH_Exported_Functions_Group3 HASH processing functions in interrupt mode
AnnaBridge 172:65be27845400 462 * @{
AnnaBridge 172:65be27845400 463 */
AnnaBridge 172:65be27845400 464
AnnaBridge 172:65be27845400 465 /* HASH processing using IT **************************************************/
AnnaBridge 172:65be27845400 466 HAL_StatusTypeDef HAL_HASH_SHA1_Start_IT(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer);
AnnaBridge 172:65be27845400 467 HAL_StatusTypeDef HAL_HASH_MD5_Start_IT(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer);
AnnaBridge 172:65be27845400 468 void HAL_HASH_IRQHandler(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 469 /**
AnnaBridge 172:65be27845400 470 * @}
AnnaBridge 172:65be27845400 471 */
AnnaBridge 172:65be27845400 472
AnnaBridge 172:65be27845400 473 /** @addtogroup HASH_Exported_Functions_Group4 HASH processing functions in DMA mode
AnnaBridge 172:65be27845400 474 * @{
AnnaBridge 172:65be27845400 475 */
AnnaBridge 172:65be27845400 476
AnnaBridge 172:65be27845400 477 /* HASH processing using DMA *************************************************/
AnnaBridge 172:65be27845400 478 HAL_StatusTypeDef HAL_HASH_SHA1_Start_DMA(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size);
AnnaBridge 172:65be27845400 479 HAL_StatusTypeDef HAL_HASH_SHA1_Finish(HASH_HandleTypeDef *hhash, uint8_t* pOutBuffer, uint32_t Timeout);
AnnaBridge 172:65be27845400 480 HAL_StatusTypeDef HAL_HASH_MD5_Start_DMA(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size);
AnnaBridge 172:65be27845400 481 HAL_StatusTypeDef HAL_HASH_MD5_Finish(HASH_HandleTypeDef *hhash, uint8_t* pOutBuffer, uint32_t Timeout);
AnnaBridge 172:65be27845400 482
AnnaBridge 172:65be27845400 483 /**
AnnaBridge 172:65be27845400 484 * @}
AnnaBridge 172:65be27845400 485 */
AnnaBridge 172:65be27845400 486
AnnaBridge 172:65be27845400 487 /** @addtogroup HASH_Exported_Functions_Group5 HMAC processing functions in polling mode
AnnaBridge 172:65be27845400 488 * @{
AnnaBridge 172:65be27845400 489 */
AnnaBridge 172:65be27845400 490
AnnaBridge 172:65be27845400 491 /* HASH-MAC processing using polling *****************************************/
AnnaBridge 172:65be27845400 492 HAL_StatusTypeDef HAL_HMAC_SHA1_Start(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer, uint32_t Timeout);
AnnaBridge 172:65be27845400 493 HAL_StatusTypeDef HAL_HMAC_MD5_Start(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer, uint32_t Timeout);
AnnaBridge 172:65be27845400 494
AnnaBridge 172:65be27845400 495 /**
AnnaBridge 172:65be27845400 496 * @}
AnnaBridge 172:65be27845400 497 */
AnnaBridge 172:65be27845400 498
AnnaBridge 172:65be27845400 499 /** @addtogroup HASH_Exported_Functions_Group6 HMAC processing functions in interrupt mode
AnnaBridge 172:65be27845400 500 * @{
AnnaBridge 172:65be27845400 501 */
AnnaBridge 172:65be27845400 502
AnnaBridge 172:65be27845400 503 HAL_StatusTypeDef HAL_HMAC_MD5_Start_IT(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer);
AnnaBridge 172:65be27845400 504 HAL_StatusTypeDef HAL_HMAC_SHA1_Start_IT(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer);
AnnaBridge 172:65be27845400 505
AnnaBridge 172:65be27845400 506 /**
AnnaBridge 172:65be27845400 507 * @}
AnnaBridge 172:65be27845400 508 */
AnnaBridge 172:65be27845400 509
AnnaBridge 172:65be27845400 510 /** @addtogroup HASH_Exported_Functions_Group7 HMAC processing functions in DMA mode
AnnaBridge 172:65be27845400 511 * @{
AnnaBridge 172:65be27845400 512 */
AnnaBridge 172:65be27845400 513
AnnaBridge 172:65be27845400 514 /* HASH-HMAC processing using DMA ********************************************/
AnnaBridge 172:65be27845400 515 HAL_StatusTypeDef HAL_HMAC_SHA1_Start_DMA(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size);
AnnaBridge 172:65be27845400 516 HAL_StatusTypeDef HAL_HMAC_MD5_Start_DMA(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size);
AnnaBridge 172:65be27845400 517
AnnaBridge 172:65be27845400 518 /**
AnnaBridge 172:65be27845400 519 * @}
AnnaBridge 172:65be27845400 520 */
AnnaBridge 172:65be27845400 521
AnnaBridge 172:65be27845400 522 /** @addtogroup HASH_Exported_Functions_Group8 Peripheral states functions
AnnaBridge 172:65be27845400 523 * @{
AnnaBridge 172:65be27845400 524 */
AnnaBridge 172:65be27845400 525
AnnaBridge 172:65be27845400 526
AnnaBridge 172:65be27845400 527 /* Peripheral State methods **************************************************/
AnnaBridge 172:65be27845400 528 HAL_HASH_StateTypeDef HAL_HASH_GetState(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 529 HAL_StatusTypeDef HAL_HASH_GetStatus(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 530 void HAL_HASH_ContextSaving(HASH_HandleTypeDef *hhash, uint8_t* pMemBuffer);
AnnaBridge 172:65be27845400 531 void HAL_HASH_ContextRestoring(HASH_HandleTypeDef *hhash, uint8_t* pMemBuffer);
AnnaBridge 172:65be27845400 532 void HAL_HASH_SwFeed_ProcessSuspend(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 533 HAL_StatusTypeDef HAL_HASH_DMAFeed_ProcessSuspend(HASH_HandleTypeDef *hhash);
AnnaBridge 172:65be27845400 534
AnnaBridge 172:65be27845400 535 /**
AnnaBridge 172:65be27845400 536 * @}
AnnaBridge 172:65be27845400 537 */
AnnaBridge 172:65be27845400 538
AnnaBridge 172:65be27845400 539 /**
AnnaBridge 172:65be27845400 540 * @}
AnnaBridge 172:65be27845400 541 */
AnnaBridge 172:65be27845400 542
AnnaBridge 172:65be27845400 543 /* Private functions -----------------------------------------------------------*/
AnnaBridge 172:65be27845400 544
AnnaBridge 172:65be27845400 545 /** @addtogroup HASH_Private_Functions HASH Private Functions
AnnaBridge 172:65be27845400 546 * @{
AnnaBridge 172:65be27845400 547 */
AnnaBridge 172:65be27845400 548
AnnaBridge 172:65be27845400 549 /* Private functions */
AnnaBridge 172:65be27845400 550 HAL_StatusTypeDef HASH_Start(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer, uint32_t Timeout, uint32_t Algorithm);
AnnaBridge 172:65be27845400 551 HAL_StatusTypeDef HASH_Accumulate(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint32_t Algorithm);
AnnaBridge 172:65be27845400 552 HAL_StatusTypeDef HASH_Start_IT(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer, uint32_t Algorithm);
AnnaBridge 172:65be27845400 553 HAL_StatusTypeDef HASH_Start_DMA(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint32_t Algorithm);
AnnaBridge 172:65be27845400 554 HAL_StatusTypeDef HASH_Finish(HASH_HandleTypeDef *hhash, uint8_t* pOutBuffer, uint32_t Timeout);
AnnaBridge 172:65be27845400 555 HAL_StatusTypeDef HMAC_Start(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer, uint32_t Timeout, uint32_t Algorithm);
AnnaBridge 172:65be27845400 556 HAL_StatusTypeDef HMAC_Start_IT(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint8_t* pOutBuffer, uint32_t Algorithm);
AnnaBridge 172:65be27845400 557 HAL_StatusTypeDef HMAC_Start_DMA(HASH_HandleTypeDef *hhash, uint8_t *pInBuffer, uint32_t Size, uint32_t Algorithm);
AnnaBridge 172:65be27845400 558
AnnaBridge 172:65be27845400 559 /**
AnnaBridge 172:65be27845400 560 * @}
AnnaBridge 172:65be27845400 561 */
AnnaBridge 172:65be27845400 562
AnnaBridge 172:65be27845400 563 /**
AnnaBridge 172:65be27845400 564 * @}
AnnaBridge 172:65be27845400 565 */
AnnaBridge 172:65be27845400 566
AnnaBridge 172:65be27845400 567 /**
AnnaBridge 172:65be27845400 568 * @}
AnnaBridge 172:65be27845400 569 */
AnnaBridge 172:65be27845400 570
AnnaBridge 172:65be27845400 571 #endif /* defined (STM32L4A6xx) || defined (STM32L4S5xx) || defined (STM32L4S7xx) || defined (STM32L4S9xx) */
AnnaBridge 172:65be27845400 572
AnnaBridge 172:65be27845400 573 #ifdef __cplusplus
AnnaBridge 172:65be27845400 574 }
AnnaBridge 172:65be27845400 575 #endif
AnnaBridge 172:65be27845400 576
AnnaBridge 172:65be27845400 577
AnnaBridge 172:65be27845400 578 #endif /* __STM32L4xx_HAL_HASH_H */
AnnaBridge 172:65be27845400 579
AnnaBridge 172:65be27845400 580 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/