STM32Cube结果文件对GPIO IDR寄存器的具体地址定义在哪里?
Where is the specific address definition of the GPIO IDR register by STM32Cube resulting files?
这个STM32Cube制作的STM32工程的解释我已经看完了website.
从这个网站上,我了解到:
例如在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对应寄存器的寄存器地址的代码?
定义明确。 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(以字节为单位 - 但机器代码仅使用字节地址)结构的开头
这个STM32Cube制作的STM32工程的解释我已经看完了website.
从这个网站上,我了解到: 例如在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对应寄存器的寄存器地址的代码?
定义明确。 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(以字节为单位 - 但机器代码仅使用字节地址)结构的开头