FIX: Flash page size check is STM (or clone) specific (#14130)
[betaflight.git] / lib / main / STM32F4 / Drivers / STM32F4xx_StdPeriph_Driver / src / stm32f4xx_flash.c
blobdd5d577205065ceba1b8375baa103ffaa8cb1422
1 /**
2 ******************************************************************************
3 * @file stm32f4xx_flash.c
4 * @author MCD Application Team
5 * @version V1.7.1
6 * @date 20-May-2016
7 * @brief This file provides firmware functions to manage the following
8 * functionalities of the FLASH peripheral:
9 * + FLASH Interface configuration
10 * + FLASH Memory Programming
11 * + Option Bytes Programming
12 * + Interrupts and flags management
14 @verbatim
15 ===============================================================================
16 ##### How to use this driver #####
17 ===============================================================================
18 [..]
19 This driver provides functions to configure and program the FLASH memory
20 of all STM32F4xx devices. These functions are split in 4 groups:
22 (#) FLASH Interface configuration functions: this group includes the
23 management of the following features:
24 (++) Set the latency
25 (++) Enable/Disable the prefetch buffer
26 (++) Enable/Disable the Instruction cache and the Data cache
27 (++) Reset the Instruction cache and the Data cache
29 (#) FLASH Memory Programming functions: this group includes all needed
30 functions to erase and program the main memory:
31 (++) Lock and Unlock the FLASH interface
32 (++) Erase function: Erase sector, erase all sectors
33 (++) Program functions: byte, half word, word and double word
35 (#) Option Bytes Programming functions: this group includes all needed
36 functions to manage the Option Bytes:
37 (++) Set/Reset the write protection
38 (++) Set the Read protection Level
39 (++) Set the BOR level
40 (++) Program the user Option Bytes
41 (++) Launch the Option Bytes loader
43 (#) Interrupts and flags management functions: this group
44 includes all needed functions to:
45 (++) Enable/Disable the FLASH interrupt sources
46 (++) Get flags status
47 (++) Clear flags
48 (++) Get FLASH operation status
49 (++) Wait for last FLASH operation
50 @endverbatim
51 ******************************************************************************
52 * @attention
54 * <h2><center>&copy; COPYRIGHT 2016 STMicroelectronics</center></h2>
56 * Licensed under MCD-ST Liberty SW License Agreement V2, (the "License");
57 * You may not use this file except in compliance with the License.
58 * You may obtain a copy of the License at:
60 * http://www.st.com/software_license_agreement_liberty_v2
62 * Unless required by applicable law or agreed to in writing, software
63 * distributed under the License is distributed on an "AS IS" BASIS,
64 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
65 * See the License for the specific language governing permissions and
66 * limitations under the License.
68 ******************************************************************************
71 /* Includes ------------------------------------------------------------------*/
72 #include "stm32f4xx_flash.h"
74 /** @addtogroup STM32F4xx_StdPeriph_Driver
75 * @{
78 /** @defgroup FLASH
79 * @brief FLASH driver modules
80 * @{
81 */
83 /* Private typedef -----------------------------------------------------------*/
84 /* Private define ------------------------------------------------------------*/
85 #define SECTOR_MASK ((uint32_t)0xFFFFFF07)
87 /* Private macro -------------------------------------------------------------*/
88 /* Private variables ---------------------------------------------------------*/
89 /* Private function prototypes -----------------------------------------------*/
90 /* Private functions ---------------------------------------------------------*/
92 /** @defgroup FLASH_Private_Functions
93 * @{
94 */
96 /** @defgroup FLASH_Group1 FLASH Interface configuration functions
97 * @brief FLASH Interface configuration functions
100 @verbatim
101 ===============================================================================
102 ##### FLASH Interface configuration functions #####
103 ===============================================================================
104 [..]
105 This group includes the following functions:
106 (+) void FLASH_SetLatency(uint32_t FLASH_Latency)
107 To correctly read data from FLASH memory, the number of wait states (LATENCY)
108 must be correctly programmed according to the frequency of the CPU clock
109 (HCLK) and the supply voltage of the device.
110 [..]
111 For STM32F405xx/07xx and STM32F415xx/17xx devices
112 +-------------------------------------------------------------------------------------+
113 | Latency | HCLK clock frequency (MHz) |
114 | |---------------------------------------------------------------------|
115 | | voltage range | voltage range | voltage range | voltage range |
116 | | 2.7 V - 3.6 V | 2.4 V - 2.7 V | 2.1 V - 2.4 V | 1.8 V - 2.1 V |
117 |---------------|----------------|----------------|-----------------|-----------------|
118 |0WS(1CPU cycle)|0 < HCLK <= 30 |0 < HCLK <= 24 |0 < HCLK <= 22 |0 < HCLK <= 20 |
119 |---------------|----------------|----------------|-----------------|-----------------|
120 |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |22 < HCLK <= 44 |20 < HCLK <= 40 |
121 |---------------|----------------|----------------|-----------------|-----------------|
122 |2WS(3CPU cycle)|60 < HCLK <= 90 |48 < HCLK <= 72 |44 < HCLK <= 66 |40 < HCLK <= 60 |
123 |---------------|----------------|----------------|-----------------|-----------------|
124 |3WS(4CPU cycle)|90 < HCLK <= 120|72 < HCLK <= 96 |66 < HCLK <= 88 |60 < HCLK <= 80 |
125 |---------------|----------------|----------------|-----------------|-----------------|
126 |4WS(5CPU cycle)|120< HCLK <= 150|96 < HCLK <= 120|88 < HCLK <= 110 |80 < HCLK <= 100 |
127 |---------------|----------------|----------------|-----------------|-----------------|
128 |5WS(6CPU cycle)|150< HCLK <= 168|120< HCLK <= 144|110 < HCLK <= 132|100 < HCLK <= 120|
129 |---------------|----------------|----------------|-----------------|-----------------|
130 |6WS(7CPU cycle)| NA |144< HCLK <= 168|132 < HCLK <= 154|120 < HCLK <= 140|
131 |---------------|----------------|----------------|-----------------|-----------------|
132 |7WS(8CPU cycle)| NA | NA |154 < HCLK <= 168|140 < HCLK <= 160|
133 +---------------|----------------|----------------|-----------------|-----------------+
135 [..]
136 For STM32F42xxx/43xxx devices
137 +-------------------------------------------------------------------------------------+
138 | Latency | HCLK clock frequency (MHz) |
139 | |---------------------------------------------------------------------|
140 | | voltage range | voltage range | voltage range | voltage range |
141 | | 2.7 V - 3.6 V | 2.4 V - 2.7 V | 2.1 V - 2.4 V | 1.8 V - 2.1 V |
142 |---------------|----------------|----------------|-----------------|-----------------|
143 |0WS(1CPU cycle)|0 < HCLK <= 30 |0 < HCLK <= 24 |0 < HCLK <= 22 |0 < HCLK <= 20 |
144 |---------------|----------------|----------------|-----------------|-----------------|
145 |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |22 < HCLK <= 44 |20 < HCLK <= 40 |
146 |---------------|----------------|----------------|-----------------|-----------------|
147 |2WS(3CPU cycle)|60 < HCLK <= 90 |48 < HCLK <= 72 |44 < HCLK <= 66 |40 < HCLK <= 60 |
148 |---------------|----------------|----------------|-----------------|-----------------|
149 |3WS(4CPU cycle)|90 < HCLK <= 120|72 < HCLK <= 96 |66 < HCLK <= 88 |60 < HCLK <= 80 |
150 |---------------|----------------|----------------|-----------------|-----------------|
151 |4WS(5CPU cycle)|120< HCLK <= 150|96 < HCLK <= 120|88 < HCLK <= 110 |80 < HCLK <= 100 |
152 |---------------|----------------|----------------|-----------------|-----------------|
153 |5WS(6CPU cycle)|120< HCLK <= 180|120< HCLK <= 144|110 < HCLK <= 132|100 < HCLK <= 120|
154 |---------------|----------------|----------------|-----------------|-----------------|
155 |6WS(7CPU cycle)| NA |144< HCLK <= 168|132 < HCLK <= 154|120 < HCLK <= 140|
156 |---------------|----------------|----------------|-----------------|-----------------|
157 |7WS(8CPU cycle)| NA |168< HCLK <= 180|154 < HCLK <= 176|140 < HCLK <= 160|
158 |---------------|----------------|----------------|-----------------|-----------------|
159 |8WS(9CPU cycle)| NA | NA |176 < HCLK <= 180|160 < HCLK <= 168|
160 +-------------------------------------------------------------------------------------+
162 [..]
163 For STM32F401x devices
164 +-------------------------------------------------------------------------------------+
165 | Latency | HCLK clock frequency (MHz) |
166 | |---------------------------------------------------------------------|
167 | | voltage range | voltage range | voltage range | voltage range |
168 | | 2.7 V - 3.6 V | 2.4 V - 2.7 V | 2.1 V - 2.4 V | 1.8 V - 2.1 V |
169 |---------------|----------------|----------------|-----------------|-----------------|
170 |0WS(1CPU cycle)|0 < HCLK <= 30 |0 < HCLK <= 24 |0 < HCLK <= 22 |0 < HCLK <= 20 |
171 |---------------|----------------|----------------|-----------------|-----------------|
172 |1WS(2CPU cycle)|30 < HCLK <= 60 |24 < HCLK <= 48 |22 < HCLK <= 44 |20 < HCLK <= 40 |
173 |---------------|----------------|----------------|-----------------|-----------------|
174 |2WS(3CPU cycle)|60 < HCLK <= 84 |48 < HCLK <= 72 |44 < HCLK <= 66 |40 < HCLK <= 60 |
175 |---------------|----------------|----------------|-----------------|-----------------|
176 |3WS(4CPU cycle)| NA |72 < HCLK <= 84 |66 < HCLK <= 84 |60 < HCLK <= 80 |
177 |---------------|----------------|----------------|-----------------|-----------------|
178 |4WS(5CPU cycle)| NA | NA | NA |80 < HCLK <= 84 |
179 +-------------------------------------------------------------------------------------+
181 [..]
182 For STM32F410xx/STM32F411xE devices
183 +-------------------------------------------------------------------------------------+
184 | Latency | HCLK clock frequency (MHz) |
185 | |---------------------------------------------------------------------|
186 | | voltage range | voltage range | voltage range | voltage range |
187 | | 2.7 V - 3.6 V | 2.4 V - 2.7 V | 2.1 V - 2.4 V | 1.8 V - 2.1 V |
188 |---------------|----------------|----------------|-----------------|-----------------|
189 |0WS(1CPU cycle)|0 < HCLK <= 30 |0 < HCLK <= 24 |0 < HCLK <= 18 |0 < HCLK <= 16 |
190 |---------------|----------------|----------------|-----------------|-----------------|
191 |1WS(2CPU cycle)|30 < HCLK <= 64 |24 < HCLK <= 48 |18 < HCLK <= 36 |16 < HCLK <= 32 |
192 |---------------|----------------|----------------|-----------------|-----------------|
193 |2WS(3CPU cycle)|64 < HCLK <= 90 |48 < HCLK <= 72 |36 < HCLK <= 54 |32 < HCLK <= 48 |
194 |---------------|----------------|----------------|-----------------|-----------------|
195 |3WS(4CPU cycle)|90 < HCLK <= 100|72 < HCLK <= 96 |54 < HCLK <= 72 |48 < HCLK <= 64 |
196 |---------------|----------------|----------------|-----------------|-----------------|
197 |4WS(5CPU cycle)| NA |96 < HCLK <= 100|72 < HCLK <= 90 |64 < HCLK <= 80 |
198 |---------------|----------------|----------------|-----------------|-----------------|
199 |5WS(6CPU cycle)| NA | NA |90 < HCLK <= 100 |80 < HCLK <= 96 |
200 |---------------|----------------|----------------|-----------------|-----------------|
201 |6WS(7CPU cycle)| NA | NA | NA |96 < HCLK <= 100 |
202 +-------------------------------------------------------------------------------------+
204 [..]
205 +-------------------------------------------------------------------------------------------------------------------+
206 | | voltage range | voltage range | voltage range | voltage range | voltage range 2.7 V - 3.6 V |
207 | | 2.7 V - 3.6 V | 2.4 V - 2.7 V | 2.1 V - 2.4 V | 1.8 V - 2.1 V | with External Vpp = 9V |
208 |---------------|----------------|----------------|-----------------|-----------------|-----------------------------|
209 |Max Parallelism| x32 | x16 | x8 | x64 |
210 |---------------|----------------|----------------|-----------------|-----------------|-----------------------------|
211 |PSIZE[1:0] | 10 | 01 | 00 | 11 |
212 +-------------------------------------------------------------------------------------------------------------------+
214 -@- On STM32F405xx/407xx and STM32F415xx/417xx devices:
215 (++) when VOS = '0' Scale 2 mode, the maximum value of fHCLK = 144MHz.
216 (++) when VOS = '1' Scale 1 mode, the maximum value of fHCLK = 168MHz.
217 [..]
218 On STM32F42xxx/43xxx devices:
219 (++) when VOS[1:0] = '0x01' Scale 3 mode, the maximum value of fHCLK is 120MHz.
220 (++) when VOS[1:0] = '0x10' Scale 2 mode, the maximum value of fHCLK is 144MHz if OverDrive OFF and 168MHz if OverDrive ON.
221 (++) when VOS[1:0] = '0x11' Scale 1 mode, the maximum value of fHCLK is 168MHz if OverDrive OFF and 180MHz if OverDrive ON.
222 [..]
223 On STM32F401x devices:
224 (++) when VOS[1:0] = '0x01' Scale 3 mode, the maximum value of fHCLK is 60MHz.
225 (++) when VOS[1:0] = '0x10' Scale 2 mode, the maximum value of fHCLK is 84MHz.
226 [..]
227 On STM32F410xx/STM32F411xE devices:
228 (++) when VOS[1:0] = '0x01' Scale 3 mode, the maximum value of fHCLK is 64MHz.
229 (++) when VOS[1:0] = '0x10' Scale 2 mode, the maximum value of fHCLK is 84MHz.
230 (++) when VOS[1:0] = '0x11' Scale 1 mode, the maximum value of fHCLK is 100MHz.
232 For more details please refer product DataSheet
233 You can use PWR_MainRegulatorModeConfig() function to control VOS bits.
235 (+) void FLASH_PrefetchBufferCmd(FunctionalState NewState)
236 (+) void FLASH_InstructionCacheCmd(FunctionalState NewState)
237 (+) void FLASH_DataCacheCmd(FunctionalState NewState)
238 (+) void FLASH_InstructionCacheReset(void)
239 (+) void FLASH_DataCacheReset(void)
241 [..]
242 The unlock sequence is not needed for these functions.
244 @endverbatim
245 * @{
249 * @brief Sets the code latency value.
250 * @param FLASH_Latency: specifies the FLASH Latency value.
251 * This parameter can be one of the following values:
252 * @arg FLASH_Latency_0: FLASH Zero Latency cycle
253 * @arg FLASH_Latency_1: FLASH One Latency cycle
254 * @arg FLASH_Latency_2: FLASH Two Latency cycles
255 * @arg FLASH_Latency_3: FLASH Three Latency cycles
256 * @arg FLASH_Latency_4: FLASH Four Latency cycles
257 * @arg FLASH_Latency_5: FLASH Five Latency cycles
258 * @arg FLASH_Latency_6: FLASH Six Latency cycles
259 * @arg FLASH_Latency_7: FLASH Seven Latency cycles
260 * @arg FLASH_Latency_8: FLASH Eight Latency cycles
261 * @arg FLASH_Latency_9: FLASH Nine Latency cycles
262 * @arg FLASH_Latency_10: FLASH Teen Latency cycles
263 * @arg FLASH_Latency_11: FLASH Eleven Latency cycles
264 * @arg FLASH_Latency_12: FLASH Twelve Latency cycles
265 * @arg FLASH_Latency_13: FLASH Thirteen Latency cycles
266 * @arg FLASH_Latency_14: FLASH Fourteen Latency cycles
267 * @arg FLASH_Latency_15: FLASH Fifteen Latency cycles
269 * @note For STM32F405xx/407xx, STM32F415xx/417xx, STM32F401xx/411xE and STM32F412xG devices
270 * this parameter can be a value between FLASH_Latency_0 and FLASH_Latency_7.
272 * @note For STM32F42xxx/43xxx devices this parameter can be a value between
273 * FLASH_Latency_0 and FLASH_Latency_15.
275 * @retval None
277 void FLASH_SetLatency(uint32_t FLASH_Latency)
279 /* Check the parameters */
280 assert_param(IS_FLASH_LATENCY(FLASH_Latency));
282 /* Perform Byte access to FLASH_ACR[8:0] to set the Latency value */
283 *(__IO uint8_t *)ACR_BYTE0_ADDRESS = (uint8_t)FLASH_Latency;
287 * @brief Enables or disables the Prefetch Buffer.
288 * @param NewState: new state of the Prefetch Buffer.
289 * This parameter can be: ENABLE or DISABLE.
290 * @retval None
292 void FLASH_PrefetchBufferCmd(FunctionalState NewState)
294 /* Check the parameters */
295 assert_param(IS_FUNCTIONAL_STATE(NewState));
297 /* Enable or disable the Prefetch Buffer */
298 if(NewState != DISABLE)
300 FLASH->ACR |= FLASH_ACR_PRFTEN;
302 else
304 FLASH->ACR &= (~FLASH_ACR_PRFTEN);
309 * @brief Enables or disables the Instruction Cache feature.
310 * @param NewState: new state of the Instruction Cache.
311 * This parameter can be: ENABLE or DISABLE.
312 * @retval None
314 void FLASH_InstructionCacheCmd(FunctionalState NewState)
316 /* Check the parameters */
317 assert_param(IS_FUNCTIONAL_STATE(NewState));
319 if(NewState != DISABLE)
321 FLASH->ACR |= FLASH_ACR_ICEN;
323 else
325 FLASH->ACR &= (~FLASH_ACR_ICEN);
330 * @brief Enables or disables the Data Cache feature.
331 * @param NewState: new state of the Data Cache.
332 * This parameter can be: ENABLE or DISABLE.
333 * @retval None
335 void FLASH_DataCacheCmd(FunctionalState NewState)
337 /* Check the parameters */
338 assert_param(IS_FUNCTIONAL_STATE(NewState));
340 if(NewState != DISABLE)
342 FLASH->ACR |= FLASH_ACR_DCEN;
344 else
346 FLASH->ACR &= (~FLASH_ACR_DCEN);
351 * @brief Resets the Instruction Cache.
352 * @note This function must be used only when the Instruction Cache is disabled.
353 * @param None
354 * @retval None
356 void FLASH_InstructionCacheReset(void)
358 FLASH->ACR |= FLASH_ACR_ICRST;
362 * @brief Resets the Data Cache.
363 * @note This function must be used only when the Data Cache is disabled.
364 * @param None
365 * @retval None
367 void FLASH_DataCacheReset(void)
369 FLASH->ACR |= FLASH_ACR_DCRST;
373 * @}
376 /** @defgroup FLASH_Group2 FLASH Memory Programming functions
377 * @brief FLASH Memory Programming functions
379 @verbatim
380 ===============================================================================
381 ##### FLASH Memory Programming functions #####
382 ===============================================================================
383 [..]
384 This group includes the following functions:
385 (+) void FLASH_Unlock(void)
386 (+) void FLASH_Lock(void)
387 (+) FLASH_Status FLASH_EraseSector(uint32_t FLASH_Sector, uint8_t VoltageRange)
388 (+) FLASH_Status FLASH_EraseAllSectors(uint8_t VoltageRange)
389 (+) FLASH_Status FLASH_ProgramDoubleWord(uint32_t Address, uint64_t Data)
390 (+) FLASH_Status FLASH_ProgramWord(uint32_t Address, uint32_t Data)
391 (+) FLASH_Status FLASH_ProgramHalfWord(uint32_t Address, uint16_t Data)
392 (+) FLASH_Status FLASH_ProgramByte(uint32_t Address, uint8_t Data)
393 The following functions can be used only for STM32F42xxx/43xxx devices.
394 (+) FLASH_Status FLASH_EraseAllBank1Sectors(uint8_t VoltageRange)
395 (+) FLASH_Status FLASH_EraseAllBank2Sectors(uint8_t VoltageRange)
396 [..]
397 Any operation of erase or program should follow these steps:
398 (#) Call the FLASH_Unlock() function to enable the FLASH control register access
400 (#) Call the desired function to erase sector(s) or program data
402 (#) Call the FLASH_Lock() function to disable the FLASH control register access
403 (recommended to protect the FLASH memory against possible unwanted operation)
405 @endverbatim
406 * @{
410 * @brief Unlocks the FLASH control register access
411 * @param None
412 * @retval None
414 void FLASH_Unlock(void)
416 if((FLASH->CR & FLASH_CR_LOCK) != RESET)
418 /* Authorize the FLASH Registers access */
419 FLASH->KEYR = FLASH_KEY1;
420 FLASH->KEYR = FLASH_KEY2;
425 * @brief Locks the FLASH control register access
426 * @param None
427 * @retval None
429 void FLASH_Lock(void)
431 /* Set the LOCK Bit to lock the FLASH Registers access */
432 FLASH->CR |= FLASH_CR_LOCK;
436 * @brief Erases a specified FLASH Sector.
438 * @note If an erase and a program operations are requested simultaneously,
439 * the erase operation is performed before the program one.
441 * @param FLASH_Sector: The Sector number to be erased.
443 * @note For STM32F405xx/407xx and STM32F415xx/417xx devices this parameter can
444 * be a value between FLASH_Sector_0 and FLASH_Sector_11.
446 * For STM32F42xxx/43xxx devices this parameter can be a value between
447 * FLASH_Sector_0 and FLASH_Sector_23.
449 * For STM32F401xx devices this parameter can be a value between
450 * FLASH_Sector_0 and FLASH_Sector_5.
452 * For STM32F411xE and STM32F412xG devices this parameter can be a value between
453 * FLASH_Sector_0 and FLASH_Sector_7.
455 * For STM32F410xx devices this parameter can be a value between
456 * FLASH_Sector_0 and FLASH_Sector_4.
458 * @param VoltageRange: The device voltage range which defines the erase parallelism.
459 * This parameter can be one of the following values:
460 * @arg VoltageRange_1: when the device voltage range is 1.8V to 2.1V,
461 * the operation will be done by byte (8-bit)
462 * @arg VoltageRange_2: when the device voltage range is 2.1V to 2.7V,
463 * the operation will be done by half word (16-bit)
464 * @arg VoltageRange_3: when the device voltage range is 2.7V to 3.6V,
465 * the operation will be done by word (32-bit)
466 * @arg VoltageRange_4: when the device voltage range is 2.7V to 3.6V + External Vpp,
467 * the operation will be done by double word (64-bit)
469 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
470 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
472 FLASH_Status FLASH_EraseSector(uint32_t FLASH_Sector, uint8_t VoltageRange)
474 uint32_t tmp_psize = 0x0;
475 FLASH_Status status = FLASH_COMPLETE;
477 /* Check the parameters */
478 assert_param(IS_FLASH_SECTOR(FLASH_Sector));
479 assert_param(IS_VOLTAGERANGE(VoltageRange));
481 if(VoltageRange == VoltageRange_1)
483 tmp_psize = FLASH_PSIZE_BYTE;
485 else if(VoltageRange == VoltageRange_2)
487 tmp_psize = FLASH_PSIZE_HALF_WORD;
489 else if(VoltageRange == VoltageRange_3)
491 tmp_psize = FLASH_PSIZE_WORD;
493 else
495 tmp_psize = FLASH_PSIZE_DOUBLE_WORD;
497 /* Wait for last operation to be completed */
498 status = FLASH_WaitForLastOperation();
500 if(status == FLASH_COMPLETE)
502 /* if the previous operation is completed, proceed to erase the sector */
503 FLASH->CR &= CR_PSIZE_MASK;
504 FLASH->CR |= tmp_psize;
505 FLASH->CR &= SECTOR_MASK;
506 FLASH->CR |= FLASH_CR_SER | FLASH_Sector;
507 FLASH->CR |= FLASH_CR_STRT;
509 /* Wait for last operation to be completed */
510 status = FLASH_WaitForLastOperation();
512 /* if the erase operation is completed, disable the SER Bit */
513 FLASH->CR &= (~FLASH_CR_SER);
514 FLASH->CR &= SECTOR_MASK;
516 /* Return the Erase Status */
517 return status;
521 * @brief Erases all FLASH Sectors.
523 * @note If an erase and a program operations are requested simultaneously,
524 * the erase operation is performed before the program one.
526 * @param VoltageRange: The device voltage range which defines the erase parallelism.
527 * This parameter can be one of the following values:
528 * @arg VoltageRange_1: when the device voltage range is 1.8V to 2.1V,
529 * the operation will be done by byte (8-bit)
530 * @arg VoltageRange_2: when the device voltage range is 2.1V to 2.7V,
531 * the operation will be done by half word (16-bit)
532 * @arg VoltageRange_3: when the device voltage range is 2.7V to 3.6V,
533 * the operation will be done by word (32-bit)
534 * @arg VoltageRange_4: when the device voltage range is 2.7V to 3.6V + External Vpp,
535 * the operation will be done by double word (64-bit)
537 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
538 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
540 FLASH_Status FLASH_EraseAllSectors(uint8_t VoltageRange)
542 uint32_t tmp_psize = 0x0;
543 FLASH_Status status = FLASH_COMPLETE;
545 /* Wait for last operation to be completed */
546 status = FLASH_WaitForLastOperation();
547 assert_param(IS_VOLTAGERANGE(VoltageRange));
549 if(VoltageRange == VoltageRange_1)
551 tmp_psize = FLASH_PSIZE_BYTE;
553 else if(VoltageRange == VoltageRange_2)
555 tmp_psize = FLASH_PSIZE_HALF_WORD;
557 else if(VoltageRange == VoltageRange_3)
559 tmp_psize = FLASH_PSIZE_WORD;
561 else
563 tmp_psize = FLASH_PSIZE_DOUBLE_WORD;
565 if(status == FLASH_COMPLETE)
567 /* if the previous operation is completed, proceed to erase all sectors */
568 #if defined(STM32F427_437xx) || defined(STM32F429_439xx) || defined(STM32F469_479xx)
569 FLASH->CR &= CR_PSIZE_MASK;
570 FLASH->CR |= tmp_psize;
571 FLASH->CR |= (FLASH_CR_MER1 | FLASH_CR_MER2);
572 FLASH->CR |= FLASH_CR_STRT;
574 /* Wait for last operation to be completed */
575 status = FLASH_WaitForLastOperation();
577 /* if the erase operation is completed, disable the MER Bit */
578 FLASH->CR &= ~(FLASH_CR_MER1 | FLASH_CR_MER2);
579 #endif /* STM32F427_437xx || STM32F429_439xx || STM32F469_479xx */
581 #if defined(STM32F40_41xxx) || defined(STM32F401xx) || defined(STM32F410xx) || defined(STM32F411xE) || defined(STM32F412xG) || defined(STM32F446xx)
582 FLASH->CR &= CR_PSIZE_MASK;
583 FLASH->CR |= tmp_psize;
584 FLASH->CR |= FLASH_CR_MER;
585 FLASH->CR |= FLASH_CR_STRT;
587 /* Wait for last operation to be completed */
588 status = FLASH_WaitForLastOperation();
590 /* if the erase operation is completed, disable the MER Bit */
591 FLASH->CR &= (~FLASH_CR_MER);
592 #endif /* STM32F40_41xxx || STM32F401xx || STM32F410xx || STM32F411xE || STM32F412xG || STM32F446xx */
595 /* Return the Erase Status */
596 return status;
600 * @brief Erases all FLASH Sectors in Bank 1.
602 * @note This function can be used only for STM32F42xxx/43xxx devices.
604 * @note If an erase and a program operations are requested simultaneously,
605 * the erase operation is performed before the program one.
607 * @param VoltageRange: The device voltage range which defines the erase parallelism.
608 * This parameter can be one of the following values:
609 * @arg VoltageRange_1: when the device voltage range is 1.8V to 2.1V,
610 * the operation will be done by byte (8-bit)
611 * @arg VoltageRange_2: when the device voltage range is 2.1V to 2.7V,
612 * the operation will be done by half word (16-bit)
613 * @arg VoltageRange_3: when the device voltage range is 2.7V to 3.6V,
614 * the operation will be done by word (32-bit)
615 * @arg VoltageRange_4: when the device voltage range is 2.7V to 3.6V + External Vpp,
616 * the operation will be done by double word (64-bit)
618 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
619 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
621 FLASH_Status FLASH_EraseAllBank1Sectors(uint8_t VoltageRange)
623 uint32_t tmp_psize = 0x0;
624 FLASH_Status status = FLASH_COMPLETE;
626 /* Wait for last operation to be completed */
627 status = FLASH_WaitForLastOperation();
628 assert_param(IS_VOLTAGERANGE(VoltageRange));
630 if(VoltageRange == VoltageRange_1)
632 tmp_psize = FLASH_PSIZE_BYTE;
634 else if(VoltageRange == VoltageRange_2)
636 tmp_psize = FLASH_PSIZE_HALF_WORD;
638 else if(VoltageRange == VoltageRange_3)
640 tmp_psize = FLASH_PSIZE_WORD;
642 else
644 tmp_psize = FLASH_PSIZE_DOUBLE_WORD;
646 if(status == FLASH_COMPLETE)
648 /* if the previous operation is completed, proceed to erase all sectors */
649 FLASH->CR &= CR_PSIZE_MASK;
650 FLASH->CR |= tmp_psize;
651 FLASH->CR |= FLASH_CR_MER1;
652 FLASH->CR |= FLASH_CR_STRT;
654 /* Wait for last operation to be completed */
655 status = FLASH_WaitForLastOperation();
657 /* if the erase operation is completed, disable the MER Bit */
658 FLASH->CR &= (~FLASH_CR_MER1);
661 /* Return the Erase Status */
662 return status;
667 * @brief Erases all FLASH Sectors in Bank 2.
669 * @note This function can be used only for STM32F42xxx/43xxx devices.
671 * @note If an erase and a program operations are requested simultaneously,
672 * the erase operation is performed before the program one.
674 * @param VoltageRange: The device voltage range which defines the erase parallelism.
675 * This parameter can be one of the following values:
676 * @arg VoltageRange_1: when the device voltage range is 1.8V to 2.1V,
677 * the operation will be done by byte (8-bit)
678 * @arg VoltageRange_2: when the device voltage range is 2.1V to 2.7V,
679 * the operation will be done by half word (16-bit)
680 * @arg VoltageRange_3: when the device voltage range is 2.7V to 3.6V,
681 * the operation will be done by word (32-bit)
682 * @arg VoltageRange_4: when the device voltage range is 2.7V to 3.6V + External Vpp,
683 * the operation will be done by double word (64-bit)
685 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
686 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
688 FLASH_Status FLASH_EraseAllBank2Sectors(uint8_t VoltageRange)
690 uint32_t tmp_psize = 0x0;
691 FLASH_Status status = FLASH_COMPLETE;
693 /* Wait for last operation to be completed */
694 status = FLASH_WaitForLastOperation();
695 assert_param(IS_VOLTAGERANGE(VoltageRange));
697 if(VoltageRange == VoltageRange_1)
699 tmp_psize = FLASH_PSIZE_BYTE;
701 else if(VoltageRange == VoltageRange_2)
703 tmp_psize = FLASH_PSIZE_HALF_WORD;
705 else if(VoltageRange == VoltageRange_3)
707 tmp_psize = FLASH_PSIZE_WORD;
709 else
711 tmp_psize = FLASH_PSIZE_DOUBLE_WORD;
713 if(status == FLASH_COMPLETE)
715 /* if the previous operation is completed, proceed to erase all sectors */
716 FLASH->CR &= CR_PSIZE_MASK;
717 FLASH->CR |= tmp_psize;
718 FLASH->CR |= FLASH_CR_MER2;
719 FLASH->CR |= FLASH_CR_STRT;
721 /* Wait for last operation to be completed */
722 status = FLASH_WaitForLastOperation();
724 /* if the erase operation is completed, disable the MER Bit */
725 FLASH->CR &= (~FLASH_CR_MER2);
728 /* Return the Erase Status */
729 return status;
733 * @brief Programs a double word (64-bit) at a specified address.
734 * @note This function must be used when the device voltage range is from
735 * 2.7V to 3.6V and an External Vpp is present.
737 * @note If an erase and a program operations are requested simultaneously,
738 * the erase operation is performed before the program one.
740 * @param Address: specifies the address to be programmed.
741 * @param Data: specifies the data to be programmed.
742 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
743 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
745 FLASH_Status FLASH_ProgramDoubleWord(uint32_t Address, uint64_t Data)
747 FLASH_Status status = FLASH_COMPLETE;
749 /* Check the parameters */
750 assert_param(IS_FLASH_ADDRESS(Address));
752 /* Wait for last operation to be completed */
753 status = FLASH_WaitForLastOperation();
755 if(status == FLASH_COMPLETE)
757 /* if the previous operation is completed, proceed to program the new data */
758 FLASH->CR &= CR_PSIZE_MASK;
759 FLASH->CR |= FLASH_PSIZE_DOUBLE_WORD;
760 FLASH->CR |= FLASH_CR_PG;
762 *(__IO uint64_t*)Address = Data;
764 /* Wait for last operation to be completed */
765 status = FLASH_WaitForLastOperation();
767 /* if the program operation is completed, disable the PG Bit */
768 FLASH->CR &= (~FLASH_CR_PG);
770 /* Return the Program Status */
771 return status;
775 * @brief Programs a word (32-bit) at a specified address.
777 * @note This function must be used when the device voltage range is from 2.7V to 3.6V.
779 * @note If an erase and a program operations are requested simultaneously,
780 * the erase operation is performed before the program one.
782 * @param Address: specifies the address to be programmed.
783 * This parameter can be any address in Program memory zone or in OTP zone.
784 * @param Data: specifies the data to be programmed.
785 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
786 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
788 FLASH_Status FLASH_ProgramWord(uint32_t Address, uint32_t Data)
790 FLASH_Status status = FLASH_COMPLETE;
792 /* Check the parameters */
793 assert_param(IS_FLASH_ADDRESS(Address));
795 /* Wait for last operation to be completed */
796 status = FLASH_WaitForLastOperation();
798 if(status == FLASH_COMPLETE)
800 /* if the previous operation is completed, proceed to program the new data */
801 FLASH->CR &= CR_PSIZE_MASK;
802 FLASH->CR |= FLASH_PSIZE_WORD;
803 FLASH->CR |= FLASH_CR_PG;
805 *(__IO uint32_t*)Address = Data;
807 /* Wait for last operation to be completed */
808 status = FLASH_WaitForLastOperation();
810 /* if the program operation is completed, disable the PG Bit */
811 FLASH->CR &= (~FLASH_CR_PG);
813 /* Return the Program Status */
814 return status;
818 * @brief Programs a half word (16-bit) at a specified address.
819 * @note This function must be used when the device voltage range is from 2.1V to 3.6V.
821 * @note If an erase and a program operations are requested simultaneously,
822 * the erase operation is performed before the program one.
824 * @param Address: specifies the address to be programmed.
825 * This parameter can be any address in Program memory zone or in OTP zone.
826 * @param Data: specifies the data to be programmed.
827 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
828 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
830 FLASH_Status FLASH_ProgramHalfWord(uint32_t Address, uint16_t Data)
832 FLASH_Status status = FLASH_COMPLETE;
834 /* Check the parameters */
835 assert_param(IS_FLASH_ADDRESS(Address));
837 /* Wait for last operation to be completed */
838 status = FLASH_WaitForLastOperation();
840 if(status == FLASH_COMPLETE)
842 /* if the previous operation is completed, proceed to program the new data */
843 FLASH->CR &= CR_PSIZE_MASK;
844 FLASH->CR |= FLASH_PSIZE_HALF_WORD;
845 FLASH->CR |= FLASH_CR_PG;
847 *(__IO uint16_t*)Address = Data;
849 /* Wait for last operation to be completed */
850 status = FLASH_WaitForLastOperation();
852 /* if the program operation is completed, disable the PG Bit */
853 FLASH->CR &= (~FLASH_CR_PG);
855 /* Return the Program Status */
856 return status;
860 * @brief Programs a byte (8-bit) at a specified address.
861 * @note This function can be used within all the device supply voltage ranges.
863 * @note If an erase and a program operations are requested simultaneously,
864 * the erase operation is performed before the program one.
866 * @param Address: specifies the address to be programmed.
867 * This parameter can be any address in Program memory zone or in OTP zone.
868 * @param Data: specifies the data to be programmed.
869 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
870 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
872 FLASH_Status FLASH_ProgramByte(uint32_t Address, uint8_t Data)
874 FLASH_Status status = FLASH_COMPLETE;
876 /* Check the parameters */
877 assert_param(IS_FLASH_ADDRESS(Address));
879 /* Wait for last operation to be completed */
880 status = FLASH_WaitForLastOperation();
882 if(status == FLASH_COMPLETE)
884 /* if the previous operation is completed, proceed to program the new data */
885 FLASH->CR &= CR_PSIZE_MASK;
886 FLASH->CR |= FLASH_PSIZE_BYTE;
887 FLASH->CR |= FLASH_CR_PG;
889 *(__IO uint8_t*)Address = Data;
891 /* Wait for last operation to be completed */
892 status = FLASH_WaitForLastOperation();
894 /* if the program operation is completed, disable the PG Bit */
895 FLASH->CR &= (~FLASH_CR_PG);
898 /* Return the Program Status */
899 return status;
903 * @}
906 /** @defgroup FLASH_Group3 Option Bytes Programming functions
907 * @brief Option Bytes Programming functions
909 @verbatim
910 ===============================================================================
911 ##### Option Bytes Programming functions #####
912 ===============================================================================
913 [..]
914 This group includes the following functions:
915 (+) void FLASH_OB_Unlock(void)
916 (+) void FLASH_OB_Lock(void)
917 (+) void FLASH_OB_WRPConfig(uint32_t OB_WRP, FunctionalState NewState)
918 (+) void FLASH_OB_WRP1Config(uint32_t OB_WRP, FunctionalState NewState)
919 (+) void FLASH_OB_PCROPSelectionConfig(uint8_t OB_PCROPSelect)
920 (+) void FLASH_OB_PCROPConfig(uint32_t OB_PCROP, FunctionalState NewState)
921 (+) void FLASH_OB_PCROP1Config(uint32_t OB_PCROP, FunctionalState NewState)
922 (+) void FLASH_OB_RDPConfig(uint8_t OB_RDP)
923 (+) void FLASH_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_STOP, uint8_t OB_STDBY)
924 (+) void FLASH_OB_BORConfig(uint8_t OB_BOR)
925 (+) FLASH_Status FLASH_ProgramOTP(uint32_t Address, uint32_t Data)
926 (+) FLASH_Status FLASH_OB_Launch(void)
927 (+) uint32_t FLASH_OB_GetUser(void)
928 (+) uint8_t FLASH_OB_GetWRP(void)
929 (+) uint8_t FLASH_OB_GetWRP1(void)
930 (+) uint8_t FLASH_OB_GetPCROP(void)
931 (+) uint8_t FLASH_OB_GetPCROP1(void)
932 (+) uint8_t FLASH_OB_GetRDP(void)
933 (+) uint8_t FLASH_OB_GetBOR(void)
934 [..]
935 The following function can be used only for STM32F42xxx/43xxx devices.
936 (+) void FLASH_OB_BootConfig(uint8_t OB_BOOT)
937 [..]
938 Any operation of erase or program should follow these steps:
939 (#) Call the FLASH_OB_Unlock() function to enable the FLASH option control
940 register access
942 (#) Call one or several functions to program the desired Option Bytes:
943 (++) void FLASH_OB_WRPConfig(uint32_t OB_WRP, FunctionalState NewState)
944 => to Enable/Disable the desired sector write protection
945 (++) void FLASH_OB_RDPConfig(uint8_t OB_RDP) => to set the desired read
946 Protection Level
947 (++) void FLASH_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_STOP, uint8_t OB_STDBY)
948 => to configure the user Option Bytes.
949 (++) void FLASH_OB_BORConfig(uint8_t OB_BOR) => to set the BOR Level
951 (#) Once all needed Option Bytes to be programmed are correctly written,
952 call the FLASH_OB_Launch() function to launch the Option Bytes
953 programming process.
955 -@- When changing the IWDG mode from HW to SW or from SW to HW, a system
956 reset is needed to make the change effective.
958 (#) Call the FLASH_OB_Lock() function to disable the FLASH option control
959 register access (recommended to protect the Option Bytes against
960 possible unwanted operations)
962 @endverbatim
963 * @{
967 * @brief Unlocks the FLASH Option Control Registers access.
968 * @param None
969 * @retval None
971 void FLASH_OB_Unlock(void)
973 if((FLASH->OPTCR & FLASH_OPTCR_OPTLOCK) != RESET)
975 /* Authorizes the Option Byte register programming */
976 FLASH->OPTKEYR = FLASH_OPT_KEY1;
977 FLASH->OPTKEYR = FLASH_OPT_KEY2;
982 * @brief Locks the FLASH Option Control Registers access.
983 * @param None
984 * @retval None
986 void FLASH_OB_Lock(void)
988 /* Set the OPTLOCK Bit to lock the FLASH Option Byte Registers access */
989 FLASH->OPTCR |= FLASH_OPTCR_OPTLOCK;
993 * @brief Enables or disables the write protection of the desired sectors, for the first
994 * 1 Mb of the Flash
996 * @note When the memory read protection level is selected (RDP level = 1),
997 * it is not possible to program or erase the flash sector i if CortexM4
998 * debug features are connected or boot code is executed in RAM, even if nWRPi = 1
999 * @note Active value of nWRPi bits is inverted when PCROP mode is active (SPRMOD =1).
1001 * @param OB_WRP: specifies the sector(s) to be write protected or unprotected.
1002 * This parameter can be one of the following values:
1003 * @arg OB_WRP: A value between OB_WRP_Sector0 and OB_WRP_Sector11
1004 * @arg OB_WRP_Sector_All
1005 * @param Newstate: new state of the Write Protection.
1006 * This parameter can be: ENABLE or DISABLE.
1007 * @retval None
1009 void FLASH_OB_WRPConfig(uint32_t OB_WRP, FunctionalState NewState)
1011 FLASH_Status status = FLASH_COMPLETE;
1013 /* Check the parameters */
1014 assert_param(IS_OB_WRP(OB_WRP));
1015 assert_param(IS_FUNCTIONAL_STATE(NewState));
1017 status = FLASH_WaitForLastOperation();
1019 if(status == FLASH_COMPLETE)
1021 if(NewState != DISABLE)
1023 *(__IO uint16_t*)OPTCR_BYTE2_ADDRESS &= (~OB_WRP);
1025 else
1027 *(__IO uint16_t*)OPTCR_BYTE2_ADDRESS |= (uint16_t)OB_WRP;
1033 * @brief Enables or disables the write protection of the desired sectors, for the second
1034 * 1 Mb of the Flash
1036 * @note This function can be used only for STM32F42xxx/43xxx devices.
1038 * @note When the memory read out protection is selected (RDP level = 1),
1039 * it is not possible to program or erase the flash sector i if CortexM4
1040 * debug features are connected or boot code is executed in RAM, even if nWRPi = 1
1041 * @note Active value of nWRPi bits is inverted when PCROP mode is active (SPRMOD =1).
1043 * @param OB_WRP: specifies the sector(s) to be write protected or unprotected.
1044 * This parameter can be one of the following values:
1045 * @arg OB_WRP: A value between OB_WRP_Sector12 and OB_WRP_Sector23
1046 * @arg OB_WRP_Sector_All
1047 * @param Newstate: new state of the Write Protection.
1048 * This parameter can be: ENABLE or DISABLE.
1049 * @retval None
1051 void FLASH_OB_WRP1Config(uint32_t OB_WRP, FunctionalState NewState)
1053 FLASH_Status status = FLASH_COMPLETE;
1055 /* Check the parameters */
1056 assert_param(IS_OB_WRP(OB_WRP));
1057 assert_param(IS_FUNCTIONAL_STATE(NewState));
1059 status = FLASH_WaitForLastOperation();
1061 if(status == FLASH_COMPLETE)
1063 if(NewState != DISABLE)
1065 *(__IO uint16_t*)OPTCR1_BYTE2_ADDRESS &= (~OB_WRP);
1067 else
1069 *(__IO uint16_t*)OPTCR1_BYTE2_ADDRESS |= (uint16_t)OB_WRP;
1075 * @brief Select the Protection Mode (SPRMOD).
1077 * @note This function can be used only for STM32F42xxx/43xxx and STM32F401xx/411xE devices.
1079 * @note After PCROP activation, Option Byte modification is not possible.
1080 * Exception made for the global Read Out Protection modification level (level1 to level0)
1081 * @note Once SPRMOD bit is active unprotection of a protected sector is not possible
1083 * @note Read a protected sector will set RDERR Flag and write a protected sector will set WRPERR Flag
1085 * @note Some Precautions should be taken when activating the PCROP feature :
1086 * The active value of nWRPi bits is inverted when PCROP mode is active, this means if SPRMOD = 1
1087 * and WRPi = 1 (default value), then the user sector i is read/write protected.
1088 * In order to avoid activation of PCROP Mode for undesired sectors, please follow the
1089 * below safety sequence :
1090 * - Disable PCROP for all Sectors using FLASH_OB_PCROPConfig(OB_PCROP_Sector_All, DISABLE) function
1091 * for Bank1 or FLASH_OB_PCROP1Config(OB_PCROP_Sector_All, DISABLE) function for Bank2
1092 * - Enable PCROP for the desired Sector i using FLASH_OB_PCROPConfig(Sector i, ENABLE) function
1093 * - Activate the PCROP Mode FLASH_OB_PCROPSelectionConfig() function.
1095 * @param OB_PCROP: Select the Protection Mode of nWPRi bits
1096 * This parameter can be one of the following values:
1097 * @arg OB_PcROP_Disable: nWRPi control the write protection of respective user sectors.
1098 * @arg OB_PcROP_Enable: nWRPi control the read&write protection (PCROP) of respective user sectors.
1099 * @retval None
1101 void FLASH_OB_PCROPSelectionConfig(uint8_t OB_PcROP)
1103 uint8_t optiontmp = 0xFF;
1105 /* Check the parameters */
1106 assert_param(IS_OB_PCROP_SELECT(OB_PcROP));
1108 /* Mask SPRMOD bit */
1109 optiontmp = (uint8_t)((*(__IO uint8_t *)OPTCR_BYTE3_ADDRESS) & (uint8_t)0x7F);
1110 /* Update Option Byte */
1111 *(__IO uint8_t *)OPTCR_BYTE3_ADDRESS = (uint8_t)(OB_PcROP | optiontmp);
1116 * @brief Enables or disables the read/write protection (PCROP) of the desired
1117 * sectors, for the first 1 MB of the Flash.
1119 * @note This function can be used only for STM32F42xxx/43xxx , STM32F401xx/411xE
1120 * and STM32F412xG devices.
1122 * @param OB_PCROP: specifies the sector(s) to be read/write protected or unprotected.
1123 * This parameter can be one of the following values:
1124 * @arg OB_PCROP: A value between OB_PCROP_Sector0 and OB_PCROP_Sector11 for
1125 * STM32F42xxx/43xxx devices and between OB_PCROP_Sector0 and
1126 * OB_PCROP_Sector5 for STM32F401xx/411xE devices.
1127 * @arg OB_PCROP_Sector_All
1128 * @param Newstate: new state of the Write Protection.
1129 * This parameter can be: ENABLE or DISABLE.
1130 * @retval None
1132 void FLASH_OB_PCROPConfig(uint32_t OB_PCROP, FunctionalState NewState)
1134 FLASH_Status status = FLASH_COMPLETE;
1136 /* Check the parameters */
1137 assert_param(IS_OB_PCROP(OB_PCROP));
1138 assert_param(IS_FUNCTIONAL_STATE(NewState));
1140 status = FLASH_WaitForLastOperation();
1142 if(status == FLASH_COMPLETE)
1144 if(NewState != DISABLE)
1146 *(__IO uint16_t*)OPTCR_BYTE2_ADDRESS |= (uint16_t)OB_PCROP;
1148 else
1150 *(__IO uint16_t*)OPTCR_BYTE2_ADDRESS &= (~OB_PCROP);
1156 * @brief Enables or disables the read/write protection (PCROP) of the desired
1157 * sectors
1159 * @note This function can be used only for STM32F42xxx/43xxx devices.
1161 * @param OB_PCROP: specifies the sector(s) to be read/write protected or unprotected.
1162 * This parameter can be one of the following values:
1163 * @arg OB_PCROP: A value between OB_PCROP_Sector12 and OB_PCROP_Sector23
1164 * @arg OB_PCROP_Sector_All
1165 * @param Newstate: new state of the Write Protection.
1166 * This parameter can be: ENABLE or DISABLE.
1167 * @retval None
1169 void FLASH_OB_PCROP1Config(uint32_t OB_PCROP, FunctionalState NewState)
1171 FLASH_Status status = FLASH_COMPLETE;
1173 /* Check the parameters */
1174 assert_param(IS_OB_PCROP(OB_PCROP));
1175 assert_param(IS_FUNCTIONAL_STATE(NewState));
1177 status = FLASH_WaitForLastOperation();
1179 if(status == FLASH_COMPLETE)
1181 if(NewState != DISABLE)
1183 *(__IO uint16_t*)OPTCR1_BYTE2_ADDRESS |= (uint16_t)OB_PCROP;
1185 else
1187 *(__IO uint16_t*)OPTCR1_BYTE2_ADDRESS &= (~OB_PCROP);
1194 * @brief Sets the read protection level.
1195 * @param OB_RDP: specifies the read protection level.
1196 * This parameter can be one of the following values:
1197 * @arg OB_RDP_Level_0: No protection
1198 * @arg OB_RDP_Level_1: Read protection of the memory
1199 * @arg OB_RDP_Level_2: Full chip protection
1201 * /!\ Warning /!\ When enabling OB_RDP level 2 it's no more possible to go back to level 1 or 0
1203 * @retval None
1205 void FLASH_OB_RDPConfig(uint8_t OB_RDP)
1207 FLASH_Status status = FLASH_COMPLETE;
1209 /* Check the parameters */
1210 assert_param(IS_OB_RDP(OB_RDP));
1212 status = FLASH_WaitForLastOperation();
1214 if(status == FLASH_COMPLETE)
1216 *(__IO uint8_t*)OPTCR_BYTE1_ADDRESS = OB_RDP;
1222 * @brief Programs the FLASH User Option Byte: IWDG_SW / RST_STOP / RST_STDBY.
1223 * @param OB_IWDG: Selects the IWDG mode
1224 * This parameter can be one of the following values:
1225 * @arg OB_IWDG_SW: Software IWDG selected
1226 * @arg OB_IWDG_HW: Hardware IWDG selected
1227 * @param OB_STOP: Reset event when entering STOP mode.
1228 * This parameter can be one of the following values:
1229 * @arg OB_STOP_NoRST: No reset generated when entering in STOP
1230 * @arg OB_STOP_RST: Reset generated when entering in STOP
1231 * @param OB_STDBY: Reset event when entering Standby mode.
1232 * This parameter can be one of the following values:
1233 * @arg OB_STDBY_NoRST: No reset generated when entering in STANDBY
1234 * @arg OB_STDBY_RST: Reset generated when entering in STANDBY
1235 * @retval None
1237 void FLASH_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_STOP, uint8_t OB_STDBY)
1239 uint8_t optiontmp = 0xFF;
1240 FLASH_Status status = FLASH_COMPLETE;
1242 /* Check the parameters */
1243 assert_param(IS_OB_IWDG_SOURCE(OB_IWDG));
1244 assert_param(IS_OB_STOP_SOURCE(OB_STOP));
1245 assert_param(IS_OB_STDBY_SOURCE(OB_STDBY));
1247 /* Wait for last operation to be completed */
1248 status = FLASH_WaitForLastOperation();
1250 if(status == FLASH_COMPLETE)
1252 #if defined(STM32F427_437xx) || defined(STM32F429_439xx) || defined(STM32F469_479xx)
1253 /* Mask OPTLOCK, OPTSTRT, BOR_LEV and BFB2 bits */
1254 optiontmp = (uint8_t)((*(__IO uint8_t *)OPTCR_BYTE0_ADDRESS) & (uint8_t)0x1F);
1255 #endif /* STM32F427_437xx || STM32F429_439xx || STM32F469_479xx */
1257 #if defined(STM32F40_41xxx) || defined(STM32F401xx) || defined(STM32F410xx) || defined(STM32F411xE) || defined(STM32F446xx)
1258 /* Mask OPTLOCK, OPTSTRT and BOR_LEV bits */
1259 optiontmp = (uint8_t)((*(__IO uint8_t *)OPTCR_BYTE0_ADDRESS) & (uint8_t)0x0F);
1260 #endif /* STM32F40_41xxx || STM32F401xx || STM32F410xx || STM32F411xE || STM32F446xx */
1262 /* Update User Option Byte */
1263 *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS = OB_IWDG | (uint8_t)(OB_STDBY | (uint8_t)(OB_STOP | ((uint8_t)optiontmp)));
1268 * @brief Configure the Dual Bank Boot.
1270 * @note This function can be used only for STM32F42xxx/43xxx devices.
1272 * @param OB_BOOT: specifies the Dual Bank Boot Option byte.
1273 * This parameter can be one of the following values:
1274 * @arg OB_Dual_BootEnabled: Dual Bank Boot Enable
1275 * @arg OB_Dual_BootDisabled: Dual Bank Boot Disabled
1276 * @retval None
1278 void FLASH_OB_BootConfig(uint8_t OB_BOOT)
1280 /* Check the parameters */
1281 assert_param(IS_OB_BOOT(OB_BOOT));
1283 /* Set Dual Bank Boot */
1284 *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS &= (~FLASH_OPTCR_BFB2);
1285 *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS |= OB_BOOT;
1290 * @brief Sets the BOR Level.
1291 * @param OB_BOR: specifies the Option Bytes BOR Reset Level.
1292 * This parameter can be one of the following values:
1293 * @arg OB_BOR_LEVEL3: Supply voltage ranges from 2.7 to 3.6 V
1294 * @arg OB_BOR_LEVEL2: Supply voltage ranges from 2.4 to 2.7 V
1295 * @arg OB_BOR_LEVEL1: Supply voltage ranges from 2.1 to 2.4 V
1296 * @arg OB_BOR_OFF: Supply voltage ranges from 1.62 to 2.1 V
1297 * @retval None
1299 void FLASH_OB_BORConfig(uint8_t OB_BOR)
1301 /* Check the parameters */
1302 assert_param(IS_OB_BOR(OB_BOR));
1304 /* Set the BOR Level */
1305 *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS &= (~FLASH_OPTCR_BOR_LEV);
1306 *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS |= OB_BOR;
1311 * @brief Launch the option byte loading.
1312 * @param None
1313 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
1314 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
1316 FLASH_Status FLASH_OB_Launch(void)
1318 FLASH_Status status = FLASH_COMPLETE;
1320 /* Set the OPTSTRT bit in OPTCR register */
1321 *(__IO uint8_t *)OPTCR_BYTE0_ADDRESS |= FLASH_OPTCR_OPTSTRT;
1323 /* Wait for last operation to be completed */
1324 status = FLASH_WaitForLastOperation();
1326 return status;
1330 * @brief Returns the FLASH User Option Bytes values.
1331 * @param None
1332 * @retval The FLASH User Option Bytes values: IWDG_SW(Bit0), RST_STOP(Bit1)
1333 * and RST_STDBY(Bit2).
1335 uint8_t FLASH_OB_GetUser(void)
1337 /* Return the User Option Byte */
1338 return (uint8_t)(FLASH->OPTCR >> 5);
1342 * @brief Returns the FLASH Write Protection Option Bytes value.
1343 * @param None
1344 * @retval The FLASH Write Protection Option Bytes value
1346 uint16_t FLASH_OB_GetWRP(void)
1348 /* Return the FLASH write protection Register value */
1349 return (*(__IO uint16_t *)(OPTCR_BYTE2_ADDRESS));
1353 * @brief Returns the FLASH Write Protection Option Bytes value.
1355 * @note This function can be used only for STM32F42xxx/43xxx devices.
1357 * @param None
1358 * @retval The FLASH Write Protection Option Bytes value
1360 uint16_t FLASH_OB_GetWRP1(void)
1362 /* Return the FLASH write protection Register value */
1363 return (*(__IO uint16_t *)(OPTCR1_BYTE2_ADDRESS));
1367 * @brief Returns the FLASH PC Read/Write Protection Option Bytes value.
1369 * @note This function can be used only for STM32F42xxx/43xxx devices and STM32F401xx/411xE devices.
1371 * @param None
1372 * @retval The FLASH PC Read/Write Protection Option Bytes value
1374 uint16_t FLASH_OB_GetPCROP(void)
1376 /* Return the FLASH PC Read/write protection Register value */
1377 return (*(__IO uint16_t *)(OPTCR_BYTE2_ADDRESS));
1381 * @brief Returns the FLASH PC Read/Write Protection Option Bytes value.
1383 * @note This function can be used only for STM32F42xxx/43xxx devices.
1385 * @param None
1386 * @retval The FLASH PC Read/Write Protection Option Bytes value
1388 uint16_t FLASH_OB_GetPCROP1(void)
1390 /* Return the FLASH write protection Register value */
1391 return (*(__IO uint16_t *)(OPTCR1_BYTE2_ADDRESS));
1395 * @brief Returns the FLASH Read Protection level.
1396 * @param None
1397 * @retval FLASH ReadOut Protection Status:
1398 * - SET, when OB_RDP_Level_1 or OB_RDP_Level_2 is set
1399 * - RESET, when OB_RDP_Level_0 is set
1401 FlagStatus FLASH_OB_GetRDP(void)
1403 FlagStatus readstatus = RESET;
1405 if ((*(__IO uint8_t*)(OPTCR_BYTE1_ADDRESS) != (uint8_t)OB_RDP_Level_0))
1407 readstatus = SET;
1409 else
1411 readstatus = RESET;
1413 return readstatus;
1417 * @brief Returns the FLASH BOR level.
1418 * @param None
1419 * @retval The FLASH BOR level:
1420 * - OB_BOR_LEVEL3: Supply voltage ranges from 2.7 to 3.6 V
1421 * - OB_BOR_LEVEL2: Supply voltage ranges from 2.4 to 2.7 V
1422 * - OB_BOR_LEVEL1: Supply voltage ranges from 2.1 to 2.4 V
1423 * - OB_BOR_OFF : Supply voltage ranges from 1.62 to 2.1 V
1425 uint8_t FLASH_OB_GetBOR(void)
1427 /* Return the FLASH BOR level */
1428 return (uint8_t)(*(__IO uint8_t *)(OPTCR_BYTE0_ADDRESS) & (uint8_t)0x0C);
1432 * @}
1435 /** @defgroup FLASH_Group4 Interrupts and flags management functions
1436 * @brief Interrupts and flags management functions
1438 @verbatim
1439 ===============================================================================
1440 ##### Interrupts and flags management functions #####
1441 ===============================================================================
1442 @endverbatim
1443 * @{
1447 * @brief Enables or disables the specified FLASH interrupts.
1448 * @param FLASH_IT: specifies the FLASH interrupt sources to be enabled or disabled.
1449 * This parameter can be any combination of the following values:
1450 * @arg FLASH_IT_ERR: FLASH Error Interrupt
1451 * @arg FLASH_IT_EOP: FLASH end of operation Interrupt
1452 * @retval None
1454 void FLASH_ITConfig(uint32_t FLASH_IT, FunctionalState NewState)
1456 /* Check the parameters */
1457 assert_param(IS_FLASH_IT(FLASH_IT));
1458 assert_param(IS_FUNCTIONAL_STATE(NewState));
1460 if(NewState != DISABLE)
1462 /* Enable the interrupt sources */
1463 FLASH->CR |= FLASH_IT;
1465 else
1467 /* Disable the interrupt sources */
1468 FLASH->CR &= ~(uint32_t)FLASH_IT;
1473 * @brief Checks whether the specified FLASH flag is set or not.
1474 * @param FLASH_FLAG: specifies the FLASH flag to check.
1475 * This parameter can be one of the following values:
1476 * @arg FLASH_FLAG_EOP: FLASH End of Operation flag
1477 * @arg FLASH_FLAG_OPERR: FLASH operation Error flag
1478 * @arg FLASH_FLAG_WRPERR: FLASH Write protected error flag
1479 * @arg FLASH_FLAG_PGAERR: FLASH Programming Alignment error flag
1480 * @arg FLASH_FLAG_PGPERR: FLASH Programming Parallelism error flag
1481 * @arg FLASH_FLAG_PGSERR: FLASH Programming Sequence error flag
1482 * @arg FLASH_FLAG_RDERR: FLASH (PCROP) Read Protection error flag (STM32F42xx/43xxx and STM32F401xx/411xE devices)
1483 * @arg FLASH_FLAG_BSY: FLASH Busy flag
1484 * @retval The new state of FLASH_FLAG (SET or RESET).
1486 FlagStatus FLASH_GetFlagStatus(uint32_t FLASH_FLAG)
1488 FlagStatus bitstatus = RESET;
1489 /* Check the parameters */
1490 assert_param(IS_FLASH_GET_FLAG(FLASH_FLAG));
1492 if((FLASH->SR & FLASH_FLAG) != (uint32_t)RESET)
1494 bitstatus = SET;
1496 else
1498 bitstatus = RESET;
1500 /* Return the new state of FLASH_FLAG (SET or RESET) */
1501 return bitstatus;
1505 * @brief Clears the FLASH's pending flags.
1506 * @param FLASH_FLAG: specifies the FLASH flags to clear.
1507 * This parameter can be any combination of the following values:
1508 * @arg FLASH_FLAG_EOP: FLASH End of Operation flag
1509 * @arg FLASH_FLAG_OPERR: FLASH operation Error flag
1510 * @arg FLASH_FLAG_WRPERR: FLASH Write protected error flag
1511 * @arg FLASH_FLAG_PGAERR: FLASH Programming Alignment error flag
1512 * @arg FLASH_FLAG_PGPERR: FLASH Programming Parallelism error flag
1513 * @arg FLASH_FLAG_PGSERR: FLASH Programming Sequence error flag
1514 * @arg FLASH_FLAG_RDERR: FLASH Read Protection error flag (STM32F42xx/43xxx and STM32F401xx/411xE devices)
1515 * @retval None
1517 void FLASH_ClearFlag(uint32_t FLASH_FLAG)
1519 /* Check the parameters */
1520 assert_param(IS_FLASH_CLEAR_FLAG(FLASH_FLAG));
1522 /* Clear the flags */
1523 FLASH->SR = FLASH_FLAG;
1527 * @brief Returns the FLASH Status.
1528 * @param None
1529 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
1530 * FLASH_ERROR_WRP, FLASH_ERROR_RD, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
1532 FLASH_Status FLASH_GetStatus(void)
1534 FLASH_Status flashstatus = FLASH_COMPLETE;
1536 if((FLASH->SR & FLASH_FLAG_BSY) == FLASH_FLAG_BSY)
1538 flashstatus = FLASH_BUSY;
1540 else
1542 if((FLASH->SR & FLASH_FLAG_WRPERR) != (uint32_t)0x00)
1544 flashstatus = FLASH_ERROR_WRP;
1546 else
1548 if((FLASH->SR & FLASH_FLAG_RDERR) != (uint32_t)0x00)
1550 flashstatus = FLASH_ERROR_RD;
1552 else
1554 if((FLASH->SR & (uint32_t)0xE0) != (uint32_t)0x00)
1556 flashstatus = FLASH_ERROR_PROGRAM;
1558 else
1560 if((FLASH->SR & FLASH_FLAG_OPERR) != (uint32_t)0x00)
1562 flashstatus = FLASH_ERROR_OPERATION;
1564 else
1566 flashstatus = FLASH_COMPLETE;
1572 /* Return the FLASH Status */
1573 return flashstatus;
1577 * @brief Waits for a FLASH operation to complete.
1578 * @param None
1579 * @retval FLASH Status: The returned value can be: FLASH_BUSY, FLASH_ERROR_PROGRAM,
1580 * FLASH_ERROR_WRP, FLASH_ERROR_OPERATION or FLASH_COMPLETE.
1582 FLASH_Status FLASH_WaitForLastOperation(void)
1584 __IO FLASH_Status status = FLASH_COMPLETE;
1586 /* Check for the FLASH Status */
1587 status = FLASH_GetStatus();
1589 /* Wait for the FLASH operation to complete by polling on BUSY flag to be reset.
1590 Even if the FLASH operation fails, the BUSY flag will be reset and an error
1591 flag will be set */
1592 while(status == FLASH_BUSY)
1594 status = FLASH_GetStatus();
1596 /* Return the operation status */
1597 return status;
1601 * @}
1605 * @}
1609 * @}
1613 * @}
1616 /************************ (C) COPYRIGHT STMicroelectronics *****END OF FILE****/