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.
TARGET_ARCH_MAX/TOOLCHAIN_GCC_ARM/stm32f4xx_hal_flash.h@172:65be27845400, 2019-02-20 (annotated)
- 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?
User | Revision | Line number | New contents of line |
---|---|---|---|
Anna Bridge |
160:5571c4ff569f | 1 | /** |
Anna Bridge |
160:5571c4ff569f | 2 | ****************************************************************************** |
Anna Bridge |
160:5571c4ff569f | 3 | * @file stm32f4xx_hal_flash.h |
Anna Bridge |
160:5571c4ff569f | 4 | * @author MCD Application Team |
Anna Bridge |
160:5571c4ff569f | 5 | * @brief Header file of FLASH HAL module. |
Anna Bridge |
160:5571c4ff569f | 6 | ****************************************************************************** |
Anna Bridge |
160:5571c4ff569f | 7 | * @attention |
Anna Bridge |
160:5571c4ff569f | 8 | * |
Anna Bridge |
160:5571c4ff569f | 9 | * <h2><center>© COPYRIGHT(c) 2017 STMicroelectronics</center></h2> |
Anna Bridge |
160:5571c4ff569f | 10 | * |
Anna Bridge |
160:5571c4ff569f | 11 | * Redistribution and use in source and binary forms, with or without modification, |
Anna Bridge |
160:5571c4ff569f | 12 | * are permitted provided that the following conditions are met: |
Anna Bridge |
160:5571c4ff569f | 13 | * 1. Redistributions of source code must retain the above copyright notice, |
Anna Bridge |
160:5571c4ff569f | 14 | * this list of conditions and the following disclaimer. |
Anna Bridge |
160:5571c4ff569f | 15 | * 2. Redistributions in binary form must reproduce the above copyright notice, |
Anna Bridge |
160:5571c4ff569f | 16 | * this list of conditions and the following disclaimer in the documentation |
Anna Bridge |
160:5571c4ff569f | 17 | * and/or other materials provided with the distribution. |
Anna Bridge |
160:5571c4ff569f | 18 | * 3. Neither the name of STMicroelectronics nor the names of its contributors |
Anna Bridge |
160:5571c4ff569f | 19 | * may be used to endorse or promote products derived from this software |
Anna Bridge |
160:5571c4ff569f | 20 | * without specific prior written permission. |
Anna Bridge |
160:5571c4ff569f | 21 | * |
Anna Bridge |
160:5571c4ff569f | 22 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" |
Anna Bridge |
160:5571c4ff569f | 23 | * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE |
Anna Bridge |
160:5571c4ff569f | 24 | * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE |
Anna Bridge |
160:5571c4ff569f | 25 | * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE |
Anna Bridge |
160:5571c4ff569f | 26 | * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL |
Anna Bridge |
160:5571c4ff569f | 27 | * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR |
Anna Bridge |
160:5571c4ff569f | 28 | * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER |
Anna Bridge |
160:5571c4ff569f | 29 | * CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, |
Anna Bridge |
160:5571c4ff569f | 30 | * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
Anna Bridge |
160:5571c4ff569f | 31 | * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
Anna Bridge |
160:5571c4ff569f | 32 | * |
Anna Bridge |
160:5571c4ff569f | 33 | ****************************************************************************** |
Anna Bridge |
160:5571c4ff569f | 34 | */ |
Anna Bridge |
160:5571c4ff569f | 35 | |
Anna Bridge |
160:5571c4ff569f | 36 | /* Define to prevent recursive inclusion -------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 37 | #ifndef __STM32F4xx_HAL_FLASH_H |
Anna Bridge |
160:5571c4ff569f | 38 | #define __STM32F4xx_HAL_FLASH_H |
Anna Bridge |
160:5571c4ff569f | 39 | |
Anna Bridge |
160:5571c4ff569f | 40 | #ifdef __cplusplus |
Anna Bridge |
160:5571c4ff569f | 41 | extern "C" { |
Anna Bridge |
160:5571c4ff569f | 42 | #endif |
Anna Bridge |
160:5571c4ff569f | 43 | |
Anna Bridge |
160:5571c4ff569f | 44 | /* Includes ------------------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 45 | #include "stm32f4xx_hal_def.h" |
Anna Bridge |
160:5571c4ff569f | 46 | |
Anna Bridge |
160:5571c4ff569f | 47 | /** @addtogroup STM32F4xx_HAL_Driver |
Anna Bridge |
160:5571c4ff569f | 48 | * @{ |
Anna Bridge |
160:5571c4ff569f | 49 | */ |
Anna Bridge |
160:5571c4ff569f | 50 | |
Anna Bridge |
160:5571c4ff569f | 51 | /** @addtogroup FLASH |
Anna Bridge |
160:5571c4ff569f | 52 | * @{ |
Anna Bridge |
160:5571c4ff569f | 53 | */ |
Anna Bridge |
160:5571c4ff569f | 54 | |
Anna Bridge |
160:5571c4ff569f | 55 | /* Exported types ------------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 56 | /** @defgroup FLASH_Exported_Types FLASH Exported Types |
Anna Bridge |
160:5571c4ff569f | 57 | * @{ |
Anna Bridge |
160:5571c4ff569f | 58 | */ |
Anna Bridge |
160:5571c4ff569f | 59 | |
Anna Bridge |
160:5571c4ff569f | 60 | /** |
Anna Bridge |
160:5571c4ff569f | 61 | * @brief FLASH Procedure structure definition |
Anna Bridge |
160:5571c4ff569f | 62 | */ |
Anna Bridge |
160:5571c4ff569f | 63 | typedef enum |
Anna Bridge |
160:5571c4ff569f | 64 | { |
Anna Bridge |
160:5571c4ff569f | 65 | FLASH_PROC_NONE = 0U, |
Anna Bridge |
160:5571c4ff569f | 66 | FLASH_PROC_SECTERASE, |
Anna Bridge |
160:5571c4ff569f | 67 | FLASH_PROC_MASSERASE, |
Anna Bridge |
160:5571c4ff569f | 68 | FLASH_PROC_PROGRAM |
Anna Bridge |
160:5571c4ff569f | 69 | } FLASH_ProcedureTypeDef; |
Anna Bridge |
160:5571c4ff569f | 70 | |
Anna Bridge |
160:5571c4ff569f | 71 | /** |
Anna Bridge |
160:5571c4ff569f | 72 | * @brief FLASH handle Structure definition |
Anna Bridge |
160:5571c4ff569f | 73 | */ |
Anna Bridge |
160:5571c4ff569f | 74 | typedef struct |
Anna Bridge |
160:5571c4ff569f | 75 | { |
Anna Bridge |
160:5571c4ff569f | 76 | __IO FLASH_ProcedureTypeDef ProcedureOnGoing; /*Internal variable to indicate which procedure is ongoing or not in IT context*/ |
Anna Bridge |
160:5571c4ff569f | 77 | |
Anna Bridge |
160:5571c4ff569f | 78 | __IO uint32_t NbSectorsToErase; /*Internal variable to save the remaining sectors to erase in IT context*/ |
Anna Bridge |
160:5571c4ff569f | 79 | |
Anna Bridge |
160:5571c4ff569f | 80 | __IO uint8_t VoltageForErase; /*Internal variable to provide voltage range selected by user in IT context*/ |
Anna Bridge |
160:5571c4ff569f | 81 | |
Anna Bridge |
160:5571c4ff569f | 82 | __IO uint32_t Sector; /*Internal variable to define the current sector which is erasing*/ |
Anna Bridge |
160:5571c4ff569f | 83 | |
Anna Bridge |
160:5571c4ff569f | 84 | __IO uint32_t Bank; /*Internal variable to save current bank selected during mass erase*/ |
Anna Bridge |
160:5571c4ff569f | 85 | |
Anna Bridge |
160:5571c4ff569f | 86 | __IO uint32_t Address; /*Internal variable to save address selected for program*/ |
Anna Bridge |
160:5571c4ff569f | 87 | |
Anna Bridge |
160:5571c4ff569f | 88 | HAL_LockTypeDef Lock; /* FLASH locking object */ |
Anna Bridge |
160:5571c4ff569f | 89 | |
Anna Bridge |
160:5571c4ff569f | 90 | __IO uint32_t ErrorCode; /* FLASH error code */ |
Anna Bridge |
160:5571c4ff569f | 91 | |
Anna Bridge |
160:5571c4ff569f | 92 | }FLASH_ProcessTypeDef; |
Anna Bridge |
160:5571c4ff569f | 93 | |
Anna Bridge |
160:5571c4ff569f | 94 | /** |
Anna Bridge |
160:5571c4ff569f | 95 | * @} |
Anna Bridge |
160:5571c4ff569f | 96 | */ |
Anna Bridge |
160:5571c4ff569f | 97 | |
Anna Bridge |
160:5571c4ff569f | 98 | /* Exported constants --------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 99 | /** @defgroup FLASH_Exported_Constants FLASH Exported Constants |
Anna Bridge |
160:5571c4ff569f | 100 | * @{ |
Anna Bridge |
160:5571c4ff569f | 101 | */ |
Anna Bridge |
160:5571c4ff569f | 102 | /** @defgroup FLASH_Error_Code FLASH Error Code |
Anna Bridge |
160:5571c4ff569f | 103 | * @brief FLASH Error Code |
Anna Bridge |
160:5571c4ff569f | 104 | * @{ |
Anna Bridge |
160:5571c4ff569f | 105 | */ |
Anna Bridge |
160:5571c4ff569f | 106 | #define HAL_FLASH_ERROR_NONE 0x00000000U /*!< No error */ |
Anna Bridge |
160:5571c4ff569f | 107 | #define HAL_FLASH_ERROR_RD 0x00000001U /*!< Read Protection error */ |
Anna Bridge |
160:5571c4ff569f | 108 | #define HAL_FLASH_ERROR_PGS 0x00000002U /*!< Programming Sequence error */ |
Anna Bridge |
160:5571c4ff569f | 109 | #define HAL_FLASH_ERROR_PGP 0x00000004U /*!< Programming Parallelism error */ |
Anna Bridge |
160:5571c4ff569f | 110 | #define HAL_FLASH_ERROR_PGA 0x00000008U /*!< Programming Alignment error */ |
Anna Bridge |
160:5571c4ff569f | 111 | #define HAL_FLASH_ERROR_WRP 0x00000010U /*!< Write protection error */ |
Anna Bridge |
160:5571c4ff569f | 112 | #define HAL_FLASH_ERROR_OPERATION 0x00000020U /*!< Operation Error */ |
Anna Bridge |
160:5571c4ff569f | 113 | /** |
Anna Bridge |
160:5571c4ff569f | 114 | * @} |
Anna Bridge |
160:5571c4ff569f | 115 | */ |
Anna Bridge |
160:5571c4ff569f | 116 | |
Anna Bridge |
160:5571c4ff569f | 117 | /** @defgroup FLASH_Type_Program FLASH Type Program |
Anna Bridge |
160:5571c4ff569f | 118 | * @{ |
Anna Bridge |
160:5571c4ff569f | 119 | */ |
Anna Bridge |
160:5571c4ff569f | 120 | #define FLASH_TYPEPROGRAM_BYTE 0x00000000U /*!< Program byte (8-bit) at a specified address */ |
Anna Bridge |
160:5571c4ff569f | 121 | #define FLASH_TYPEPROGRAM_HALFWORD 0x00000001U /*!< Program a half-word (16-bit) at a specified address */ |
Anna Bridge |
160:5571c4ff569f | 122 | #define FLASH_TYPEPROGRAM_WORD 0x00000002U /*!< Program a word (32-bit) at a specified address */ |
Anna Bridge |
160:5571c4ff569f | 123 | #define FLASH_TYPEPROGRAM_DOUBLEWORD 0x00000003U /*!< Program a double word (64-bit) at a specified address */ |
Anna Bridge |
160:5571c4ff569f | 124 | /** |
Anna Bridge |
160:5571c4ff569f | 125 | * @} |
Anna Bridge |
160:5571c4ff569f | 126 | */ |
Anna Bridge |
160:5571c4ff569f | 127 | |
Anna Bridge |
160:5571c4ff569f | 128 | /** @defgroup FLASH_Flag_definition FLASH Flag definition |
Anna Bridge |
160:5571c4ff569f | 129 | * @brief Flag definition |
Anna Bridge |
160:5571c4ff569f | 130 | * @{ |
Anna Bridge |
160:5571c4ff569f | 131 | */ |
Anna Bridge |
160:5571c4ff569f | 132 | #define FLASH_FLAG_EOP FLASH_SR_EOP /*!< FLASH End of Operation flag */ |
Anna Bridge |
160:5571c4ff569f | 133 | #define FLASH_FLAG_OPERR FLASH_SR_SOP /*!< FLASH operation Error flag */ |
Anna Bridge |
160:5571c4ff569f | 134 | #define FLASH_FLAG_WRPERR FLASH_SR_WRPERR /*!< FLASH Write protected error flag */ |
Anna Bridge |
160:5571c4ff569f | 135 | #define FLASH_FLAG_PGAERR FLASH_SR_PGAERR /*!< FLASH Programming Alignment error flag */ |
Anna Bridge |
160:5571c4ff569f | 136 | #define FLASH_FLAG_PGPERR FLASH_SR_PGPERR /*!< FLASH Programming Parallelism error flag */ |
Anna Bridge |
160:5571c4ff569f | 137 | #define FLASH_FLAG_PGSERR FLASH_SR_PGSERR /*!< FLASH Programming Sequence error flag */ |
Anna Bridge |
160:5571c4ff569f | 138 | #if defined(FLASH_SR_RDERR) |
Anna Bridge |
160:5571c4ff569f | 139 | #define FLASH_FLAG_RDERR FLASH_SR_RDERR /*!< Read Protection error flag (PCROP) */ |
Anna Bridge |
160:5571c4ff569f | 140 | #endif /* FLASH_SR_RDERR */ |
Anna Bridge |
160:5571c4ff569f | 141 | #define FLASH_FLAG_BSY FLASH_SR_BSY /*!< FLASH Busy flag */ |
Anna Bridge |
160:5571c4ff569f | 142 | /** |
Anna Bridge |
160:5571c4ff569f | 143 | * @} |
Anna Bridge |
160:5571c4ff569f | 144 | */ |
Anna Bridge |
160:5571c4ff569f | 145 | |
Anna Bridge |
160:5571c4ff569f | 146 | /** @defgroup FLASH_Interrupt_definition FLASH Interrupt definition |
Anna Bridge |
160:5571c4ff569f | 147 | * @brief FLASH Interrupt definition |
Anna Bridge |
160:5571c4ff569f | 148 | * @{ |
Anna Bridge |
160:5571c4ff569f | 149 | */ |
Anna Bridge |
160:5571c4ff569f | 150 | #define FLASH_IT_EOP FLASH_CR_EOPIE /*!< End of FLASH Operation Interrupt source */ |
Anna Bridge |
160:5571c4ff569f | 151 | #define FLASH_IT_ERR 0x02000000U /*!< Error Interrupt source */ |
Anna Bridge |
160:5571c4ff569f | 152 | /** |
Anna Bridge |
160:5571c4ff569f | 153 | * @} |
Anna Bridge |
160:5571c4ff569f | 154 | */ |
Anna Bridge |
160:5571c4ff569f | 155 | |
Anna Bridge |
160:5571c4ff569f | 156 | /** @defgroup FLASH_Program_Parallelism FLASH Program Parallelism |
Anna Bridge |
160:5571c4ff569f | 157 | * @{ |
Anna Bridge |
160:5571c4ff569f | 158 | */ |
Anna Bridge |
160:5571c4ff569f | 159 | #define FLASH_PSIZE_BYTE 0x00000000U |
Anna Bridge |
160:5571c4ff569f | 160 | #define FLASH_PSIZE_HALF_WORD 0x00000100U |
Anna Bridge |
160:5571c4ff569f | 161 | #define FLASH_PSIZE_WORD 0x00000200U |
Anna Bridge |
160:5571c4ff569f | 162 | #define FLASH_PSIZE_DOUBLE_WORD 0x00000300U |
Anna Bridge |
160:5571c4ff569f | 163 | #define CR_PSIZE_MASK 0xFFFFFCFFU |
Anna Bridge |
160:5571c4ff569f | 164 | /** |
Anna Bridge |
160:5571c4ff569f | 165 | * @} |
Anna Bridge |
160:5571c4ff569f | 166 | */ |
Anna Bridge |
160:5571c4ff569f | 167 | |
Anna Bridge |
160:5571c4ff569f | 168 | /** @defgroup FLASH_Keys FLASH Keys |
Anna Bridge |
160:5571c4ff569f | 169 | * @{ |
Anna Bridge |
160:5571c4ff569f | 170 | */ |
Anna Bridge |
160:5571c4ff569f | 171 | #define RDP_KEY ((uint16_t)0x00A5) |
Anna Bridge |
160:5571c4ff569f | 172 | #define FLASH_KEY1 0x45670123U |
Anna Bridge |
160:5571c4ff569f | 173 | #define FLASH_KEY2 0xCDEF89ABU |
Anna Bridge |
160:5571c4ff569f | 174 | #define FLASH_OPT_KEY1 0x08192A3BU |
Anna Bridge |
160:5571c4ff569f | 175 | #define FLASH_OPT_KEY2 0x4C5D6E7FU |
Anna Bridge |
160:5571c4ff569f | 176 | /** |
Anna Bridge |
160:5571c4ff569f | 177 | * @} |
Anna Bridge |
160:5571c4ff569f | 178 | */ |
Anna Bridge |
160:5571c4ff569f | 179 | |
Anna Bridge |
160:5571c4ff569f | 180 | /** |
Anna Bridge |
160:5571c4ff569f | 181 | * @} |
Anna Bridge |
160:5571c4ff569f | 182 | */ |
Anna Bridge |
160:5571c4ff569f | 183 | |
Anna Bridge |
160:5571c4ff569f | 184 | /* Exported macro ------------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 185 | /** @defgroup FLASH_Exported_Macros FLASH Exported Macros |
Anna Bridge |
160:5571c4ff569f | 186 | * @{ |
Anna Bridge |
160:5571c4ff569f | 187 | */ |
Anna Bridge |
160:5571c4ff569f | 188 | /** |
Anna Bridge |
160:5571c4ff569f | 189 | * @brief Set the FLASH Latency. |
AnnaBridge | 163:e59c8e839560 | 190 | * @param __LATENCY__ FLASH Latency |
Anna Bridge |
160:5571c4ff569f | 191 | * The value of this parameter depend on device used within the same series |
Anna Bridge |
160:5571c4ff569f | 192 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 193 | */ |
Anna Bridge |
160:5571c4ff569f | 194 | #define __HAL_FLASH_SET_LATENCY(__LATENCY__) (*(__IO uint8_t *)ACR_BYTE0_ADDRESS = (uint8_t)(__LATENCY__)) |
Anna Bridge |
160:5571c4ff569f | 195 | |
Anna Bridge |
160:5571c4ff569f | 196 | /** |
Anna Bridge |
160:5571c4ff569f | 197 | * @brief Get the FLASH Latency. |
Anna Bridge |
160:5571c4ff569f | 198 | * @retval FLASH Latency |
Anna Bridge |
160:5571c4ff569f | 199 | * The value of this parameter depend on device used within the same series |
Anna Bridge |
160:5571c4ff569f | 200 | */ |
Anna Bridge |
160:5571c4ff569f | 201 | #define __HAL_FLASH_GET_LATENCY() (READ_BIT((FLASH->ACR), FLASH_ACR_LATENCY)) |
Anna Bridge |
160:5571c4ff569f | 202 | |
Anna Bridge |
160:5571c4ff569f | 203 | /** |
Anna Bridge |
160:5571c4ff569f | 204 | * @brief Enable the FLASH prefetch buffer. |
Anna Bridge |
160:5571c4ff569f | 205 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 206 | */ |
Anna Bridge |
160:5571c4ff569f | 207 | #define __HAL_FLASH_PREFETCH_BUFFER_ENABLE() (FLASH->ACR |= FLASH_ACR_PRFTEN) |
Anna Bridge |
160:5571c4ff569f | 208 | |
Anna Bridge |
160:5571c4ff569f | 209 | /** |
Anna Bridge |
160:5571c4ff569f | 210 | * @brief Disable the FLASH prefetch buffer. |
Anna Bridge |
160:5571c4ff569f | 211 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 212 | */ |
Anna Bridge |
160:5571c4ff569f | 213 | #define __HAL_FLASH_PREFETCH_BUFFER_DISABLE() (FLASH->ACR &= (~FLASH_ACR_PRFTEN)) |
Anna Bridge |
160:5571c4ff569f | 214 | |
Anna Bridge |
160:5571c4ff569f | 215 | /** |
Anna Bridge |
160:5571c4ff569f | 216 | * @brief Enable the FLASH instruction cache. |
Anna Bridge |
160:5571c4ff569f | 217 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 218 | */ |
Anna Bridge |
160:5571c4ff569f | 219 | #define __HAL_FLASH_INSTRUCTION_CACHE_ENABLE() (FLASH->ACR |= FLASH_ACR_ICEN) |
Anna Bridge |
160:5571c4ff569f | 220 | |
Anna Bridge |
160:5571c4ff569f | 221 | /** |
Anna Bridge |
160:5571c4ff569f | 222 | * @brief Disable the FLASH instruction cache. |
Anna Bridge |
160:5571c4ff569f | 223 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 224 | */ |
Anna Bridge |
160:5571c4ff569f | 225 | #define __HAL_FLASH_INSTRUCTION_CACHE_DISABLE() (FLASH->ACR &= (~FLASH_ACR_ICEN)) |
Anna Bridge |
160:5571c4ff569f | 226 | |
Anna Bridge |
160:5571c4ff569f | 227 | /** |
Anna Bridge |
160:5571c4ff569f | 228 | * @brief Enable the FLASH data cache. |
Anna Bridge |
160:5571c4ff569f | 229 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 230 | */ |
Anna Bridge |
160:5571c4ff569f | 231 | #define __HAL_FLASH_DATA_CACHE_ENABLE() (FLASH->ACR |= FLASH_ACR_DCEN) |
Anna Bridge |
160:5571c4ff569f | 232 | |
Anna Bridge |
160:5571c4ff569f | 233 | /** |
Anna Bridge |
160:5571c4ff569f | 234 | * @brief Disable the FLASH data cache. |
Anna Bridge |
160:5571c4ff569f | 235 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 236 | */ |
Anna Bridge |
160:5571c4ff569f | 237 | #define __HAL_FLASH_DATA_CACHE_DISABLE() (FLASH->ACR &= (~FLASH_ACR_DCEN)) |
Anna Bridge |
160:5571c4ff569f | 238 | |
Anna Bridge |
160:5571c4ff569f | 239 | /** |
Anna Bridge |
160:5571c4ff569f | 240 | * @brief Resets the FLASH instruction Cache. |
Anna Bridge |
160:5571c4ff569f | 241 | * @note This function must be used only when the Instruction Cache is disabled. |
Anna Bridge |
160:5571c4ff569f | 242 | * @retval None |
Anna Bridge |
160:5571c4ff569f | 243 | */ |
Anna Bridge |
160:5571c4ff569f | 244 | #define __HAL_FLASH_INSTRUCTION_CACHE_RESET() do {FLASH->ACR |= FLASH_ACR_ICRST; \ |
Anna Bridge |
160:5571c4ff569f | 245 | FLASH->ACR &= ~FLASH_ACR_ICRST; \ |
Anna Bridge |
160:5571c4ff569f | 246 | }while(0U) |
Anna Bridge |
160:5571c4ff569f | 247 | |
Anna Bridge |
160:5571c4ff569f | 248 | /** |
Anna Bridge |
160:5571c4ff569f | 249 | * @brief Resets the FLASH data Cache. |
Anna Bridge |
160:5571c4ff569f | 250 | * @note This function must be used only when the data Cache is disabled. |
Anna Bridge |
160:5571c4ff569f | 251 | * @retval None |
Anna Bridge |
160:5571c4ff569f | 252 | */ |
Anna Bridge |
160:5571c4ff569f | 253 | #define __HAL_FLASH_DATA_CACHE_RESET() do {FLASH->ACR |= FLASH_ACR_DCRST; \ |
Anna Bridge |
160:5571c4ff569f | 254 | FLASH->ACR &= ~FLASH_ACR_DCRST; \ |
Anna Bridge |
160:5571c4ff569f | 255 | }while(0U) |
Anna Bridge |
160:5571c4ff569f | 256 | /** |
Anna Bridge |
160:5571c4ff569f | 257 | * @brief Enable the specified FLASH interrupt. |
AnnaBridge | 163:e59c8e839560 | 258 | * @param __INTERRUPT__ FLASH interrupt |
Anna Bridge |
160:5571c4ff569f | 259 | * This parameter can be any combination of the following values: |
Anna Bridge |
160:5571c4ff569f | 260 | * @arg FLASH_IT_EOP: End of FLASH Operation Interrupt |
Anna Bridge |
160:5571c4ff569f | 261 | * @arg FLASH_IT_ERR: Error Interrupt |
Anna Bridge |
160:5571c4ff569f | 262 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 263 | */ |
Anna Bridge |
160:5571c4ff569f | 264 | #define __HAL_FLASH_ENABLE_IT(__INTERRUPT__) (FLASH->CR |= (__INTERRUPT__)) |
Anna Bridge |
160:5571c4ff569f | 265 | |
Anna Bridge |
160:5571c4ff569f | 266 | /** |
Anna Bridge |
160:5571c4ff569f | 267 | * @brief Disable the specified FLASH interrupt. |
AnnaBridge | 163:e59c8e839560 | 268 | * @param __INTERRUPT__ FLASH interrupt |
Anna Bridge |
160:5571c4ff569f | 269 | * This parameter can be any combination of the following values: |
Anna Bridge |
160:5571c4ff569f | 270 | * @arg FLASH_IT_EOP: End of FLASH Operation Interrupt |
Anna Bridge |
160:5571c4ff569f | 271 | * @arg FLASH_IT_ERR: Error Interrupt |
Anna Bridge |
160:5571c4ff569f | 272 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 273 | */ |
Anna Bridge |
160:5571c4ff569f | 274 | #define __HAL_FLASH_DISABLE_IT(__INTERRUPT__) (FLASH->CR &= ~(uint32_t)(__INTERRUPT__)) |
Anna Bridge |
160:5571c4ff569f | 275 | |
Anna Bridge |
160:5571c4ff569f | 276 | /** |
Anna Bridge |
160:5571c4ff569f | 277 | * @brief Get the specified FLASH flag status. |
AnnaBridge | 163:e59c8e839560 | 278 | * @param __FLAG__ specifies the FLASH flags to check. |
Anna Bridge |
160:5571c4ff569f | 279 | * This parameter can be any combination of the following values: |
Anna Bridge |
160:5571c4ff569f | 280 | * @arg FLASH_FLAG_EOP : FLASH End of Operation flag |
Anna Bridge |
160:5571c4ff569f | 281 | * @arg FLASH_FLAG_OPERR : FLASH operation Error flag |
Anna Bridge |
160:5571c4ff569f | 282 | * @arg FLASH_FLAG_WRPERR: FLASH Write protected error flag |
Anna Bridge |
160:5571c4ff569f | 283 | * @arg FLASH_FLAG_PGAERR: FLASH Programming Alignment error flag |
Anna Bridge |
160:5571c4ff569f | 284 | * @arg FLASH_FLAG_PGPERR: FLASH Programming Parallelism error flag |
Anna Bridge |
160:5571c4ff569f | 285 | * @arg FLASH_FLAG_PGSERR: FLASH Programming Sequence error flag |
Anna Bridge |
160:5571c4ff569f | 286 | * @arg FLASH_FLAG_RDERR : FLASH Read Protection error flag (PCROP) (*) |
Anna Bridge |
160:5571c4ff569f | 287 | * @arg FLASH_FLAG_BSY : FLASH Busy flag |
Anna Bridge |
160:5571c4ff569f | 288 | * (*) FLASH_FLAG_RDERR is not available for STM32F405xx/407xx/415xx/417xx devices |
Anna Bridge |
160:5571c4ff569f | 289 | * @retval The new state of __FLAG__ (SET or RESET). |
Anna Bridge |
160:5571c4ff569f | 290 | */ |
Anna Bridge |
160:5571c4ff569f | 291 | #define __HAL_FLASH_GET_FLAG(__FLAG__) ((FLASH->SR & (__FLAG__))) |
Anna Bridge |
160:5571c4ff569f | 292 | |
Anna Bridge |
160:5571c4ff569f | 293 | /** |
Anna Bridge |
160:5571c4ff569f | 294 | * @brief Clear the specified FLASH flags. |
AnnaBridge | 163:e59c8e839560 | 295 | * @param __FLAG__ specifies the FLASH flags to clear. |
Anna Bridge |
160:5571c4ff569f | 296 | * This parameter can be any combination of the following values: |
Anna Bridge |
160:5571c4ff569f | 297 | * @arg FLASH_FLAG_EOP : FLASH End of Operation flag |
Anna Bridge |
160:5571c4ff569f | 298 | * @arg FLASH_FLAG_OPERR : FLASH operation Error flag |
Anna Bridge |
160:5571c4ff569f | 299 | * @arg FLASH_FLAG_WRPERR: FLASH Write protected error flag |
Anna Bridge |
160:5571c4ff569f | 300 | * @arg FLASH_FLAG_PGAERR: FLASH Programming Alignment error flag |
Anna Bridge |
160:5571c4ff569f | 301 | * @arg FLASH_FLAG_PGPERR: FLASH Programming Parallelism error flag |
Anna Bridge |
160:5571c4ff569f | 302 | * @arg FLASH_FLAG_PGSERR: FLASH Programming Sequence error flag |
Anna Bridge |
160:5571c4ff569f | 303 | * @arg FLASH_FLAG_RDERR : FLASH Read Protection error flag (PCROP) (*) |
Anna Bridge |
160:5571c4ff569f | 304 | * (*) FLASH_FLAG_RDERR is not available for STM32F405xx/407xx/415xx/417xx devices |
Anna Bridge |
160:5571c4ff569f | 305 | * @retval none |
Anna Bridge |
160:5571c4ff569f | 306 | */ |
Anna Bridge |
160:5571c4ff569f | 307 | #define __HAL_FLASH_CLEAR_FLAG(__FLAG__) (FLASH->SR = (__FLAG__)) |
Anna Bridge |
160:5571c4ff569f | 308 | /** |
Anna Bridge |
160:5571c4ff569f | 309 | * @} |
Anna Bridge |
160:5571c4ff569f | 310 | */ |
Anna Bridge |
160:5571c4ff569f | 311 | |
Anna Bridge |
160:5571c4ff569f | 312 | /* Include FLASH HAL Extension module */ |
Anna Bridge |
160:5571c4ff569f | 313 | #include "stm32f4xx_hal_flash_ex.h" |
Anna Bridge |
160:5571c4ff569f | 314 | #include "stm32f4xx_hal_flash_ramfunc.h" |
Anna Bridge |
160:5571c4ff569f | 315 | |
Anna Bridge |
160:5571c4ff569f | 316 | /* Exported functions --------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 317 | /** @addtogroup FLASH_Exported_Functions |
Anna Bridge |
160:5571c4ff569f | 318 | * @{ |
Anna Bridge |
160:5571c4ff569f | 319 | */ |
Anna Bridge |
160:5571c4ff569f | 320 | /** @addtogroup FLASH_Exported_Functions_Group1 |
Anna Bridge |
160:5571c4ff569f | 321 | * @{ |
Anna Bridge |
160:5571c4ff569f | 322 | */ |
Anna Bridge |
160:5571c4ff569f | 323 | /* Program operation functions ***********************************************/ |
Anna Bridge |
160:5571c4ff569f | 324 | HAL_StatusTypeDef HAL_FLASH_Program(uint32_t TypeProgram, uint32_t Address, uint64_t Data); |
Anna Bridge |
160:5571c4ff569f | 325 | HAL_StatusTypeDef HAL_FLASH_Program_IT(uint32_t TypeProgram, uint32_t Address, uint64_t Data); |
Anna Bridge |
160:5571c4ff569f | 326 | /* FLASH IRQ handler method */ |
Anna Bridge |
160:5571c4ff569f | 327 | void HAL_FLASH_IRQHandler(void); |
Anna Bridge |
160:5571c4ff569f | 328 | /* Callbacks in non blocking modes */ |
Anna Bridge |
160:5571c4ff569f | 329 | void HAL_FLASH_EndOfOperationCallback(uint32_t ReturnValue); |
Anna Bridge |
160:5571c4ff569f | 330 | void HAL_FLASH_OperationErrorCallback(uint32_t ReturnValue); |
Anna Bridge |
160:5571c4ff569f | 331 | /** |
Anna Bridge |
160:5571c4ff569f | 332 | * @} |
Anna Bridge |
160:5571c4ff569f | 333 | */ |
Anna Bridge |
160:5571c4ff569f | 334 | |
Anna Bridge |
160:5571c4ff569f | 335 | /** @addtogroup FLASH_Exported_Functions_Group2 |
Anna Bridge |
160:5571c4ff569f | 336 | * @{ |
Anna Bridge |
160:5571c4ff569f | 337 | */ |
Anna Bridge |
160:5571c4ff569f | 338 | /* Peripheral Control functions **********************************************/ |
Anna Bridge |
160:5571c4ff569f | 339 | HAL_StatusTypeDef HAL_FLASH_Unlock(void); |
Anna Bridge |
160:5571c4ff569f | 340 | HAL_StatusTypeDef HAL_FLASH_Lock(void); |
Anna Bridge |
160:5571c4ff569f | 341 | HAL_StatusTypeDef HAL_FLASH_OB_Unlock(void); |
Anna Bridge |
160:5571c4ff569f | 342 | HAL_StatusTypeDef HAL_FLASH_OB_Lock(void); |
Anna Bridge |
160:5571c4ff569f | 343 | /* Option bytes control */ |
Anna Bridge |
160:5571c4ff569f | 344 | HAL_StatusTypeDef HAL_FLASH_OB_Launch(void); |
Anna Bridge |
160:5571c4ff569f | 345 | /** |
Anna Bridge |
160:5571c4ff569f | 346 | * @} |
Anna Bridge |
160:5571c4ff569f | 347 | */ |
Anna Bridge |
160:5571c4ff569f | 348 | |
Anna Bridge |
160:5571c4ff569f | 349 | /** @addtogroup FLASH_Exported_Functions_Group3 |
Anna Bridge |
160:5571c4ff569f | 350 | * @{ |
Anna Bridge |
160:5571c4ff569f | 351 | */ |
Anna Bridge |
160:5571c4ff569f | 352 | /* Peripheral State functions ************************************************/ |
Anna Bridge |
160:5571c4ff569f | 353 | uint32_t HAL_FLASH_GetError(void); |
Anna Bridge |
160:5571c4ff569f | 354 | HAL_StatusTypeDef FLASH_WaitForLastOperation(uint32_t Timeout); |
Anna Bridge |
160:5571c4ff569f | 355 | /** |
Anna Bridge |
160:5571c4ff569f | 356 | * @} |
Anna Bridge |
160:5571c4ff569f | 357 | */ |
Anna Bridge |
160:5571c4ff569f | 358 | |
Anna Bridge |
160:5571c4ff569f | 359 | /** |
Anna Bridge |
160:5571c4ff569f | 360 | * @} |
Anna Bridge |
160:5571c4ff569f | 361 | */ |
Anna Bridge |
160:5571c4ff569f | 362 | /* Private types -------------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 363 | /* Private variables ---------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 364 | /** @defgroup FLASH_Private_Variables FLASH Private Variables |
Anna Bridge |
160:5571c4ff569f | 365 | * @{ |
Anna Bridge |
160:5571c4ff569f | 366 | */ |
Anna Bridge |
160:5571c4ff569f | 367 | |
Anna Bridge |
160:5571c4ff569f | 368 | /** |
Anna Bridge |
160:5571c4ff569f | 369 | * @} |
Anna Bridge |
160:5571c4ff569f | 370 | */ |
Anna Bridge |
160:5571c4ff569f | 371 | /* Private constants ---------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 372 | /** @defgroup FLASH_Private_Constants FLASH Private Constants |
Anna Bridge |
160:5571c4ff569f | 373 | * @{ |
Anna Bridge |
160:5571c4ff569f | 374 | */ |
Anna Bridge |
160:5571c4ff569f | 375 | |
Anna Bridge |
160:5571c4ff569f | 376 | /** |
Anna Bridge |
160:5571c4ff569f | 377 | * @brief ACR register byte 0 (Bits[7:0]) base address |
Anna Bridge |
160:5571c4ff569f | 378 | */ |
Anna Bridge |
160:5571c4ff569f | 379 | #define ACR_BYTE0_ADDRESS 0x40023C00U |
Anna Bridge |
160:5571c4ff569f | 380 | /** |
Anna Bridge |
160:5571c4ff569f | 381 | * @brief OPTCR register byte 0 (Bits[7:0]) base address |
Anna Bridge |
160:5571c4ff569f | 382 | */ |
Anna Bridge |
160:5571c4ff569f | 383 | #define OPTCR_BYTE0_ADDRESS 0x40023C14U |
Anna Bridge |
160:5571c4ff569f | 384 | /** |
Anna Bridge |
160:5571c4ff569f | 385 | * @brief OPTCR register byte 1 (Bits[15:8]) base address |
Anna Bridge |
160:5571c4ff569f | 386 | */ |
Anna Bridge |
160:5571c4ff569f | 387 | #define OPTCR_BYTE1_ADDRESS 0x40023C15U |
Anna Bridge |
160:5571c4ff569f | 388 | /** |
Anna Bridge |
160:5571c4ff569f | 389 | * @brief OPTCR register byte 2 (Bits[23:16]) base address |
Anna Bridge |
160:5571c4ff569f | 390 | */ |
Anna Bridge |
160:5571c4ff569f | 391 | #define OPTCR_BYTE2_ADDRESS 0x40023C16U |
Anna Bridge |
160:5571c4ff569f | 392 | /** |
Anna Bridge |
160:5571c4ff569f | 393 | * @brief OPTCR register byte 3 (Bits[31:24]) base address |
Anna Bridge |
160:5571c4ff569f | 394 | */ |
Anna Bridge |
160:5571c4ff569f | 395 | #define OPTCR_BYTE3_ADDRESS 0x40023C17U |
Anna Bridge |
160:5571c4ff569f | 396 | |
Anna Bridge |
160:5571c4ff569f | 397 | /** |
Anna Bridge |
160:5571c4ff569f | 398 | * @} |
Anna Bridge |
160:5571c4ff569f | 399 | */ |
Anna Bridge |
160:5571c4ff569f | 400 | |
Anna Bridge |
160:5571c4ff569f | 401 | /* Private macros ------------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 402 | /** @defgroup FLASH_Private_Macros FLASH Private Macros |
Anna Bridge |
160:5571c4ff569f | 403 | * @{ |
Anna Bridge |
160:5571c4ff569f | 404 | */ |
Anna Bridge |
160:5571c4ff569f | 405 | |
Anna Bridge |
160:5571c4ff569f | 406 | /** @defgroup FLASH_IS_FLASH_Definitions FLASH Private macros to check input parameters |
Anna Bridge |
160:5571c4ff569f | 407 | * @{ |
Anna Bridge |
160:5571c4ff569f | 408 | */ |
Anna Bridge |
160:5571c4ff569f | 409 | #define IS_FLASH_TYPEPROGRAM(VALUE)(((VALUE) == FLASH_TYPEPROGRAM_BYTE) || \ |
Anna Bridge |
160:5571c4ff569f | 410 | ((VALUE) == FLASH_TYPEPROGRAM_HALFWORD) || \ |
Anna Bridge |
160:5571c4ff569f | 411 | ((VALUE) == FLASH_TYPEPROGRAM_WORD) || \ |
Anna Bridge |
160:5571c4ff569f | 412 | ((VALUE) == FLASH_TYPEPROGRAM_DOUBLEWORD)) |
Anna Bridge |
160:5571c4ff569f | 413 | /** |
Anna Bridge |
160:5571c4ff569f | 414 | * @} |
Anna Bridge |
160:5571c4ff569f | 415 | */ |
Anna Bridge |
160:5571c4ff569f | 416 | |
Anna Bridge |
160:5571c4ff569f | 417 | /** |
Anna Bridge |
160:5571c4ff569f | 418 | * @} |
Anna Bridge |
160:5571c4ff569f | 419 | */ |
Anna Bridge |
160:5571c4ff569f | 420 | |
Anna Bridge |
160:5571c4ff569f | 421 | /* Private functions ---------------------------------------------------------*/ |
Anna Bridge |
160:5571c4ff569f | 422 | /** @defgroup FLASH_Private_Functions FLASH Private Functions |
Anna Bridge |
160:5571c4ff569f | 423 | * @{ |
Anna Bridge |
160:5571c4ff569f | 424 | */ |
Anna Bridge |
160:5571c4ff569f | 425 | |
Anna Bridge |
160:5571c4ff569f | 426 | /** |
Anna Bridge |
160:5571c4ff569f | 427 | * @} |
Anna Bridge |
160:5571c4ff569f | 428 | */ |
Anna Bridge |
160:5571c4ff569f | 429 | |
Anna Bridge |
160:5571c4ff569f | 430 | /** |
Anna Bridge |
160:5571c4ff569f | 431 | * @} |
Anna Bridge |
160:5571c4ff569f | 432 | */ |
Anna Bridge |
160:5571c4ff569f | 433 | |
Anna Bridge |
160:5571c4ff569f | 434 | /** |
Anna Bridge |
160:5571c4ff569f | 435 | * @} |
Anna Bridge |
160:5571c4ff569f | 436 | */ |
Anna Bridge |
160:5571c4ff569f | 437 | |
Anna Bridge |
160:5571c4ff569f | 438 | #ifdef __cplusplus |
Anna Bridge |
160:5571c4ff569f | 439 | } |
Anna Bridge |
160:5571c4ff569f | 440 | #endif |
Anna Bridge |
160:5571c4ff569f | 441 | |
Anna Bridge |
160:5571c4ff569f | 442 | #endif /* __STM32F4xx_HAL_FLASH_H */ |
Anna Bridge |
160:5571c4ff569f | 443 | |
Anna Bridge |
160:5571c4ff569f | 444 | /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/ |