Fork of the official mbed C/C SDK provides the software platform and libraries to build your applications for RenBED.

Dependents:   1-RenBuggyTimed RenBED_RGB RenBED_RGB_PWM RenBED_RGB

Fork of mbed by mbed official

Committer:
elijahorr
Date:
Thu Apr 14 07:28:54 2016 +0000
Revision:
121:672067c3ada4
Parent:
110:165afa46840b
.

Who changed what in which revision?

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