24 #ifndef __STM32F10x_FLASH_H 25 #define __STM32F10x_FLASH_H 71 #define FLASH_Latency_0 ((uint32_t)0x00000000) 72 #define FLASH_Latency_1 ((uint32_t)0x00000001) 73 #define FLASH_Latency_2 ((uint32_t)0x00000002) 74 #define IS_FLASH_LATENCY(LATENCY) (((LATENCY) == FLASH_Latency_0) || \ 75 ((LATENCY) == FLASH_Latency_1) || \ 76 ((LATENCY) == FLASH_Latency_2)) 85 #define FLASH_HalfCycleAccess_Enable ((uint32_t)0x00000008) 86 #define FLASH_HalfCycleAccess_Disable ((uint32_t)0x00000000) 87 #define IS_FLASH_HALFCYCLEACCESS_STATE(STATE) (((STATE) == FLASH_HalfCycleAccess_Enable) || \ 88 ((STATE) == FLASH_HalfCycleAccess_Disable)) 97 #define FLASH_PrefetchBuffer_Enable ((uint32_t)0x00000010) 98 #define FLASH_PrefetchBuffer_Disable ((uint32_t)0x00000000) 99 #define IS_FLASH_PREFETCHBUFFER_STATE(STATE) (((STATE) == FLASH_PrefetchBuffer_Enable) || \ 100 ((STATE) == FLASH_PrefetchBuffer_Disable)) 110 #define FLASH_WRProt_Pages0to3 ((uint32_t)0x00000001) 111 #define FLASH_WRProt_Pages4to7 ((uint32_t)0x00000002) 112 #define FLASH_WRProt_Pages8to11 ((uint32_t)0x00000004) 113 #define FLASH_WRProt_Pages12to15 ((uint32_t)0x00000008) 114 #define FLASH_WRProt_Pages16to19 ((uint32_t)0x00000010) 115 #define FLASH_WRProt_Pages20to23 ((uint32_t)0x00000020) 116 #define FLASH_WRProt_Pages24to27 ((uint32_t)0x00000040) 117 #define FLASH_WRProt_Pages28to31 ((uint32_t)0x00000080) 120 #define FLASH_WRProt_Pages32to35 ((uint32_t)0x00000100) 121 #define FLASH_WRProt_Pages36to39 ((uint32_t)0x00000200) 122 #define FLASH_WRProt_Pages40to43 ((uint32_t)0x00000400) 123 #define FLASH_WRProt_Pages44to47 ((uint32_t)0x00000800) 124 #define FLASH_WRProt_Pages48to51 ((uint32_t)0x00001000) 125 #define FLASH_WRProt_Pages52to55 ((uint32_t)0x00002000) 126 #define FLASH_WRProt_Pages56to59 ((uint32_t)0x00004000) 127 #define FLASH_WRProt_Pages60to63 ((uint32_t)0x00008000) 128 #define FLASH_WRProt_Pages64to67 ((uint32_t)0x00010000) 129 #define FLASH_WRProt_Pages68to71 ((uint32_t)0x00020000) 130 #define FLASH_WRProt_Pages72to75 ((uint32_t)0x00040000) 131 #define FLASH_WRProt_Pages76to79 ((uint32_t)0x00080000) 132 #define FLASH_WRProt_Pages80to83 ((uint32_t)0x00100000) 133 #define FLASH_WRProt_Pages84to87 ((uint32_t)0x00200000) 134 #define FLASH_WRProt_Pages88to91 ((uint32_t)0x00400000) 135 #define FLASH_WRProt_Pages92to95 ((uint32_t)0x00800000) 136 #define FLASH_WRProt_Pages96to99 ((uint32_t)0x01000000) 137 #define FLASH_WRProt_Pages100to103 ((uint32_t)0x02000000) 138 #define FLASH_WRProt_Pages104to107 ((uint32_t)0x04000000) 139 #define FLASH_WRProt_Pages108to111 ((uint32_t)0x08000000) 140 #define FLASH_WRProt_Pages112to115 ((uint32_t)0x10000000) 141 #define FLASH_WRProt_Pages116to119 ((uint32_t)0x20000000) 142 #define FLASH_WRProt_Pages120to123 ((uint32_t)0x40000000) 143 #define FLASH_WRProt_Pages124to127 ((uint32_t)0x80000000) 146 #define FLASH_WRProt_Pages0to1 ((uint32_t)0x00000001) 148 #define FLASH_WRProt_Pages2to3 ((uint32_t)0x00000002) 150 #define FLASH_WRProt_Pages4to5 ((uint32_t)0x00000004) 152 #define FLASH_WRProt_Pages6to7 ((uint32_t)0x00000008) 154 #define FLASH_WRProt_Pages8to9 ((uint32_t)0x00000010) 156 #define FLASH_WRProt_Pages10to11 ((uint32_t)0x00000020) 158 #define FLASH_WRProt_Pages12to13 ((uint32_t)0x00000040) 160 #define FLASH_WRProt_Pages14to15 ((uint32_t)0x00000080) 162 #define FLASH_WRProt_Pages16to17 ((uint32_t)0x00000100) 164 #define FLASH_WRProt_Pages18to19 ((uint32_t)0x00000200) 166 #define FLASH_WRProt_Pages20to21 ((uint32_t)0x00000400) 168 #define FLASH_WRProt_Pages22to23 ((uint32_t)0x00000800) 170 #define FLASH_WRProt_Pages24to25 ((uint32_t)0x00001000) 172 #define FLASH_WRProt_Pages26to27 ((uint32_t)0x00002000) 174 #define FLASH_WRProt_Pages28to29 ((uint32_t)0x00004000) 176 #define FLASH_WRProt_Pages30to31 ((uint32_t)0x00008000) 178 #define FLASH_WRProt_Pages32to33 ((uint32_t)0x00010000) 180 #define FLASH_WRProt_Pages34to35 ((uint32_t)0x00020000) 182 #define FLASH_WRProt_Pages36to37 ((uint32_t)0x00040000) 184 #define FLASH_WRProt_Pages38to39 ((uint32_t)0x00080000) 186 #define FLASH_WRProt_Pages40to41 ((uint32_t)0x00100000) 188 #define FLASH_WRProt_Pages42to43 ((uint32_t)0x00200000) 190 #define FLASH_WRProt_Pages44to45 ((uint32_t)0x00400000) 192 #define FLASH_WRProt_Pages46to47 ((uint32_t)0x00800000) 194 #define FLASH_WRProt_Pages48to49 ((uint32_t)0x01000000) 196 #define FLASH_WRProt_Pages50to51 ((uint32_t)0x02000000) 198 #define FLASH_WRProt_Pages52to53 ((uint32_t)0x04000000) 200 #define FLASH_WRProt_Pages54to55 ((uint32_t)0x08000000) 202 #define FLASH_WRProt_Pages56to57 ((uint32_t)0x10000000) 204 #define FLASH_WRProt_Pages58to59 ((uint32_t)0x20000000) 206 #define FLASH_WRProt_Pages60to61 ((uint32_t)0x40000000) 208 #define FLASH_WRProt_Pages62to127 ((uint32_t)0x80000000) 209 #define FLASH_WRProt_Pages62to255 ((uint32_t)0x80000000) 210 #define FLASH_WRProt_Pages62to511 ((uint32_t)0x80000000) 212 #define FLASH_WRProt_AllPages ((uint32_t)0xFFFFFFFF) 214 #define IS_FLASH_WRPROT_PAGE(PAGE) (((PAGE) != 0x00000000)) 216 #define IS_FLASH_ADDRESS(ADDRESS) (((ADDRESS) >= 0x08000000) && ((ADDRESS) < 0x080FFFFF)) 218 #define IS_OB_DATA_ADDRESS(ADDRESS) (((ADDRESS) == 0x1FFFF804) || ((ADDRESS) == 0x1FFFF806)) 228 #define OB_IWDG_SW ((uint16_t)0x0001) 229 #define OB_IWDG_HW ((uint16_t)0x0000) 230 #define IS_OB_IWDG_SOURCE(SOURCE) (((SOURCE) == OB_IWDG_SW) || ((SOURCE) == OB_IWDG_HW)) 240 #define OB_STOP_NoRST ((uint16_t)0x0002) 241 #define OB_STOP_RST ((uint16_t)0x0000) 242 #define IS_OB_STOP_SOURCE(SOURCE) (((SOURCE) == OB_STOP_NoRST) || ((SOURCE) == OB_STOP_RST)) 252 #define OB_STDBY_NoRST ((uint16_t)0x0004) 253 #define OB_STDBY_RST ((uint16_t)0x0000) 254 #define IS_OB_STDBY_SOURCE(SOURCE) (((SOURCE) == OB_STDBY_NoRST) || ((SOURCE) == OB_STDBY_RST)) 263 #define FLASH_BOOT_Bank1 ((uint16_t)0x0000) 265 #define FLASH_BOOT_Bank2 ((uint16_t)0x0001) 268 #define IS_FLASH_BOOT(BOOT) (((BOOT) == FLASH_BOOT_Bank1) || ((BOOT) == FLASH_BOOT_Bank2)) 277 #define FLASH_IT_BANK2_ERROR ((uint32_t)0x80000400) 278 #define FLASH_IT_BANK2_EOP ((uint32_t)0x80001000) 280 #define FLASH_IT_BANK1_ERROR FLASH_IT_ERROR 281 #define FLASH_IT_BANK1_EOP FLASH_IT_EOP 283 #define FLASH_IT_ERROR ((uint32_t)0x00000400) 284 #define FLASH_IT_EOP ((uint32_t)0x00001000) 285 #define IS_FLASH_IT(IT) ((((IT) & (uint32_t)0x7FFFEBFF) == 0x00000000) && (((IT) != 0x00000000))) 287 #define FLASH_IT_ERROR ((uint32_t)0x00000400) 288 #define FLASH_IT_EOP ((uint32_t)0x00001000) 289 #define FLASH_IT_BANK1_ERROR FLASH_IT_ERROR 290 #define FLASH_IT_BANK1_EOP FLASH_IT_EOP 292 #define IS_FLASH_IT(IT) ((((IT) & (uint32_t)0xFFFFEBFF) == 0x00000000) && (((IT) != 0x00000000))) 303 #define FLASH_FLAG_BANK2_BSY ((uint32_t)0x80000001) 304 #define FLASH_FLAG_BANK2_EOP ((uint32_t)0x80000020) 305 #define FLASH_FLAG_BANK2_PGERR ((uint32_t)0x80000004) 306 #define FLASH_FLAG_BANK2_WRPRTERR ((uint32_t)0x80000010) 308 #define FLASH_FLAG_BANK1_BSY FLASH_FLAG_BSY 309 #define FLASH_FLAG_BANK1_EOP FLASH_FLAG_EOP 310 #define FLASH_FLAG_BANK1_PGERR FLASH_FLAG_PGERR 311 #define FLASH_FLAG_BANK1_WRPRTERR FLASH_FLAG_WRPRTERR 313 #define FLASH_FLAG_BSY ((uint32_t)0x00000001) 314 #define FLASH_FLAG_EOP ((uint32_t)0x00000020) 315 #define FLASH_FLAG_PGERR ((uint32_t)0x00000004) 316 #define FLASH_FLAG_WRPRTERR ((uint32_t)0x00000010) 317 #define FLASH_FLAG_OPTERR ((uint32_t)0x00000001) 319 #define IS_FLASH_CLEAR_FLAG(FLAG) ((((FLAG) & (uint32_t)0x7FFFFFCA) == 0x00000000) && ((FLAG) != 0x00000000)) 320 #define IS_FLASH_GET_FLAG(FLAG) (((FLAG) == FLASH_FLAG_BSY) || ((FLAG) == FLASH_FLAG_EOP) || \ 321 ((FLAG) == FLASH_FLAG_PGERR) || ((FLAG) == FLASH_FLAG_WRPRTERR) || \ 322 ((FLAG) == FLASH_FLAG_OPTERR)|| \ 323 ((FLAG) == FLASH_FLAG_BANK1_BSY) || ((FLAG) == FLASH_FLAG_BANK1_EOP) || \ 324 ((FLAG) == FLASH_FLAG_BANK1_PGERR) || ((FLAG) == FLASH_FLAG_BANK1_WRPRTERR) || \ 325 ((FLAG) == FLASH_FLAG_BANK2_BSY) || ((FLAG) == FLASH_FLAG_BANK2_EOP) || \ 326 ((FLAG) == FLASH_FLAG_BANK2_PGERR) || ((FLAG) == FLASH_FLAG_BANK2_WRPRTERR)) 328 #define FLASH_FLAG_BSY ((uint32_t)0x00000001) 329 #define FLASH_FLAG_EOP ((uint32_t)0x00000020) 330 #define FLASH_FLAG_PGERR ((uint32_t)0x00000004) 331 #define FLASH_FLAG_WRPRTERR ((uint32_t)0x00000010) 332 #define FLASH_FLAG_OPTERR ((uint32_t)0x00000001) 334 #define FLASH_FLAG_BANK1_BSY FLASH_FLAG_BSY 335 #define FLASH_FLAG_BANK1_EOP FLASH_FLAG_EOP 336 #define FLASH_FLAG_BANK1_PGERR FLASH_FLAG_PGERR 337 #define FLASH_FLAG_BANK1_WRPRTERR FLASH_FLAG_WRPRTERR 339 #define IS_FLASH_CLEAR_FLAG(FLAG) ((((FLAG) & (uint32_t)0xFFFFFFCA) == 0x00000000) && ((FLAG) != 0x00000000)) 340 #define IS_FLASH_GET_FLAG(FLAG) (((FLAG) == FLASH_FLAG_BSY) || ((FLAG) == FLASH_FLAG_EOP) || \ 341 ((FLAG) == FLASH_FLAG_PGERR) || ((FLAG) == FLASH_FLAG_WRPRTERR) || \ 342 ((FLAG) == FLASH_FLAG_BANK1_BSY) || ((FLAG) == FLASH_FLAG_BANK1_EOP) || \ 343 ((FLAG) == FLASH_FLAG_BANK1_PGERR) || ((FLAG) == FLASH_FLAG_BANK1_WRPRTERR) || \ 344 ((FLAG) == FLASH_FLAG_OPTERR)) 401 void FLASH_UnlockBank2(
void);
402 void FLASH_LockBank2(
void);
403 FLASH_Status FLASH_EraseAllBank2Pages(
void);
404 FLASH_Status FLASH_GetBank2Status(
void);
405 FLASH_Status FLASH_WaitForLastBank2Operation(uint32_t Timeout);
406 FLASH_Status FLASH_BootConfig(uint16_t FLASH_BOOT);
FLASH_Status
FLASH Status.
FLASH_Status FLASH_EraseAllPages(void)
Erases all FLASH pages.
void FLASH_ITConfig(uint32_t FLASH_IT, FunctionalState NewState)
Enables or disables the specified FLASH interrupts.
void FLASH_Lock(void)
Locks the FLASH control register access.
FLASH_Status FLASH_ProgramHalfWord(uint32_t Address, uint16_t Data)
Programs a half word (16-bit) at a specified address.
FLASH_Status FLASH_ProgramOptionByteData(uint32_t Address, uint8_t Data)
Programs a half word at a specified Option Byte Data address.
FLASH_Status FLASH_WaitForLastOperation(uint32_t Timeout)
Waits for a Flash operation to complete or a TIMEOUT to occur.
FlagStatus FLASH_GetPrefetchBufferStatus(void)
Checks whether the FLASH Prefetch Buffer status is set or not.
void FLASH_PrefetchBufferCmd(uint32_t FLASH_PrefetchBuffer)
Enables or disables the Prefetch Buffer.
FLASH_Status FLASH_EraseOptionBytes(void)
Erases the FLASH option bytes.
FLASH_Status FLASH_UserOptionByteConfig(uint16_t OB_IWDG, uint16_t OB_STOP, uint16_t OB_STDBY)
Programs the FLASH User Option Byte: IWDG_SW / RST_STOP / RST_STDBY.
void FLASH_UnlockBank1(void)
Unlocks the FLASH Bank1 Program Erase Controller.
void FLASH_ClearFlag(uint32_t FLASH_FLAG)
Clears the FLASH's pending flags.
FLASH_Status FLASH_GetBank1Status(void)
Returns the FLASH Bank1 Status.
FlagStatus FLASH_GetReadOutProtectionStatus(void)
Checks whether the FLASH Read Out Protection Status is set or not.
FLASH_Status FLASH_GetStatus(void)
Returns the FLASH Status.
FLASH_Status FLASH_EnableWriteProtection(uint32_t FLASH_Pages)
Write protects the desired pages.
uint32_t FLASH_GetUserOptionByte(void)
Returns the FLASH User Option Bytes values.
FLASH_Status FLASH_EraseAllBank1Pages(void)
Erases all Bank1 FLASH pages.
FLASH_Status FLASH_ErasePage(uint32_t Page_Address)
Erases a specified FLASH page.
void FLASH_Unlock(void)
Unlocks the FLASH control register access.
void FLASH_HalfCycleAccessCmd(uint32_t FLASH_HalfCycleAccess)
Enables or disables the Half cycle flash access.
CMSIS Cortex-M3 Device Peripheral Access Layer Header File. This file contains all the peripheral reg...
void FLASH_LockBank1(void)
Locks the FLASH Bank1 Program Erase Controller.
FlagStatus FLASH_GetFlagStatus(uint32_t FLASH_FLAG)
Checks whether the specified FLASH flag is set or not.
FLASH_Status FLASH_ReadOutProtection(FunctionalState NewState)
Enables or disables the read out protection.
FLASH_Status FLASH_WaitForLastBank1Operation(uint32_t Timeout)
Waits for a Flash operation on Bank1 to complete or a TIMEOUT to occur.
FLASH_Status FLASH_ProgramWord(uint32_t Address, uint32_t Data)
Programs a word (32-bit) at a specified address.
uint32_t FLASH_GetWriteProtectionOptionByte(void)
Returns the FLASH Write Protection Option Bytes Register value.
void FLASH_SetLatency(uint32_t FLASH_Latency)
Sets the code latency value.