你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

【经验分享】STM32 系统配置控制器相关函数和类型

[复制链接]
STMCU小助手 发布时间:2022-4-2 20:00
01. 概述
系统配置控制器主要用于管理对可执行代码的存储区域的地址重映射、选择以太网 PHY 接口以及管理 GPIO 的外部中断线连接。

02. 相关类型

SYSCFG_EXTI_Port_Sources

  1. /** @defgroup SYSCFG_EXTI_Port_Sources
  2.   * @{
  3.   */
  4. #define EXTI_PortSourceGPIOA       ((uint8_t)0x00)
  5. #define EXTI_PortSourceGPIOB       ((uint8_t)0x01)
  6. #define EXTI_PortSourceGPIOC       ((uint8_t)0x02)
  7. #define EXTI_PortSourceGPIOD       ((uint8_t)0x03)
  8. #define EXTI_PortSourceGPIOE       ((uint8_t)0x04)
  9. #define EXTI_PortSourceGPIOF       ((uint8_t)0x05)
  10. #define EXTI_PortSourceGPIOG       ((uint8_t)0x06)
  11. #define EXTI_PortSourceGPIOH       ((uint8_t)0x07)
  12. #define EXTI_PortSourceGPIOI       ((uint8_t)0x08)
  13. #define EXTI_PortSourceGPIOJ       ((uint8_t)0x09)
  14. #define EXTI_PortSourceGPIOK       ((uint8_t)0x0A)

  15. #define IS_EXTI_PORT_SOURCE(PORTSOURCE) (((PORTSOURCE) == EXTI_PortSourceGPIOA) || \
  16.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOB) || \
  17.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOC) || \
  18.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOD) || \
  19.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOE) || \
  20.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOF) || \
  21.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOG) || \
  22.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOH) || \
  23.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOI) || \
  24.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOJ) || \
  25.                                          ((PORTSOURCE) == EXTI_PortSourceGPIOK))
复制代码

SYSCFG_EXTI_Pin_Sources

  1. /** @defgroup SYSCFG_EXTI_Pin_Sources
  2.   * @{
  3.   */
  4. #define EXTI_PinSource0            ((uint8_t)0x00)
  5. #define EXTI_PinSource1            ((uint8_t)0x01)
  6. #define EXTI_PinSource2            ((uint8_t)0x02)
  7. #define EXTI_PinSource3            ((uint8_t)0x03)
  8. #define EXTI_PinSource4            ((uint8_t)0x04)
  9. #define EXTI_PinSource5            ((uint8_t)0x05)
  10. #define EXTI_PinSource6            ((uint8_t)0x06)
  11. #define EXTI_PinSource7            ((uint8_t)0x07)
  12. #define EXTI_PinSource8            ((uint8_t)0x08)
  13. #define EXTI_PinSource9            ((uint8_t)0x09)
  14. #define EXTI_PinSource10           ((uint8_t)0x0A)
  15. #define EXTI_PinSource11           ((uint8_t)0x0B)
  16. #define EXTI_PinSource12           ((uint8_t)0x0C)
  17. #define EXTI_PinSource13           ((uint8_t)0x0D)
  18. #define EXTI_PinSource14           ((uint8_t)0x0E)
  19. #define EXTI_PinSource15           ((uint8_t)0x0F)
  20. #define IS_EXTI_PIN_SOURCE(PINSOURCE) (((PINSOURCE) == EXTI_PinSource0)  || \
  21.                                        ((PINSOURCE) == EXTI_PinSource1)  || \
  22.                                        ((PINSOURCE) == EXTI_PinSource2)  || \
  23.                                        ((PINSOURCE) == EXTI_PinSource3)  || \
  24.                                        ((PINSOURCE) == EXTI_PinSource4)  || \
  25.                                        ((PINSOURCE) == EXTI_PinSource5)  || \
  26.                                        ((PINSOURCE) == EXTI_PinSource6)  || \
  27.                                        ((PINSOURCE) == EXTI_PinSource7)  || \
  28.                                        ((PINSOURCE) == EXTI_PinSource8)  || \
  29.                                        ((PINSOURCE) == EXTI_PinSource9)  || \
  30.                                        ((PINSOURCE) == EXTI_PinSource10) || \
  31.                                        ((PINSOURCE) == EXTI_PinSource11) || \
  32.                                        ((PINSOURCE) == EXTI_PinSource12) || \
  33.                                        ((PINSOURCE) == EXTI_PinSource13) || \
  34.                                        ((PINSOURCE) == EXTI_PinSource14) || \
  35.                                        ((PINSOURCE) == EXTI_PinSource15))
复制代码

SYSCFG_Memory_Remap_Config

  1. /** @defgroup SYSCFG_Memory_Remap_Config
  2.   * @{
  3.   */
  4. #define SYSCFG_MemoryRemap_Flash       ((uint8_t)0x00)
  5. #define SYSCFG_MemoryRemap_SystemFlash ((uint8_t)0x01)
  6. #define SYSCFG_MemoryRemap_SRAM        ((uint8_t)0x03)
  7. #define SYSCFG_MemoryRemap_SDRAM       ((uint8_t)0x04)
复制代码

SYSCFG_ETHERNET_Media_Interface


  1. /** @defgroup SYSCFG_ETHERNET_Media_Interface
  2.   * @{
  3.   */
  4. #define SYSCFG_ETH_MediaInterface_MII    ((uint32_t)0x00000000)
  5. #define SYSCFG_ETH_MediaInterface_RMII   ((uint32_t)0x00000001)

  6. #define IS_SYSCFG_ETH_MEDIA_INTERFACE(INTERFACE) (((INTERFACE) == SYSCFG_ETH_MediaInterface_MII) || \
  7.                                                  ((INTERFACE) == SYSCFG_ETH_MediaInterface_RMII))
复制代码

03. 相关函数

  1. /* Exported macro ------------------------------------------------------------*/
  2. /* Exported functions --------------------------------------------------------*/

  3. void       SYSCFG_DeInit(void);
  4. void       SYSCFG_MemoryRemapConfig(uint8_t SYSCFG_MemoryRemap);
  5. void       SYSCFG_MemorySwappingBank(FunctionalState NewState);
  6. void       SYSCFG_EXTILineConfig(uint8_t EXTI_PortSourceGPIOx, uint8_t EXTI_PinSourcex);
  7. void       SYSCFG_ETH_MediaInterfaceConfig(uint32_t SYSCFG_ETH_MediaInterface);
  8. void       SYSCFG_CompensationCellCmd(FunctionalState NewState);
  9. FlagStatus SYSCFG_GetCompensationCellStatus(void);

  10. #if defined(STM32F410xx) || defined(STM32F412xG) || defined(STM32F413_423xx)
  11. void       SYSCFG_BreakConfig(uint32_t SYSCFG_Break);
  12. #endif /* STM32F410xx || STM32F412xG || STM32F413_423xx */


  13. #if defined(STM32F413_423xx)
  14. void DFSDM_BitstreamClock_SourceSelection(uint32_t source);
  15. void DFSDM_DisableDelayClock(uint32_t MCHDLY);
  16. void DFSDM_EnableDelayClock(uint32_t MCHDLY);
  17. void DFSDM_ClockIn_SourceSelection(uint32_t source);
  18. void DFSDM_ClockOut_SourceSelection(uint32_t source);
  19. void DFSDM_DataIn0_SourceSelection(uint32_t source);
  20. void DFSDM_DataIn2_SourceSelection(uint32_t source);
  21. void DFSDM_DataIn4_SourceSelection(uint32_t source);
  22. void DFSDM_DataIn6_SourceSelection(uint32_t source);
  23. void DFSDM1_BitStreamClk_Config(uint32_t source);
  24. void DFSDM2_BitStreamClk_Config(uint32_t source);
  25. #endif /* STM32F413_423xx */
复制代码

04. 结构体封装

系统配置控制器结构体封装


  1. /**
  2.   * @brief System configuration controller
  3.   */

  4. typedef struct
  5. {
  6.   __IO uint32_t MEMRMP;       /*!< SYSCFG memory remap register,
  7.   Address offset: 0x00      */
  8.   __IO uint32_t PMC;          /*!< SYSCFG peripheral mode configuration register,
  9.   Address offset: 0x04      */
  10.   __IO uint32_t EXTICR[4];    /*!< SYSCFG external interrupt configuration registers,
  11.   Address offset: 0x08-0x14 */
  12. #if defined (STM32F410xx) || defined(STM32F412xG) || defined(STM32F413_423xx)
  13.   uint32_t      RESERVED;     /*!< Reserved, 0x18                                                               */
  14.   __IO uint32_t CFGR2;        /*!< Reserved, 0x1C                                                               */
  15.   __IO uint32_t CMPCR;        /*!< SYSCFG Compensation cell control register,
  16.   Address offset: 0x20      */
  17.   uint32_t      RESERVED1[2]; /*!< Reserved, 0x24-0x28                                                          */
  18.   __IO uint32_t CFGR;         /*!< SYSCFG Configuration register,
  19.   Address offset: 0x2C      */
  20. #else  /* STM32F40_41xxx || STM32F427_437xx || STM32F429_439xx ||
  21. STM32F401xx || STM32F411xE || STM32F446xx || STM32F469_479xx */
  22.   uint32_t      RESERVED[2];  /*!< Reserved, 0x18-0x1C                                                          */
  23.   __IO uint32_t CMPCR;        /*!< SYSCFG Compensation cell control register,
  24.   Address offset: 0x20      */
  25. #endif /* STM32F410xx || defined(STM32F412xG) || defined(STM32F413_423xx) */
  26. #if defined(STM32F413_423xx)
  27.   __IO uint32_t MCHDLYCR;     /*!< SYSCFG multi-channel delay register,
  28.   Address offset: 0x30      */
  29. #endif /* STM32F413_423xx */
  30. } SYSCFG_TypeDef;
复制代码


收藏 评论0 发布时间:2022-4-2 20:00

举报

0个回答

所属标签

相似分享

官网相关资源

关于
我们是谁
投资者关系
意法半导体可持续发展举措
创新与技术
意法半导体官网
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
官方最新发布
STM32N6 AI生态系统
STM32MCU,MPU高性能GUI
ST ACEPACK电源模块
意法半导体生物传感器
STM32Cube扩展软件包
关注我们
st-img 微信公众号
st-img 手机版