OpenEdv-开源电子网

 找回密码
 立即注册

扫一扫,访问微社区

正点原子全套STM32开发资料,上千讲STM32视频教程,RT1052教程免费下载啦...

查看: 428|回复: 8

32的寄存器的地址是物理地址还是逻辑地址

[复制链接]

  离线 

15

主题

83

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
314
金钱
314
注册时间
2016-7-24
在线时间
82 小时
发表于 2018-1-11 13:41:29 | 显示全部楼层 |阅读模式
40金钱
32的寄存器的地址是物理地址还是逻辑地址,就是说比如  GPIOx_ODR  的地址是    0x4001080c  ,他的偏移地址是0Ch,   这里面的哪个地址是物理地址,哪个地址是逻辑地址买这两个地址有什么区别和联系

最佳答案

查看完整内容[请看2#楼]

凡是寄存器,都是物理地址。 物理地址是不可以变动的,逻辑地址,在某些情况下,可以重新定义。
回复

使用道具 举报

  离线 

501

主题

9万

帖子

31

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
130074
金钱
130074
注册时间
2010-12-1
在线时间
1173 小时
发表于 2018-1-11 13:41:30 | 显示全部楼层
fanhuayishi 发表于 2018-1-11 17:03
那32的  GPIO的地址,是属于物理地址吗

就像stm32f10x.h里的

凡是寄存器,都是物理地址。
物理地址是不可以变动的,逻辑地址,在某些情况下,可以重新定义。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

  离线 

32

主题

180

帖子

0

精华

高级会员

Rank: 4

积分
510
金钱
510
注册时间
2016-3-8
在线时间
118 小时
发表于 2018-1-11 14:30:40 | 显示全部楼层
物理地址就是实际的一个寻址地址,偏移地址是基于某一个实际物理地址的偏移。就比如有100个数0-99。你可以整体来看,那11这个数就是第11个(0开始计),如果分成10断看,那就是第1断(0开始计)的起始数是10。。往后偏移1个的数是11.。那这个1就是偏移地址了。
回复

使用道具 举报

  离线 

15

主题

83

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
314
金钱
314
注册时间
2016-7-24
在线时间
82 小时
 楼主| 发表于 2018-1-11 15:34:42 | 显示全部楼层
pdwdzz 发表于 2018-1-11 14:30
物理地址就是实际的一个寻址地址,偏移地址是基于某一个实际物理地址的偏移。就比如有100个数0-99。你可以 ...

偏移地址明白,那逻辑地址又是指的什么呢
回复

使用道具 举报

  离线 

14

主题

414

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2467
金钱
2467
注册时间
2013-6-27
在线时间
321 小时
发表于 2018-1-11 15:48:25 | 显示全部楼层
正点原子公众号
32单片机是统一编址 范围为0~0XFFFF_FFFF每个bit都可以理解为有唯一对应地址。 (串口收发寄存器为特立)
模块偏于地址  是设计芯片32核与外设资源对4G地址资源的分段分区。

如何有用STM32总线配置CPLD,把CPLD连接的SRAM,定时器,配置模块统一挂一个片选总线上编址,就会非常清楚。
让我们的思维驾驭在电的速度之上!
回复

使用道具 举报

  离线 

2

主题

83

帖子

0

精华

高级会员

Rank: 4

积分
607
金钱
607
注册时间
2017-12-11
在线时间
135 小时
发表于 2018-1-11 16:10:35 | 显示全部楼层
物理地址,就是硬件地址,可以认为cortex内核设计者为每个寄存器都排了个座位。这样方便寻(寻找座位)。
逻辑地址,我没理解楼主的意思,可能这里指的是软件地址(逻辑意义上的地址)。不管怎么说,所谓的逻辑地址或者软件地址,归根到底是目标是为了操作硬件地址(物理地址),所以站在硬件地址(物理地址)上去理解,应该会比较容易。
为什么大多数的地址是32位的呢?
因为内核设计时,已经将数据总线,指令总线,AHB总线,APB总线,包括通用寄存器等统统使用32位宽度,这样操作32位寄存器效率最高。当然,你用32位总线去传输16位指令或者16位数据当然是可以的,只不过有浪费(好比32车道的高速公路,你只使用了16个车道),自然效率不是最高。
回复

使用道具 举报

  离线 

15

主题

83

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
314
金钱
314
注册时间
2016-7-24
在线时间
82 小时
 楼主| 发表于 2018-1-11 17:03:12 | 显示全部楼层
bootblack 发表于 2018-1-11 16:10
物理地址,就是硬件地址,可以认为cortex内核设计者为每个寄存器都排了个座位。这样方便寻(寻找座位)。
...

那32的  GPIO的地址,是属于物理地址吗

就像stm32f10x.h里的

#define GPIOD_BASE            (APB2PERIPH_BASE + 0x1400)

这句话 里    (APB2PERIPH_BASE + 0x1400)  属于什么地址
回复

使用道具 举报

  离线 

7

主题

124

帖子

0

精华

高级会员

Rank: 4

积分
959
金钱
959
注册时间
2016-11-21
在线时间
257 小时
发表于 2018-1-12 09:01:07 | 显示全部楼层
fanhuayishi 发表于 2018-1-11 17:03
那32的  GPIO的地址,是属于物理地址吗

就像stm32f10x.h里的

物理地址
回复

使用道具 举报

  离线 

1

主题

5

帖子

0

精华

新手入门

积分
17
金钱
17
注册时间
2018-1-12
在线时间
4 小时
发表于 2018-1-12 10:52:19 | 显示全部楼层
学习了!
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则




关闭

"原子哥”推荐上一条 /1 下一条

QQ|联系我们|手机版|官方淘宝店|新浪微博|微信公众平台|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2018-7-23 23:34

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

快速回复 返回顶部 返回列表
/* */