21#ifndef STM32H7xx_HAL_FLASH_EX_H
22#define STM32H7xx_HAL_FLASH_EX_H
61 uint32_t VoltageRange;
64} FLASH_EraseInitTypeDef;
114#if defined(DUAL_CORE)
136#if defined (FLASH_OTPBL_LOCKBL)
141#if defined (FLASH_OPTSR2_TCM_AXI_SHARED)
146#if defined (FLASH_OPTSR2_CPUFREQ_BOOST)
193#define FLASH_TYPEERASE_SECTORS 0x00U
194#define FLASH_TYPEERASE_MASSERASE 0x01U
199#if defined (FLASH_CR_PSIZE)
203#define FLASH_VOLTAGE_RANGE_1 0x00000000U
204#define FLASH_VOLTAGE_RANGE_2 FLASH_CR_PSIZE_0
205#define FLASH_VOLTAGE_RANGE_3 FLASH_CR_PSIZE_1
206#define FLASH_VOLTAGE_RANGE_4 FLASH_CR_PSIZE
215#define OB_WRPSTATE_DISABLE 0x00000000U
216#define OB_WRPSTATE_ENABLE 0x00000001U
224#define OPTIONBYTE_WRP 0x01U
225#define OPTIONBYTE_RDP 0x02U
226#define OPTIONBYTE_USER 0x04U
227#define OPTIONBYTE_PCROP 0x08U
228#define OPTIONBYTE_BOR 0x10U
229#define OPTIONBYTE_SECURE_AREA 0x20U
230#if defined (DUAL_CORE)
231#define OPTIONBYTE_CM7_BOOTADD 0x40U
232#define OPTIONBYTE_CM4_BOOTADD 0x80U
233#define OPTIONBYTE_BOOTADD OPTIONBYTE_CM7_BOOTADD
235#define OPTIONBYTE_BOOTADD 0x40U
237#if defined (FLASH_OTPBL_LOCKBL)
238#define OPTIONBYTE_OTP_LOCK 0x80U
240#if defined (FLASH_OPTSR2_TCM_AXI_SHARED)
241#define OPTIONBYTE_SHARED_RAM 0x100U
243#if defined (FLASH_OPTSR2_CPUFREQ_BOOST)
244#define OPTIONBYTE_FREQ_BOOST 0x200U
247#if defined (DUAL_CORE)
248#define OPTIONBYTE_ALL (OPTIONBYTE_WRP | OPTIONBYTE_RDP | OPTIONBYTE_USER |\
249 OPTIONBYTE_PCROP | OPTIONBYTE_BOR | OPTIONBYTE_SECURE_AREA |\
250 OPTIONBYTE_CM7_BOOTADD | OPTIONBYTE_CM4_BOOTADD)
251#elif defined (FLASH_OTPBL_LOCKBL)
252#define OPTIONBYTE_ALL (OPTIONBYTE_WRP | OPTIONBYTE_RDP | OPTIONBYTE_USER |\
253 OPTIONBYTE_PCROP | OPTIONBYTE_BOR | OPTIONBYTE_SECURE_AREA |\
254 OPTIONBYTE_BOOTADD | OPTIONBYTE_OTP_LOCK)
255#elif defined (FLASH_OPTSR2_TCM_AXI_SHARED)
256#define OPTIONBYTE_ALL (OPTIONBYTE_WRP | OPTIONBYTE_RDP | OPTIONBYTE_USER |\
257 OPTIONBYTE_PCROP | OPTIONBYTE_BOR | OPTIONBYTE_SECURE_AREA |\
258 OPTIONBYTE_BOOTADD | OPTIONBYTE_SHARED_RAM | OPTIONBYTE_FREQ_BOOST)
260#define OPTIONBYTE_ALL (OPTIONBYTE_WRP | OPTIONBYTE_RDP | OPTIONBYTE_USER |\
261 OPTIONBYTE_PCROP | OPTIONBYTE_BOR | OPTIONBYTE_SECURE_AREA |\
271#define OB_RDP_LEVEL_0 0xAA00U
272#define OB_RDP_LEVEL_1 0x5500U
273#define OB_RDP_LEVEL_2 0xCC00U
282#define OB_WWDG_SW 0x10U
283#define OB_WWDG_HW 0x00U
292#define OB_IWDG_SW OB_IWDG1_SW
293#define OB_IWDG_HW OB_IWDG1_HW
301#define OB_STOP_NO_RST 0x40U
302#define OB_STOP_RST 0x00U
310#define OB_STDBY_NO_RST 0x80U
311#define OB_STDBY_RST 0x00U
319#define OB_IWDG_STOP_FREEZE 0x00000000U
320#define OB_IWDG_STOP_ACTIVE FLASH_OPTSR_FZ_IWDG_STOP
328#define OB_IWDG_STDBY_FREEZE 0x00000000U
329#define OB_IWDG_STDBY_ACTIVE FLASH_OPTSR_FZ_IWDG_SDBY
337#define OB_BOR_LEVEL0 0x00000000U
338#define OB_BOR_LEVEL1 FLASH_OPTSR_BOR_LEV_0
339#define OB_BOR_LEVEL2 FLASH_OPTSR_BOR_LEV_1
340#define OB_BOR_LEVEL3 (FLASH_OPTSR_BOR_LEV_1 | FLASH_OPTSR_BOR_LEV_0)
342#define OB_BOR_OFF OB_BOR_LEVEL0
352#define OB_BOOTADDR_ITCM_RAM 0x0000U
353#define OB_BOOTADDR_SYSTEM 0x0040U
354#define OB_BOOTADDR_ITCM_FLASH 0x0080U
355#define OB_BOOTADDR_AXIM_FLASH 0x2000U
356#define OB_BOOTADDR_DTCM_RAM 0x8000U
357#define OB_BOOTADDR_SRAM1 0x8004U
358#define OB_BOOTADDR_SRAM2 0x8013U
366#define FLASH_LATENCY_0 FLASH_ACR_LATENCY_0WS
367#define FLASH_LATENCY_1 FLASH_ACR_LATENCY_1WS
368#define FLASH_LATENCY_2 FLASH_ACR_LATENCY_2WS
369#define FLASH_LATENCY_3 FLASH_ACR_LATENCY_3WS
370#define FLASH_LATENCY_4 FLASH_ACR_LATENCY_4WS
371#define FLASH_LATENCY_5 FLASH_ACR_LATENCY_5WS
372#define FLASH_LATENCY_6 FLASH_ACR_LATENCY_6WS
373#define FLASH_LATENCY_7 FLASH_ACR_LATENCY_7WS
374#define FLASH_LATENCY_8 FLASH_ACR_LATENCY_8WS
375#define FLASH_LATENCY_9 FLASH_ACR_LATENCY_9WS
376#define FLASH_LATENCY_10 FLASH_ACR_LATENCY_10WS
377#define FLASH_LATENCY_11 FLASH_ACR_LATENCY_11WS
378#define FLASH_LATENCY_12 FLASH_ACR_LATENCY_12WS
379#define FLASH_LATENCY_13 FLASH_ACR_LATENCY_13WS
380#define FLASH_LATENCY_14 FLASH_ACR_LATENCY_14WS
381#define FLASH_LATENCY_15 FLASH_ACR_LATENCY_15WS
389#define FLASH_BANK_1 0x01U
390#if defined (DUAL_BANK)
391#define FLASH_BANK_2 0x02U
392#define FLASH_BANK_BOTH (FLASH_BANK_1 | FLASH_BANK_2)
401#define OB_PCROP_RDP_NOT_ERASE 0x00000000U
403#define OB_PCROP_RDP_ERASE FLASH_PRAR_DMEP
413#if (FLASH_SECTOR_TOTAL == 128)
414#define OB_WRP_SECTOR_0TO3 0x00000001U
415#define OB_WRP_SECTOR_4TO7 0x00000002U
416#define OB_WRP_SECTOR_8TO11 0x00000004U
417#define OB_WRP_SECTOR_12TO15 0x00000008U
418#define OB_WRP_SECTOR_16TO19 0x00000010U
419#define OB_WRP_SECTOR_20TO23 0x00000020U
420#define OB_WRP_SECTOR_24TO27 0x00000040U
421#define OB_WRP_SECTOR_28TO31 0x00000080U
422#define OB_WRP_SECTOR_32TO35 0x00000100U
423#define OB_WRP_SECTOR_36TO39 0x00000200U
424#define OB_WRP_SECTOR_40TO43 0x00000400U
425#define OB_WRP_SECTOR_44TO47 0x00000800U
426#define OB_WRP_SECTOR_48TO51 0x00001000U
427#define OB_WRP_SECTOR_52TO55 0x00002000U
428#define OB_WRP_SECTOR_56TO59 0x00004000U
429#define OB_WRP_SECTOR_60TO63 0x00008000U
430#define OB_WRP_SECTOR_64TO67 0x00010000U
431#define OB_WRP_SECTOR_68TO71 0x00020000U
432#define OB_WRP_SECTOR_72TO75 0x00040000U
433#define OB_WRP_SECTOR_76TO79 0x00080000U
434#define OB_WRP_SECTOR_80TO83 0x00100000U
435#define OB_WRP_SECTOR_84TO87 0x00200000U
436#define OB_WRP_SECTOR_88TO91 0x00400000U
437#define OB_WRP_SECTOR_92TO95 0x00800000U
438#define OB_WRP_SECTOR_96TO99 0x01000000U
439#define OB_WRP_SECTOR_100TO103 0x02000000U
440#define OB_WRP_SECTOR_104TO107 0x04000000U
441#define OB_WRP_SECTOR_108TO111 0x08000000U
442#define OB_WRP_SECTOR_112TO115 0x10000000U
443#define OB_WRP_SECTOR_116TO119 0x20000000U
444#define OB_WRP_SECTOR_120TO123 0x40000000U
445#define OB_WRP_SECTOR_124TO127 0x80000000U
446#define OB_WRP_SECTOR_ALL 0xFFFFFFFFU
448#define OB_WRP_SECTOR_0 0x00000001U
449#define OB_WRP_SECTOR_1 0x00000002U
450#define OB_WRP_SECTOR_2 0x00000004U
451#define OB_WRP_SECTOR_3 0x00000008U
452#define OB_WRP_SECTOR_4 0x00000010U
453#define OB_WRP_SECTOR_5 0x00000020U
454#define OB_WRP_SECTOR_6 0x00000040U
455#define OB_WRP_SECTOR_7 0x00000080U
456#define OB_WRP_SECTOR_ALL 0x000000FFU
465#define OB_SECURITY_DISABLE 0x00000000U
466#define OB_SECURITY_ENABLE FLASH_OPTSR_SECURITY
474#define OB_ST_RAM_SIZE_2KB 0x00000000U
475#define OB_ST_RAM_SIZE_4KB FLASH_OPTSR_ST_RAM_SIZE_0
476#define OB_ST_RAM_SIZE_8KB FLASH_OPTSR_ST_RAM_SIZE_1
477#define OB_ST_RAM_SIZE_16KB FLASH_OPTSR_ST_RAM_SIZE
482#if defined(DUAL_CORE)
486#define OB_BCM7_DISABLE 0x00000000U
487#define OB_BCM7_ENABLE FLASH_OPTSR_BCM7
496#define OB_BCM4_DISABLE 0x00000000U
497#define OB_BCM4_ENABLE FLASH_OPTSR_BCM4
506#define OB_IWDG1_SW FLASH_OPTSR_IWDG1_SW
507#define OB_IWDG1_HW 0x00000000U
512#if defined(DUAL_CORE)
516#define OB_IWDG2_SW FLASH_OPTSR_IWDG2_SW
517#define OB_IWDG2_HW 0x00000000U
526#define OB_STOP_RST_D1 0x00000000U
527#define OB_STOP_NO_RST_D1 FLASH_OPTSR_NRST_STOP_D1
535#define OB_STDBY_RST_D1 0x00000000U
536#define OB_STDBY_NO_RST_D1 FLASH_OPTSR_NRST_STBY_D1
541#if defined (FLASH_OPTSR_NRST_STOP_D2)
545#define OB_STOP_RST_D2 0x00000000U
546#define OB_STOP_NO_RST_D2 FLASH_OPTSR_NRST_STOP_D2
554#define OB_STDBY_RST_D2 0x00000000U
555#define OB_STDBY_NO_RST_D2 FLASH_OPTSR_NRST_STBY_D2
564#define OB_SWAP_BANK_DISABLE 0x00000000U
565#define OB_SWAP_BANK_ENABLE FLASH_OPTSR_SWAP_BANK_OPT
573#define OB_IOHSLV_DISABLE 0x00000000U
574#define OB_IOHSLV_ENABLE FLASH_OPTSR_IO_HSLV
579#if defined (FLASH_OPTSR_VDDMMC_HSLV)
583#define OB_VDDMMC_HSLV_DISABLE 0x00000000U
584#define OB_VDDMMC_HSLV_ENABLE FLASH_OPTSR_VDDMMC_HSLV
590#if defined (FLASH_OPTSR2_CPUFREQ_BOOST)
594#define OB_CPUFREQ_BOOST_DISABLE 0x00000000U
595#define OB_CPUFREQ_BOOST_ENABLE FLASH_OPTSR2_CPUFREQ_BOOST
601#if defined (FLASH_OPTSR2_TCM_AXI_SHARED)
605#define OB_TCM_AXI_SHARED_ITCM64KB 0x00000000U
606#define OB_TCM_AXI_SHARED_ITCM128KB FLASH_OPTSR2_TCM_AXI_SHARED_0
607#define OB_TCM_AXI_SHARED_ITCM192KB FLASH_OPTSR2_TCM_AXI_SHARED_1
608#define OB_TCM_AXI_SHARED_ITCM256KB FLASH_OPTSR2_TCM_AXI_SHARED
617#define OB_USER_IWDG1_SW 0x0001U
618#define OB_USER_NRST_STOP_D1 0x0002U
619#define OB_USER_NRST_STDBY_D1 0x0004U
620#define OB_USER_IWDG_STOP 0x0008U
621#define OB_USER_IWDG_STDBY 0x0010U
622#define OB_USER_ST_RAM_SIZE 0x0020U
623#define OB_USER_SECURITY 0x0040U
624#define OB_USER_IOHSLV 0x0080U
625#if defined (DUAL_BANK)
626#define OB_USER_SWAP_BANK 0x0100U
628#if defined (FLASH_OPTSR_VDDMMC_HSLV)
629#define OB_USER_VDDMMC_HSLV 0x0200U
631#if defined (DUAL_CORE)
632#define OB_USER_IWDG2_SW 0x0200U
633#define OB_USER_BCM4 0x0400U
634#define OB_USER_BCM7 0x0800U
636#if defined (FLASH_OPTSR_NRST_STOP_D2)
637#define OB_USER_NRST_STOP_D2 0x1000U
638#define OB_USER_NRST_STDBY_D2 0x2000U
641#if defined (DUAL_CORE)
642#define OB_USER_ALL (OB_USER_IWDG1_SW | OB_USER_NRST_STOP_D1 | OB_USER_NRST_STDBY_D1 |\
643 OB_USER_IWDG_STOP | OB_USER_IWDG_STDBY | OB_USER_ST_RAM_SIZE |\
644 OB_USER_SECURITY | OB_USER_IOHSLV | OB_USER_SWAP_BANK |\
645 OB_USER_IWDG2_SW | OB_USER_BCM4 | OB_USER_BCM7 |\
646 OB_USER_NRST_STOP_D2 | OB_USER_NRST_STDBY_D2)
647#elif defined (FLASH_OPTSR_VDDMMC_HSLV)
648#define OB_USER_ALL (OB_USER_IWDG1_SW | OB_USER_NRST_STOP_D1 | OB_USER_NRST_STDBY_D1 |\
649 OB_USER_IWDG_STOP | OB_USER_IWDG_STDBY | OB_USER_ST_RAM_SIZE |\
650 OB_USER_SECURITY | OB_USER_IOHSLV | OB_USER_SWAP_BANK |\
652#elif defined (FLASH_OPTSR2_TCM_AXI_SHARED)
653#define OB_USER_ALL (OB_USER_IWDG1_SW | OB_USER_NRST_STOP_D1 | OB_USER_NRST_STDBY_D1 |\
654 OB_USER_IWDG_STOP | OB_USER_IWDG_STDBY | OB_USER_ST_RAM_SIZE |\
655 OB_USER_SECURITY | OB_USER_IOHSLV |\
656 OB_USER_NRST_STOP_D2 | OB_USER_NRST_STDBY_D2)
658#define OB_USER_ALL (OB_USER_IWDG1_SW | OB_USER_NRST_STOP_D1 | OB_USER_NRST_STDBY_D1 |\
659 OB_USER_IWDG_STOP | OB_USER_IWDG_STDBY | OB_USER_ST_RAM_SIZE |\
660 OB_USER_SECURITY | OB_USER_IOHSLV | OB_USER_SWAP_BANK )
669#define OB_BOOT_ADD0 0x01U
670#define OB_BOOT_ADD1 0x02U
671#define OB_BOOT_ADD_BOTH 0x03U
679#define OB_SECURE_RDP_NOT_ERASE 0x00000000U
681#define OB_SECURE_RDP_ERASE FLASH_SCAR_DMES
690#define FLASH_CRC_ADDR 0x00000000U
691#define FLASH_CRC_SECTORS FLASH_CRCCR_CRC_BY_SECT
692#define FLASH_CRC_BANK (FLASH_CRCCR_ALL_BANK | FLASH_CRCCR_CRC_BY_SECT)
700#define FLASH_CRC_BURST_SIZE_4 0x00000000U
701#define FLASH_CRC_BURST_SIZE_16 FLASH_CRCCR_CRC_BURST_0
702#define FLASH_CRC_BURST_SIZE_64 FLASH_CRCCR_CRC_BURST_1
703#define FLASH_CRC_BURST_SIZE_256 FLASH_CRCCR_CRC_BURST
711#define FLASH_PROGRAMMING_DELAY_0 0x00000000U
712#define FLASH_PROGRAMMING_DELAY_1 FLASH_ACR_WRHIGHFREQ_0
713#define FLASH_PROGRAMMING_DELAY_2 FLASH_ACR_WRHIGHFREQ_1
714#define FLASH_PROGRAMMING_DELAY_3 FLASH_ACR_WRHIGHFREQ
719#if defined (FLASH_OTPBL_LOCKBL)
723#define FLASH_OTP_BLOCK_0 0x00000001U
724#define FLASH_OTP_BLOCK_1 0x00000002U
725#define FLASH_OTP_BLOCK_2 0x00000004U
726#define FLASH_OTP_BLOCK_3 0x00000008U
727#define FLASH_OTP_BLOCK_4 0x00000010U
728#define FLASH_OTP_BLOCK_5 0x00000020U
729#define FLASH_OTP_BLOCK_6 0x00000040U
730#define FLASH_OTP_BLOCK_7 0x00000080U
731#define FLASH_OTP_BLOCK_8 0x00000100U
732#define FLASH_OTP_BLOCK_9 0x00000200U
733#define FLASH_OTP_BLOCK_10 0x00000400U
734#define FLASH_OTP_BLOCK_11 0x00000800U
735#define FLASH_OTP_BLOCK_12 0x00001000U
736#define FLASH_OTP_BLOCK_13 0x00002000U
737#define FLASH_OTP_BLOCK_14 0x00004000U
738#define FLASH_OTP_BLOCK_15 0x00008000U
739#define FLASH_OTP_BLOCK_ALL 0x0000FFFFU
755#define __HAL_FLASH_CALC_BOOT_BASE_ADR(__ADDRESS__) ((__ADDRESS__) >> 14U)
760#if defined (FLASH_CR_PSIZE)
768#if defined (DUAL_BANK)
769#define __HAL_FLASH_SET_PSIZE(__PSIZE__, __BANK__) (((__BANK__) == FLASH_BANK_1) ? \
770 MODIFY_REG(FLASH->CR1, FLASH_CR_PSIZE, (__PSIZE__)) : \
771 MODIFY_REG(FLASH->CR2, FLASH_CR_PSIZE, (__PSIZE__)))
773#define __HAL_FLASH_SET_PSIZE(__PSIZE__, __BANK__) MODIFY_REG(FLASH->CR1, FLASH_CR_PSIZE, (__PSIZE__))
782#if defined (DUAL_BANK)
783#define __HAL_FLASH_GET_PSIZE(__BANK__) (((__BANK__) == FLASH_BANK_1) ? \
784 READ_BIT((FLASH->CR1), FLASH_CR_PSIZE) : \
785 READ_BIT((FLASH->CR2), FLASH_CR_PSIZE))
787#define __HAL_FLASH_GET_PSIZE(__BANK__) READ_BIT((FLASH->CR1), FLASH_CR_PSIZE)
798#define __HAL_FLASH_SET_PROGRAM_DELAY(__DELAY__) MODIFY_REG(FLASH->ACR, FLASH_ACR_WRHIGHFREQ, (__DELAY__))
805#define __HAL_FLASH_GET_PROGRAM_DELAY() READ_BIT(FLASH->ACR, FLASH_ACR_WRHIGHFREQ)
816HAL_StatusTypeDef
HAL_FLASHEx_Erase(FLASH_EraseInitTypeDef *pEraseInit, uint32_t *SectorError);
823#if defined (DUAL_BANK)
849#define IS_FLASH_TYPEERASE(VALUE) (((VALUE) == FLASH_TYPEERASE_SECTORS) || \
850 ((VALUE) == FLASH_TYPEERASE_MASSERASE))
852#if defined (FLASH_CR_PSIZE)
853#define IS_VOLTAGERANGE(RANGE) (((RANGE) == FLASH_VOLTAGE_RANGE_1) || \
854 ((RANGE) == FLASH_VOLTAGE_RANGE_2) || \
855 ((RANGE) == FLASH_VOLTAGE_RANGE_3) || \
856 ((RANGE) == FLASH_VOLTAGE_RANGE_4))
859#define IS_WRPSTATE(VALUE) (((VALUE) == OB_WRPSTATE_DISABLE) || \
860 ((VALUE) == OB_WRPSTATE_ENABLE))
862#define IS_OPTIONBYTE(VALUE) ((((VALUE) & OPTIONBYTE_ALL) != 0U) && \
863 (((VALUE) & ~OPTIONBYTE_ALL) == 0U))
865#define IS_OB_BOOT_ADDRESS(ADDRESS) ((ADDRESS) <= 0x8013U)
867#define IS_OB_RDP_LEVEL(LEVEL) (((LEVEL) == OB_RDP_LEVEL_0) ||\
868 ((LEVEL) == OB_RDP_LEVEL_1) ||\
869 ((LEVEL) == OB_RDP_LEVEL_2))
871#define IS_OB_WWDG_SOURCE(SOURCE) (((SOURCE) == OB_WWDG_SW) || ((SOURCE) == OB_WWDG_HW))
873#define IS_OB_IWDG_SOURCE(SOURCE) (((SOURCE) == OB_IWDG_SW) || ((SOURCE) == OB_IWDG_HW))
875#define IS_OB_STOP_SOURCE(SOURCE) (((SOURCE) == OB_STOP_NO_RST) || ((SOURCE) == OB_STOP_RST))
877#define IS_OB_STDBY_SOURCE(SOURCE) (((SOURCE) == OB_STDBY_NO_RST) || ((SOURCE) == OB_STDBY_RST))
879#define IS_OB_IWDG_STOP_FREEZE(FREEZE) (((FREEZE) == OB_IWDG_STOP_FREEZE) || ((FREEZE) == OB_IWDG_STOP_ACTIVE))
881#define IS_OB_IWDG_STDBY_FREEZE(FREEZE) (((FREEZE) == OB_IWDG_STDBY_FREEZE) || ((FREEZE) == OB_IWDG_STDBY_ACTIVE))
883#define IS_OB_BOR_LEVEL(LEVEL) (((LEVEL) == OB_BOR_LEVEL0) || ((LEVEL) == OB_BOR_LEVEL1) || \
884 ((LEVEL) == OB_BOR_LEVEL2) || ((LEVEL) == OB_BOR_LEVEL3))
886#define IS_FLASH_LATENCY(LATENCY) (((LATENCY) == FLASH_LATENCY_0) || \
887 ((LATENCY) == FLASH_LATENCY_1) || \
888 ((LATENCY) == FLASH_LATENCY_2) || \
889 ((LATENCY) == FLASH_LATENCY_3) || \
890 ((LATENCY) == FLASH_LATENCY_4) || \
891 ((LATENCY) == FLASH_LATENCY_5) || \
892 ((LATENCY) == FLASH_LATENCY_6) || \
893 ((LATENCY) == FLASH_LATENCY_7) || \
894 ((LATENCY) == FLASH_LATENCY_8) || \
895 ((LATENCY) == FLASH_LATENCY_9) || \
896 ((LATENCY) == FLASH_LATENCY_10) || \
897 ((LATENCY) == FLASH_LATENCY_11) || \
898 ((LATENCY) == FLASH_LATENCY_12) || \
899 ((LATENCY) == FLASH_LATENCY_13) || \
900 ((LATENCY) == FLASH_LATENCY_14) || \
901 ((LATENCY) == FLASH_LATENCY_15))
903#define IS_FLASH_SECTOR(SECTOR) ((SECTOR) < FLASH_SECTOR_TOTAL)
905#if (FLASH_SECTOR_TOTAL == 8U)
906#define IS_OB_WRP_SECTOR(SECTOR) ((((SECTOR) & 0xFFFFFF00U) == 0x00000000U) && ((SECTOR) != 0x00000000U))
908#define IS_OB_WRP_SECTOR(SECTOR) ((SECTOR) != 0x00000000U)
911#define IS_OB_PCROP_RDP(CONFIG) (((CONFIG) == OB_PCROP_RDP_NOT_ERASE) || \
912 ((CONFIG) == OB_PCROP_RDP_ERASE))
914#define IS_OB_SECURE_RDP(CONFIG) (((CONFIG) == OB_SECURE_RDP_NOT_ERASE) || \
915 ((CONFIG) == OB_SECURE_RDP_ERASE))
917#define IS_OB_USER_SWAP_BANK(VALUE) (((VALUE) == OB_SWAP_BANK_DISABLE) || ((VALUE) == OB_SWAP_BANK_ENABLE))
919#define IS_OB_USER_IOHSLV(VALUE) (((VALUE) == OB_IOHSLV_DISABLE) || ((VALUE) == OB_IOHSLV_ENABLE))
921#if defined (FLASH_OPTSR_VDDMMC_HSLV)
922#define IS_OB_USER_VDDMMC_HSLV(VALUE) (((VALUE) == OB_VDDMMC_HSLV_DISABLE) || ((VALUE) == OB_VDDMMC_HSLV_ENABLE))
925#define IS_OB_IWDG1_SOURCE(SOURCE) (((SOURCE) == OB_IWDG1_SW) || ((SOURCE) == OB_IWDG1_HW))
926#if defined (DUAL_CORE)
927#define IS_OB_IWDG2_SOURCE(SOURCE) (((SOURCE) == OB_IWDG2_SW) || ((SOURCE) == OB_IWDG2_HW))
929#define IS_OB_STOP_D1_RESET(VALUE) (((VALUE) == OB_STOP_NO_RST_D1) || ((VALUE) == OB_STOP_RST_D1))
931#define IS_OB_STDBY_D1_RESET(VALUE) (((VALUE) == OB_STDBY_NO_RST_D1) || ((VALUE) == OB_STDBY_RST_D1))
933#define IS_OB_USER_IWDG_STOP(VALUE) (((VALUE) == OB_IWDG_STOP_FREEZE) || ((VALUE) == OB_IWDG_STOP_ACTIVE))
935#define IS_OB_USER_IWDG_STDBY(VALUE) (((VALUE) == OB_IWDG_STDBY_FREEZE) || ((VALUE) == OB_IWDG_STDBY_ACTIVE))
937#define IS_OB_USER_ST_RAM_SIZE(VALUE) (((VALUE) == OB_ST_RAM_SIZE_2KB) || ((VALUE) == OB_ST_RAM_SIZE_4KB) || \
938 ((VALUE) == OB_ST_RAM_SIZE_8KB) || ((VALUE) == OB_ST_RAM_SIZE_16KB))
940#define IS_OB_USER_SECURITY(VALUE) (((VALUE) == OB_SECURITY_ENABLE) || ((VALUE) == OB_SECURITY_DISABLE))
942#if defined (DUAL_CORE)
943#define IS_OB_USER_BCM4(VALUE) (((VALUE) == OB_BCM4_DISABLE) || ((VALUE) == OB_BCM4_ENABLE))
945#define IS_OB_USER_BCM7(VALUE) (((VALUE) == OB_BCM7_DISABLE) || ((VALUE) == OB_BCM7_ENABLE))
948#if defined (FLASH_OPTSR_NRST_STOP_D2)
949#define IS_OB_STOP_D2_RESET(VALUE) (((VALUE) == OB_STOP_NO_RST_D2) || ((VALUE) == OB_STOP_RST_D2))
951#define IS_OB_STDBY_D2_RESET(VALUE) (((VALUE) == OB_STDBY_NO_RST_D2) || ((VALUE) == OB_STDBY_RST_D2))
954#if defined (FLASH_OPTSR2_TCM_AXI_SHARED)
955#define IS_OB_USER_TCM_AXI_SHARED(VALUE) (((VALUE) == OB_TCM_AXI_SHARED_ITCM64KB) || ((VALUE) == OB_TCM_AXI_SHARED_ITCM128KB) || \
956 ((VALUE) == OB_TCM_AXI_SHARED_ITCM192KB) || ((VALUE) == OB_TCM_AXI_SHARED_ITCM256KB))
959#if defined (FLASH_OPTSR2_CPUFREQ_BOOST)
960#define IS_OB_USER_CPUFREQ_BOOST(VALUE) (((VALUE) == OB_CPUFREQ_BOOST_DISABLE) || ((VALUE) == OB_CPUFREQ_BOOST_ENABLE))
963#define IS_OB_USER_TYPE(TYPE) ((((TYPE) & OB_USER_ALL) != 0U) && \
964 (((TYPE) & ~OB_USER_ALL) == 0U))
966#define IS_OB_BOOT_ADD_OPTION(VALUE) (((VALUE) == OB_BOOT_ADD0) || \
967 ((VALUE) == OB_BOOT_ADD1) || \
968 ((VALUE) == OB_BOOT_ADD_BOTH))
970#define IS_FLASH_TYPECRC(VALUE) (((VALUE) == FLASH_CRC_ADDR) || \
971 ((VALUE) == FLASH_CRC_SECTORS) || \
972 ((VALUE) == FLASH_CRC_BANK))
974#if defined (FLASH_OTPBL_LOCKBL)
975#define IS_OTP_BLOCK(VALUE) ((((VALUE) & 0xFFFF0000U) == 0x00000000U) && ((VALUE) != 0x00000000U))
HAL_StatusTypeDef HAL_FLASHEx_OBProgram(FLASH_OBProgramInitTypeDef *pOBInit)
Program option bytes.
HAL_StatusTypeDef HAL_FLASHEx_Lock_Bank2(void)
Locks the FLASH Bank2 control registers access.
HAL_StatusTypeDef HAL_FLASHEx_Unlock_Bank2(void)
Unlock the FLASH Bank2 control registers access.
HAL_StatusTypeDef HAL_FLASHEx_Erase(FLASH_EraseInitTypeDef *pEraseInit, uint32_t *SectorError)
Perform a mass erase or erase the specified FLASH memory sectors.
void HAL_FLASHEx_OBGetConfig(FLASH_OBProgramInitTypeDef *pOBInit)
Get the Option byte configuration.
HAL_StatusTypeDef HAL_FLASHEx_ComputeCRC(FLASH_CRCInitTypeDef *pCRCInit, uint32_t *CRC_Result)
HAL_StatusTypeDef HAL_FLASHEx_Unlock_Bank1(void)
Unlock the FLASH Bank1 control registers access.
HAL_StatusTypeDef HAL_FLASHEx_Lock_Bank1(void)
Locks the FLASH Bank1 control registers access.
HAL_StatusTypeDef HAL_FLASHEx_Erase_IT(FLASH_EraseInitTypeDef *pEraseInit)
Perform a mass erase or erase the specified FLASH memory sectors with interrupt enabled.
void FLASH_Erase_Sector(uint32_t Sector, uint8_t VoltageRange)
Erase the specified FLASH memory sector.
This file contains HAL common defines, enumeration, macros and structures definitions.
FLASH Erase structure definition.
FLASH Option Bytes Program structure definition.
uint32_t SecureAreaConfig
uint32_t SecureAreaStartAddr
uint32_t SecureAreaEndAddr