123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263 |
- /**
- ******************************************************************************
- * @brief FMC header file of the firmware library.
- ******************************************************************************
- */
- /* Define to prevent recursive inclusion -------------------------------------*/
- #ifndef __GD32F10X_FMC_H
- #define __GD32F10X_FMC_H
- #ifdef __cplusplus
- extern "C" {
- #endif
- /* Includes ------------------------------------------------------------------*/
- #include "gd32f10x.h"
- /** @addtogroup GD32F10x_Firmware
- * @{
- */
- /** @addtogroup FMC
- * @{
- */
- /* Exported types ------------------------------------------------------------*/
- /** @defgroup FMC_Exported_Types
- * @{
- */
- /**
- * @brief FMC State
- */
- typedef enum {
- FMC_READY,
- FMC_BSY,
- FMC_WRPERR,
- FMC_PGERR,
- FMC_TIMEOUT_ERR
- } FMC_State;
- /**
- * @}
- */
- /* Exported constants --------------------------------------------------------*/
- /** @defgroup FMC_Exported_Constants
- * @{
- */
- /** @defgroup FMC_Interrupts
- * @{
- */
- #define FMC_INT_EOP FMC_CMR_ENDIE /*!< End of programming interrupt source */
- #define FMC_INT_ERR FMC_CMR_ERIE /*!< Error interrupt source */
- #define FMC_INT_B2_EOP ((uint32_t)0x80000400) /*!< Bank2 End of programming interrupt source */
- #define FMC_INT_B2_ERR ((uint32_t)0x80001000) /*!< Bank2 Error interrupt source */
- /**
- * @}
- */
- /** @defgroup FMC_Option_Bytes_Write_Protection
- * @{
- */
- #define WRP_SECTOR0 ((uint32_t)0x00000001) /*!< Write protection of sector 0 */
- #define WRP_SECTOR1 ((uint32_t)0x00000002) /*!< Write protection of sector 1 */
- #define WRP_SECTOR2 ((uint32_t)0x00000004) /*!< Write protection of sector 2 */
- #define WRP_SECTOR3 ((uint32_t)0x00000008) /*!< Write protection of sector 3 */
- #define WRP_SECTOR4 ((uint32_t)0x00000010) /*!< Write protection of sector 4 */
- #define WRP_SECTOR5 ((uint32_t)0x00000020) /*!< Write protection of sector 5 */
- #define WRP_SECTOR6 ((uint32_t)0x00000040) /*!< Write protection of sector 6 */
- #define WRP_SECTOR7 ((uint32_t)0x00000080) /*!< Write protection of sector 7 */
- #define WRP_SECTOR8 ((uint32_t)0x00000100) /*!< Write protection of sector 8 */
- #define WRP_SECTOR9 ((uint32_t)0x00000200) /*!< Write protection of sector 9 */
- #define WRP_SECTOR10 ((uint32_t)0x00000400) /*!< Write protection of sector 10 */
- #define WRP_SECTOR11 ((uint32_t)0x00000800) /*!< Write protection of sector 11 */
- #define WRP_SECTOR12 ((uint32_t)0x00001000) /*!< Write protection of sector 12 */
- #define WRP_SECTOR13 ((uint32_t)0x00002000) /*!< Write protection of sector 13 */
- #define WRP_SECTOR14 ((uint32_t)0x00004000) /*!< Write protection of sector 14 */
- #define WRP_SECTOR15 ((uint32_t)0x00008000) /*!< Write protection of sector 15 */
- #define WRP_SECTOR16 ((uint32_t)0x00010000) /*!< Write protection of sector 16 */
- #define WRP_SECTOR17 ((uint32_t)0x00020000) /*!< Write protection of sector 17 */
- #define WRP_SECTOR18 ((uint32_t)0x00040000) /*!< Write protection of sector 18 */
- #define WRP_SECTOR19 ((uint32_t)0x00080000) /*!< Write protection of sector 19 */
- #define WRP_SECTOR20 ((uint32_t)0x00100000) /*!< Write protection of sector 20 */
- #define WRP_SECTOR21 ((uint32_t)0x00200000) /*!< Write protection of sector 21 */
- #define WRP_SECTOR22 ((uint32_t)0x00400000) /*!< Write protection of sector 22 */
- #define WRP_SECTOR23 ((uint32_t)0x00800000) /*!< Write protection of sector 23 */
- #define WRP_SECTOR24 ((uint32_t)0x01000000) /*!< Write protection of sector 24 */
- #define WRP_SECTOR25 ((uint32_t)0x02000000) /*!< Write protection of sector 25 */
- #define WRP_SECTOR26 ((uint32_t)0x04000000) /*!< Write protection of sector 26 */
- #define WRP_SECTOR27 ((uint32_t)0x08000000) /*!< Write protection of sector 27 */
- #define WRP_SECTOR28 ((uint32_t)0x10000000) /*!< Write protection of sector 28 */
- #define WRP_SECTOR29 ((uint32_t)0x20000000) /*!< Write protection of sector 29 */
- #define WRP_SECTOR30 ((uint32_t)0x40000000) /*!< Write protection of sector 30 */
- #define WRP_SECTOR31 ((uint32_t)0x80000000) /*!< Write protection of sector 31 */
- #define WRP_ALLSECTORS ((uint32_t)0xFFFFFFFF) /*!< Write protection of all Sectors */
- /**
- * @}
- */
- /** @defgroup FMC_Option_Bytes_Read_Protection
- * @{
- */
- /**
- * @brief FMC_Read Protection Level
- */
- #define RDP_LEVEL_0 ((uint8_t)0xA5)
- #define RDP_LEVEL_1 ((uint8_t)0xBB)
- /**
- * @}
- */
- /** @defgroup FMC_Option_Bytes_IWatchdog
- * @{
- */
- #define OB_IWDG_SW ((uint8_t)0x01) /*!< Software IWDG selected */
- #define OB_IWDG_HW ((uint8_t)0x00) /*!< Hardware IWDG selected */
- /**
- * @}
- */
- /** @defgroup FMC_Option_Bytes_nRST_DEEPSLEEP
- * @{
- */
- #define OB_DEEPSLEEP_NORST ((uint8_t)0x02) /*!< No reset generated when entering in DEEPSLEEP */
- #define OB_DEEPSLEEP_RST ((uint8_t)0x00) /*!< Reset generated when entering in DEEPSLEEP */
- /**
- * @}
- */
- /** @defgroup FMC_Option_Bytes_nRST_STDBY
- * @{
- */
- #define OB_STDBY_NORST ((uint8_t)0x04) /*!< No reset generated when entering in STANDBY */
- #define OB_STDBY_RST ((uint8_t)0x00) /*!< Reset generated when entering in STANDBY */
- /**
- * @}
- */
- /** @defgroup FMC_Option_Bytes_BOOT
- * @{
- */
- #define OB_BOOT_B1 ((uint8_t)0x08) /*!< BOOT from Bank1 */
- #define OB_BOOT_B2 ((uint8_t)0x00) /*!< BOOT from Bank2 */
- #define OB_USER_BFB2 ((uint16_t)0x0008) /*!< Configure BOOT from Bank1 */
- /**
- * @}
- */
- /** @defgroup FMC_Flags
- * @{
- */
- #define FMC_FLAG_BSY FMC_CSR_BUSY /*!< FMC Busy flag */
- #define FMC_FLAG_PERR FMC_CSR_PGEF /*!< FMC Programming error flag */
- #define FMC_FLAG_WERR FMC_CSR_WPEF /*!< FMC Write protected error flag */
- #define FMC_FLAG_EOP FMC_CSR_ENDF /*!< FMC End of Programming flag */
- #define FMC_FLAG_OPTERR ((uint32_t)0x00000001) /*!< FMC Option Byte error flag */
- #define FMC_FLAG_B2_BSY ((uint32_t)0x80000001) /*!< FMC Busy flag */
- #define FMC_FLAG_B2_PERR ((uint32_t)0x80000004) /*!< FMC Programming error flag */
- #define FMC_FLAG_B2_WERR ((uint32_t)0x80000010) /*!< FMC Write protected error flag */
- #define FMC_FLAG_B2_EOP ((uint32_t)0x80000020) /*!< FMC End of Programming flag */
- /**
- * @}
- */
- /** @defgroup FMC_Timeout_definition
- * @{
- */
- #define FMC_TIMEOUT_COUNT ((uint32_t)0x000F0000)
- /**
- * @}
- */
- /* FMC BANK address */
- #define FMC_B1_END_ADDRESS ((uint32_t)0x807FFFF)
- #define FMC_BANK1_SIZE 0x0200
- #define FMC_SIZE (*(uint16_t *)0x1ffff7e0)
- /**
- * @}
- */
- /** @defgroup FMC_Exported_Functions
- * @{
- */
- /**
- * @brief FMC memory functions.
- */
- /* FMC Main Memory Programming functions *****************************************/
- void FMC_Unlock(void);
- void FMC_UnlockB1(void);
- void FMC_UnlockB2(void);
- void FMC_Lock(void);
- void FMC_LockB1(void);
- void FMC_LockB2(void);
- FMC_State FMC_ErasePage(uint32_t Page_Address);
- FMC_State FMC_MassErase(void);
- FMC_State FMC_MassB1Erase(void);
- FMC_State FMC_MassB2Erase(void);
- FMC_State FMC_ProgramWord(uint32_t Address, uint32_t Data);
- /* FMC Option Bytes Programming functions *****************************************/
- void FMC_OB_Unlock(void);
- void FMC_OB_Lock(void);
- void FMC_OB_Reset(void);
- FMC_State FMC_OB_Erase(void);
- FMC_State FMC_OB_EnableWRP(uint32_t OB_WRP);
- FMC_State FMC_ReadOutProtection(TypeState NewValue);
- FMC_State FMC_OB_RDPConfig(uint8_t OB_RDP);
- FMC_State FMC_OB_UserConfig(uint8_t OB_IWDG, uint8_t OB_DEEPSLEEP, uint8_t OB_STDBY);
- FMC_State FMC_OB_BOOTConfig(uint8_t OB_BOOT);
- FMC_State FMC_OB_WriteUser(uint8_t OB_USER);
- FMC_State FMC_ProgramOptionByteData(uint32_t Address, uint8_t Data);
- uint8_t FMC_OB_GetUser(void);
- uint32_t FMC_OB_GetWRP(void);
- TypeState FMC_OB_GetRDP(void);
- /* FMC Interrupts and flags management functions **********************************/
- void FMC_INTConfig(uint32_t FMC_INT, TypeState NewValue);
- TypeState FMC_GetBitState(uint32_t FMC_FLAG);
- void FMC_ClearBitState(uint32_t FMC_FLAG);
- FMC_State FMC_GetState(void);
- FMC_State FMC_GetB1State(void);
- FMC_State FMC_GetB2State(void);
- FMC_State FMC_WaitReady(uint32_t uCount);
- FMC_State FMC_B1_WaitReady(uint32_t uCount);
- FMC_State FMC_B2_WaitReady(uint32_t uCount);
- #ifdef __cplusplus
- }
- #endif
- #endif /* __GD32F10X_FMC_H */
- /**
- * @}
- */
- /**
- * @}
- */
- /**
- * @}
- */
|