OpenEdv-开源电子网

 找回密码
 立即注册
正点原子全套STM32/Linux/FPGA开发资料,上千讲STM32视频教程免费下载...
查看: 12730|回复: 3

GPIO寄存器是32位,为什么一个寄存器要占用4个地址?

[复制链接]

2

主题

3

帖子

0

精华

新手入门

积分
31
金钱
31
注册时间
2015-10-24
在线时间
0 小时
发表于 2015-10-24 11:34:39 | 显示全部楼层 |阅读模式
5金钱
我的理解是一个地址就能访问到这个32位的寄存器。
一个寄存器占用4个地址的话,也就是一个地址可以访问8位,我觉得这种寄存器以8位作为一个存储单元,应该叫做8位寄存器。
这点有点困惑,望大家指教。

最佳答案

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

地址是以Byte为单位进行空间分配的,32位就是4Byte。 所以,显然,对于32位的寄存器,一个寄存器就必须占用4Byte的地址。 如果系统支持按字节访问,那么,如果你不嫌麻烦的话,是可以分4次按字节访问该寄存器的全部4个字节的。但似乎,除了无聊或特殊情况,没有谁会这么做。。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

1

主题

67

帖子

0

精华

初级会员

Rank: 2

积分
102
金钱
102
注册时间
2015-6-6
在线时间
2 小时
发表于 2015-10-24 11:34:40 | 显示全部楼层
地址是以Byte为单位进行空间分配的,32位就是4Byte。
所以,显然,对于32位的寄存器,一个寄存器就必须占用4Byte的地址。
如果系统支持按字节访问,那么,如果你不嫌麻烦的话,是可以分4次按字节访问该寄存器的全部4个字节的。但似乎,除了无聊或特殊情况,没有谁会这么做。。
三更有梦书当枕,千里怀人月在峰!
回复

使用道具 举报

2

主题

3

帖子

0

精华

新手入门

积分
31
金钱
31
注册时间
2015-10-24
在线时间
0 小时
 楼主| 发表于 2015-10-24 17:30:16 | 显示全部楼层
回复【2楼】laidaihua:
---------------------------------
你好。
“地址是以Byte为单位进行空间分配的。”这句话的意思是不是一个地址只能指向一个8位的空间?
“如果系统支持按字节访问,是可以分4次按字节访问该寄存器的全部4个字节的。”这句的意思是一个地址就能访问这个32位的寄存器吗,我觉得既然有四个地址,不就是一个地址对应一个8位的空间吗,然后分4次访问该寄存器的全部4个字节?
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165371
金钱
165371
注册时间
2010-12-1
在线时间
2110 小时
发表于 2015-10-24 18:54:27 | 显示全部楼层
回复【3楼】Arachne:
---------------------------------
在MCU系统里面,地址一般都是以字节为单位的。
32位系统,可以读一个地址,访问32位,提高访问速度,你不闲蛋疼和速度慢的话,可以慢慢一次读1字节。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

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

本版积分规则



关闭

原子哥极力推荐上一条 /2 下一条

正点原子公众号

QQ|手机版|OpenEdv-开源电子网 ( 粤ICP备12000418号-1 )

GMT+8, 2025-2-25 12:21

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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