RTEMS 6.1-rc7
Loading...
Searching...
No Matches
Data Structures | Macros | Functions
stm32h7xx_hal_flash_ex.h File Reference

Header file of FLASH HAL module. More...

#include "stm32h7xx_hal_def.h"

Go to the source code of this file.

Data Structures

struct  FLASH_EraseInitTypeDef
 FLASH Erase structure definition. More...
 
struct  FLASH_OBProgramInitTypeDef
 FLASH Option Bytes Program structure definition. More...
 
struct  FLASH_CRCInitTypeDef
 FLASH Erase structure definition. More...
 

Macros

#define FLASH_TYPEERASE_SECTORS   0x00U
 
#define FLASH_TYPEERASE_MASSERASE   0x01U
 
#define OB_WRPSTATE_DISABLE   0x00000000U
 
#define OB_WRPSTATE_ENABLE   0x00000001U
 
#define OPTIONBYTE_WRP   0x01U
 
#define OPTIONBYTE_RDP   0x02U
 
#define OPTIONBYTE_USER   0x04U
 
#define OPTIONBYTE_PCROP   0x08U
 
#define OPTIONBYTE_BOR   0x10U
 
#define OPTIONBYTE_SECURE_AREA   0x20U
 
#define OPTIONBYTE_BOOTADD   0x40U
 
#define OPTIONBYTE_ALL
 
#define OB_RDP_LEVEL_0   0xAA00U
 
#define OB_RDP_LEVEL_1   0x5500U
 
#define OB_RDP_LEVEL_2   0xCC00U
 
#define OB_IWDG_SW   OB_IWDG1_SW
 
#define OB_IWDG_HW   OB_IWDG1_HW
 
#define OB_STOP_NO_RST   0x40U
 
#define OB_STOP_RST   0x00U
 
#define OB_STDBY_NO_RST   0x80U
 
#define OB_STDBY_RST   0x00U
 
#define OB_IWDG_STOP_FREEZE   0x00000000U
 
#define OB_IWDG_STOP_ACTIVE   FLASH_OPTSR_FZ_IWDG_STOP
 
#define OB_IWDG_STDBY_FREEZE   0x00000000U
 
#define OB_IWDG_STDBY_ACTIVE   FLASH_OPTSR_FZ_IWDG_SDBY
 
#define OB_BOR_LEVEL0   0x00000000U
 
#define OB_BOR_LEVEL1   FLASH_OPTSR_BOR_LEV_0
 
#define OB_BOR_LEVEL2   FLASH_OPTSR_BOR_LEV_1
 
#define OB_BOR_LEVEL3   (FLASH_OPTSR_BOR_LEV_1 | FLASH_OPTSR_BOR_LEV_0)
 
#define OB_BOOTADDR_ITCM_RAM   0x0000U
 
#define OB_BOOTADDR_SYSTEM   0x0040U
 
#define OB_BOOTADDR_ITCM_FLASH   0x0080U
 
#define OB_BOOTADDR_AXIM_FLASH   0x2000U
 
#define OB_BOOTADDR_DTCM_RAM   0x8000U
 
#define OB_BOOTADDR_SRAM1   0x8004U
 
#define OB_BOOTADDR_SRAM2   0x8013U
 
#define FLASH_LATENCY_0   FLASH_ACR_LATENCY_0WS
 
#define FLASH_LATENCY_1   FLASH_ACR_LATENCY_1WS
 
#define FLASH_LATENCY_2   FLASH_ACR_LATENCY_2WS
 
#define FLASH_LATENCY_3   FLASH_ACR_LATENCY_3WS
 
#define FLASH_LATENCY_4   FLASH_ACR_LATENCY_4WS
 
#define FLASH_LATENCY_5   FLASH_ACR_LATENCY_5WS
 
#define FLASH_LATENCY_6   FLASH_ACR_LATENCY_6WS
 
#define FLASH_LATENCY_7   FLASH_ACR_LATENCY_7WS
 
#define FLASH_LATENCY_8   FLASH_ACR_LATENCY_8WS
 
#define FLASH_LATENCY_9   FLASH_ACR_LATENCY_9WS
 
#define FLASH_LATENCY_10   FLASH_ACR_LATENCY_10WS
 
#define FLASH_LATENCY_11   FLASH_ACR_LATENCY_11WS
 
#define FLASH_LATENCY_12   FLASH_ACR_LATENCY_12WS
 
#define FLASH_LATENCY_13   FLASH_ACR_LATENCY_13WS
 
#define FLASH_LATENCY_14   FLASH_ACR_LATENCY_14WS
 
#define FLASH_LATENCY_15   FLASH_ACR_LATENCY_15WS
 
#define FLASH_BANK_1   0x01U
 
#define OB_PCROP_RDP_NOT_ERASE   0x00000000U
 
#define OB_PCROP_RDP_ERASE   FLASH_PRAR_DMEP
 
#define OB_WRP_SECTOR_0   0x00000001U
 
#define OB_WRP_SECTOR_1   0x00000002U
 
#define OB_WRP_SECTOR_2   0x00000004U
 
#define OB_WRP_SECTOR_3   0x00000008U
 
#define OB_WRP_SECTOR_4   0x00000010U
 
#define OB_WRP_SECTOR_5   0x00000020U
 
#define OB_WRP_SECTOR_6   0x00000040U
 
#define OB_WRP_SECTOR_7   0x00000080U
 
#define OB_WRP_SECTOR_ALL   0x000000FFU
 
#define OB_SECURITY_DISABLE   0x00000000U
 
#define OB_SECURITY_ENABLE   FLASH_OPTSR_SECURITY
 
#define OB_ST_RAM_SIZE_2KB   0x00000000U
 
#define OB_ST_RAM_SIZE_4KB   FLASH_OPTSR_ST_RAM_SIZE_0
 
#define OB_ST_RAM_SIZE_8KB   FLASH_OPTSR_ST_RAM_SIZE_1
 
#define OB_ST_RAM_SIZE_16KB   FLASH_OPTSR_ST_RAM_SIZE
 
#define OB_IWDG1_SW   FLASH_OPTSR_IWDG1_SW
 
#define OB_IWDG1_HW   0x00000000U
 
#define OB_STOP_RST_D1   0x00000000U
 
#define OB_STOP_NO_RST_D1   FLASH_OPTSR_NRST_STOP_D1
 
#define OB_STDBY_RST_D1   0x00000000U
 
#define OB_STDBY_NO_RST_D1   FLASH_OPTSR_NRST_STBY_D1
 
#define OB_IOHSLV_DISABLE   0x00000000U
 
#define OB_IOHSLV_ENABLE   FLASH_OPTSR_IO_HSLV
 
#define OB_USER_IWDG1_SW   0x0001U
 
#define OB_USER_NRST_STOP_D1   0x0002U
 
#define OB_USER_NRST_STDBY_D1   0x0004U
 
#define OB_USER_IWDG_STOP   0x0008U
 
#define OB_USER_IWDG_STDBY   0x0010U
 
#define OB_USER_ST_RAM_SIZE   0x0020U
 
#define OB_USER_SECURITY   0x0040U
 
#define OB_USER_IOHSLV   0x0080U
 
#define OB_USER_ALL
 
#define OB_BOOT_ADD0   0x01U
 
#define OB_BOOT_ADD1   0x02U
 
#define OB_BOOT_ADD_BOTH   0x03U
 
#define OB_SECURE_RDP_NOT_ERASE   0x00000000U
 
#define OB_SECURE_RDP_ERASE   FLASH_SCAR_DMES
 
#define FLASH_CRC_ADDR   0x00000000U
 
#define FLASH_CRC_SECTORS   FLASH_CRCCR_CRC_BY_SECT
 
#define FLASH_CRC_BANK   (FLASH_CRCCR_ALL_BANK | FLASH_CRCCR_CRC_BY_SECT)
 
#define FLASH_CRC_BURST_SIZE_4   0x00000000U
 
#define FLASH_CRC_BURST_SIZE_16   FLASH_CRCCR_CRC_BURST_0
 
#define FLASH_CRC_BURST_SIZE_64   FLASH_CRCCR_CRC_BURST_1
 
#define FLASH_CRC_BURST_SIZE_256   FLASH_CRCCR_CRC_BURST
 
#define FLASH_PROGRAMMING_DELAY_0   0x00000000U
 
#define FLASH_PROGRAMMING_DELAY_1   FLASH_ACR_WRHIGHFREQ_0
 
#define FLASH_PROGRAMMING_DELAY_2   FLASH_ACR_WRHIGHFREQ_1
 
#define FLASH_PROGRAMMING_DELAY_3   FLASH_ACR_WRHIGHFREQ
 
#define __HAL_FLASH_CALC_BOOT_BASE_ADR(__ADDRESS__)   ((__ADDRESS__) >> 14U)
 Calculate the FLASH Boot Base Address (BOOT_ADD0 or BOOT_ADD1)
 
#define __HAL_FLASH_SET_PROGRAM_DELAY(__DELAY__)   MODIFY_REG(FLASH->ACR, FLASH_ACR_WRHIGHFREQ, (__DELAY__))
 Set the FLASH Programming Delay.
 
#define __HAL_FLASH_GET_PROGRAM_DELAY()   READ_BIT(FLASH->ACR, FLASH_ACR_WRHIGHFREQ)
 Get the FLASH Programming Delay.
 
#define IS_FLASH_TYPEERASE(VALUE)
 
#define IS_WRPSTATE(VALUE)
 
#define IS_OPTIONBYTE(VALUE)
 
#define IS_OB_BOOT_ADDRESS(ADDRESS)   ((ADDRESS) <= 0x8013U)
 
#define IS_OB_RDP_LEVEL(LEVEL)
 
#define IS_OB_IWDG_SOURCE(SOURCE)   (((SOURCE) == OB_IWDG_SW) || ((SOURCE) == OB_IWDG_HW))
 
#define IS_OB_STOP_SOURCE(SOURCE)   (((SOURCE) == OB_STOP_NO_RST) || ((SOURCE) == OB_STOP_RST))
 
#define IS_OB_STDBY_SOURCE(SOURCE)   (((SOURCE) == OB_STDBY_NO_RST) || ((SOURCE) == OB_STDBY_RST))
 
#define IS_OB_IWDG_STOP_FREEZE(FREEZE)   (((FREEZE) == OB_IWDG_STOP_FREEZE) || ((FREEZE) == OB_IWDG_STOP_ACTIVE))
 
#define IS_OB_IWDG_STDBY_FREEZE(FREEZE)   (((FREEZE) == OB_IWDG_STDBY_FREEZE) || ((FREEZE) == OB_IWDG_STDBY_ACTIVE))
 
#define IS_OB_BOR_LEVEL(LEVEL)
 
#define IS_FLASH_LATENCY(LATENCY)
 
#define IS_FLASH_SECTOR(SECTOR)   ((SECTOR) < FLASH_SECTOR_TOTAL)
 
#define IS_OB_WRP_SECTOR(SECTOR)   ((SECTOR) != 0x00000000U)
 
#define IS_OB_PCROP_RDP(CONFIG)
 
#define IS_OB_SECURE_RDP(CONFIG)
 
#define IS_OB_USER_IOHSLV(VALUE)   (((VALUE) == OB_IOHSLV_DISABLE) || ((VALUE) == OB_IOHSLV_ENABLE))
 
#define IS_OB_IWDG1_SOURCE(SOURCE)   (((SOURCE) == OB_IWDG1_SW) || ((SOURCE) == OB_IWDG1_HW))
 
#define IS_OB_STOP_D1_RESET(VALUE)   (((VALUE) == OB_STOP_NO_RST_D1) || ((VALUE) == OB_STOP_RST_D1))
 
#define IS_OB_STDBY_D1_RESET(VALUE)   (((VALUE) == OB_STDBY_NO_RST_D1) || ((VALUE) == OB_STDBY_RST_D1))
 
#define IS_OB_USER_IWDG_STOP(VALUE)   (((VALUE) == OB_IWDG_STOP_FREEZE) || ((VALUE) == OB_IWDG_STOP_ACTIVE))
 
#define IS_OB_USER_IWDG_STDBY(VALUE)   (((VALUE) == OB_IWDG_STDBY_FREEZE) || ((VALUE) == OB_IWDG_STDBY_ACTIVE))
 
#define IS_OB_USER_ST_RAM_SIZE(VALUE)
 
#define IS_OB_USER_SECURITY(VALUE)   (((VALUE) == OB_SECURITY_ENABLE) || ((VALUE) == OB_SECURITY_DISABLE))
 
#define IS_OB_USER_TYPE(TYPE)
 
#define IS_OB_BOOT_ADD_OPTION(VALUE)
 
#define IS_FLASH_TYPECRC(VALUE)
 

Functions

HAL_StatusTypeDef HAL_FLASHEx_Erase (FLASH_EraseInitTypeDef *pEraseInit, uint32_t *SectorError)
 
HAL_StatusTypeDef HAL_FLASHEx_Erase_IT (FLASH_EraseInitTypeDef *pEraseInit)
 
HAL_StatusTypeDef HAL_FLASHEx_OBProgram (FLASH_OBProgramInitTypeDef *pOBInit)
 
void HAL_FLASHEx_OBGetConfig (FLASH_OBProgramInitTypeDef *pOBInit)
 
HAL_StatusTypeDef HAL_FLASHEx_Unlock_Bank1 (void)
 
HAL_StatusTypeDef HAL_FLASHEx_Lock_Bank1 (void)
 
HAL_StatusTypeDef HAL_FLASHEx_ComputeCRC (FLASH_CRCInitTypeDef *pCRCInit, uint32_t *CRC_Result)
 
void FLASH_Erase_Sector (uint32_t Sector, uint32_t Banks, uint32_t VoltageRange)
 

Detailed Description

Header file of FLASH HAL module.

Author
MCD Application Team
Attention

Copyright (c) 2017 STMicroelectronics. All rights reserved.

This software is licensed under terms that can be found in the LICENSE file in the root directory of this software component. If no LICENSE file comes with this software, it is provided AS-IS.