[应用相关] 寄存器地址与结构体

[复制链接]
968|12
 楼主| morrisk 发表于 2020-5-19 23:35 | 显示全部楼层 |阅读模式
stm32f103寄存器地址与结构体是怎么关联的
xxmmi 发表于 2020-5-19 23:40 | 显示全部楼层
什么意思?不是很明白你说的什么,能再解释一下这个现象吗
 楼主| morrisk 发表于 2020-5-19 23:42 | 显示全部楼层
比如说GPIOA->CRL,是如何就知道CRL的具体地址了,这里具体只是定义了GPIOA的基地址,GPIO_TypeDef结构体中的寄存器成员是如何和实际寄存器相关联的   
kangzj 发表于 2020-5-19 23:46 | 显示全部楼层
这个是C语音的概念吧,没深究过
huwr 发表于 2020-5-19 23:48 | 显示全部楼层
基地址加偏移,看应用手册里面CRL的地址是不是这样构成的
stly 发表于 2020-5-19 23:52 | 显示全部楼层
主要对地址要了解透彻
ayb_ice 发表于 2020-5-20 09:36 | 显示全部楼层
基地址+偏移
huanghuac 发表于 2020-5-20 21:14 | 显示全部楼层
这要研究头文件怎么写的了。
 楼主| morrisk 发表于 2020-5-20 21:19 | 显示全部楼层

我看了库以及相关头文件的定义并没有看到加偏移量的地方
bqyj 发表于 2020-5-20 21:22 | 显示全部楼层
typedef struct
{
  __IO uint32_t CRL;
  __IO uint32_t CRH;
  __IO uint32_t IDR;
  __IO uint32_t ODR;
  __IO uint32_t BSRR;
  __IO uint32_t BRR;
  __IO uint32_t LCKR;
} GPIO_TypeDef;

看结构定义CRL偏移量是0,寄存器定义的是uint32_t型,32位,下一个CRH偏移量是0x04。C语言要加强练习了。
 楼主| morrisk 发表于 2020-5-20 21:27 | 显示全部楼层
大神说的是,一定的加强了
kcfoo1 发表于 2020-5-21 09:40 来自手机 | 显示全部楼层
用的是结构指针,用结构体将寄存器地址排列好,然后指向的是x40000000+偏移量
zchong 发表于 2020-5-22 07:25 来自手机 | 显示全部楼层
就是个指向特定位置的结构体指针而已,没啥特别
您需要登录后才可以回帖 登录 | 注册

本版积分规则

701

主题

6879

帖子

2

粉丝
快速回复 在线客服 返回列表 返回顶部