OpenEdv-开源电子网

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

为什么STM32中的寄存器地址偏移为0或4的倍数呢?

[复制链接]

69

主题

475

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1334
金钱
1334
注册时间
2013-12-28
在线时间
197 小时
发表于 2014-4-3 20:57:19 | 显示全部楼层 |阅读模式
如题,为什么一个寄存器要占用4个寻址地址?如果一个寄存器只占用1个寻址地址的话,那32位地址的寻址空间不就是16GB了。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165475
金钱
165475
注册时间
2010-12-1
在线时间
2115 小时
发表于 2014-4-3 23:32:46 | 显示全部楼层
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

69

主题

475

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1334
金钱
1334
注册时间
2013-12-28
在线时间
197 小时
 楼主| 发表于 2014-4-4 08:10:08 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
谢谢原子哥的回答,看了你回答,瞬间感觉我的问题好2啊。我一直以为每一个寻址地址寻址的是32位的数据,所以我对其中空余的寻址地址不理解。那我想再问问原子哥,为什么每个寻址地址对应的数据是8位呢?也就是为什么一个32位的寄存器需要占用4个寻址地址呢。在我们修改某个寄存器值的时候也不能将一个32位的寄存器分成4部分去单独进行操作啊。如果每个寻址地址对应的数据是32位的话,那32的寻址空间不就变成16G了,那不更好吗。难道是因为Flash的原因?很多的不解啊!
回复 支持 反对

使用道具 举报

69

主题

475

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1334
金钱
1334
注册时间
2013-12-28
在线时间
197 小时
 楼主| 发表于 2014-4-4 16:16:55 | 显示全部楼层
自己顶一个
回复 支持 反对

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165475
金钱
165475
注册时间
2010-12-1
在线时间
2115 小时
发表于 2014-4-4 22:06:39 | 显示全部楼层
回复【3楼】jiaozhu:
---------------------------------
基本单位就是字节。所以一般地址加1,都是对应一个8位的数据地址。
因为以8位为基准,所以32位自然是占4个地址了。。。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-12 19:14

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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