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

STM32Cube结果文件的GPIO IDR寄存器的特定地址定义在哪里?,stm32,memory-address,gpio,Stm32,Memory Address,Gpio,我已经阅读了关于STM32Cube生成的STM32项目的解释,如下所示 从这个网站上,我了解到: 例如,在stm32f0xx.h文件中,GPIOA的原始地址已由声明 “#定义GPIOA_基地(AHB1PERIPH_基地+0x0000U)” 然后,GPIOA的所有对应寄存器由 “#定义GPIOA((GPIO_TypeDef*)GPIOA_BASE)” 根据上述信息,此头文件已经定义了GPIOA的原始地址,并声明了GPIOA的相应寄存器(如IDR、MODER、ODR等)的存在 但是这些代码没有明确定

我已经阅读了关于STM32Cube生成的STM32项目的解释,如下所示

从这个网站上,我了解到: 例如,在stm32f0xx.h文件中,GPIOA的原始地址已由声明

“#定义GPIOA_基地(AHB1PERIPH_基地+0x0000U)”

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

“#定义GPIOA((GPIO_TypeDef*)GPIOA_BASE)” 根据上述信息,此头文件已经定义了GPIOA的原始地址,并声明了GPIOA的相应寄存器(如IDR、MODER、ODR等)的存在

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


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

它定义得很清楚。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;
typedef结构
{
__IO uint32_t MODER;/*!

因此,例如,如果您解除对访问OSpeder寄存器的指针的反馈
GPIOA->OSpeder=0x4567编译器知道结构的此成员位于结构开头的偏移量8处(以字节为单位,但机器代码仅使用字节地址),并且已明确定义。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;
typedef结构
{
__IO uint32_t MODER;/*!

因此,例如,如果您解除对访问OSpeder寄存器的指针的反馈
GPIOA->OSpeder=0x4567编译器知道结构的这个成员位于结构开头的偏移量8处(以字节为单位,但机器代码只使用字节地址)

非常感谢您的回答。因此,我从您的回答中了解到,“编译器自动知道GPIOA_OTYPER的实际地址为GPIOA_OTYPER的地址=(GPIOA_基地址+OTYPER的地址偏移量)GPIOA_基的地址在头文件中明确给出,但哪些代码明确定义了OTYPER的地址偏移量=0x04?对我来说,/*!GPIOA_OTYPER
而是
GPIOA->OTYPER
@ZhengHu注释反映了编译器将使用ffsets。结构中的每个字段都是
uint32\u t
类型。因此
GPIOA->MODER
相当于访问位于
GPIOA\u库
的4个字节,
GPIOA->OTYPER
相当于访问
GPIOA\u库+4
,因为
OTYPER
被定义为位于
MODER
长度为4字节。PS。在这种特殊情况下,我没有涉及结构字段填充方面。@P_uj_u_uu是的,GPIOA->OTYPER,我仍然想知道编译器如何知道这个指针指向这个OTYPER寄存器的特定地址?我们知道每个寄存器都有一个唯一的地址,我一直在寻找STMCube生成的项目文件中的代码