STM32Cube结果文件对GPIO IDR寄存器的特定地址定义在哪里?

时间:2018-08-01 15:33:39

标签: stm32 memory-address gpio

我已经阅读了website中对STM32Cube产生的STM32项目的解释。

从此网站,我了解到: 例如,在stm32f0xx.h文件中,

已经声明了GPIOA的原始地址。

“#define GPIOA_BASE(AHB1PERIPH_BASE + 0x0000U)”

然后所有与GPIOA对应的寄存器都由

声明

“#define GPIOA((GPIO_TypeDef *)GPIOA_BASE)”

根据以上信息,该头文件已经定义了GPIOA的原始地址,并声明了GPIOA相应寄存器的存在(例如IDR,MODER,ODR等)。

但是这些代码尚未明确定义这些GPIOA对应寄存器的地址。例如,GPIOA_IDR地址应定义为0x40020000 + 0x10 = 0x40020010,但我在头文件中没有看到这样的定义。

在哪里可以找到定义GOIP对应寄存器的寄存器地址的代码?

1 个答案:

答案 0 :(得分:2)

它有明确的定义。 GPIO寄存器在别名为GPIO_TypeDef类型的结构中定义。

您问题中的定义仅定义了指向类型为GPIO_TypeDef的结构的指针,其地址由整数常量GPIOA_BASE定义。通过访问结构成员取消引用此指针时,编译器会知道该特定成员在内存中的位置。

typedef struct
{
  __IO uint32_t MODER;        /*!< GPIO port mode register,               Address offset: 0x00      */
  __IO uint32_t OTYPER;       /*!< GPIO port output type register,        Address offset: 0x04      */
  __IO uint32_t OSPEEDR;      /*!< GPIO port output speed register,       Address offset: 0x08      */
  __IO uint32_t PUPDR;        /*!< GPIO port pull-up/pull-down register,  Address offset: 0x0C      */
  __IO uint32_t IDR;          /*!< GPIO port input data register,         Address offset: 0x10      */
  __IO uint32_t ODR;          /*!< GPIO port output data register,        Address offset: 0x14      */
  __IO uint32_t BSRR;         /*!< GPIO port bit set/reset register,      Address offset: 0x1A */
  __IO uint32_t LCKR;         /*!< GPIO port configuration lock register, Address offset: 0x1C      */
  __IO uint32_t AFR[2];       /*!< GPIO alternate function registers,     Address offset: 0x20-0x24 */
  __IO uint32_t BRR;          /*!< GPIO bit reset register,               Address offset: 0x28 */
}GPIO_TypeDef;

因此,例如,如果取消引用访问OSPEEDR寄存器GPIOA -> OSPEEDR = 0x4567;的指针,则编译器会知道该结构的该成员与以下内容的偏移量为8(以字节为单位,但是机器代码仅使用字节地址)。结构