OpenEdv-开源电子网

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

关于战舰FSMC地址线一些疑问和理解

[复制链接]

4

主题

7

帖子

0

精华

初级会员

Rank: 2

积分
59
金钱
59
注册时间
2013-6-8
在线时间
6 小时
发表于 2016-1-14 12:10:31 | 显示全部楼层 |阅读模式
u8 data1[4]={0};
如果data1==0x0000;
那么
&data1[0]==0x0000;
&data1[1]==0x0001;
&data1[2]==0x0002;
&data1[3]==0x0003;
因为STM32内部的HADDR[25:0]包含外部存储器地址,而且HADDR是“字节地址”,意思就是stm32访问的单位是“字节8bit”,所以当外部是64M字节*8的sram时,地址线是意义对应的,以为
data1数组在sram里面存储的方式是u8格式。
u16 data2[4]={0};
如果data1==0x0000;
那么
&data2[0]==0x0000;
&data2[1]==0x0002;
&data2[2]==0x0004;
&data2[3]==0x0006;

data2数组在sram中一个元素占据两个字节的内存单元,但是HADDR时“字节地址”,并且stm32访问的单位是“字节”,而不是“字”,所以存在地址匹配的问题。
关系是:HADDR[25:1]与FSMC_A[24:0]对应相连,HADDR[0]未接
内部HADDR给出地址是0X0004,最终由FSMC_A[24:0]反应给sram的是0x0002;相当于对0X0004>>1得到的。
HADDR[0]未接,HADDR给出的地址都是2的倍数,正好跨过去“2个字节”,
举例:
HADDR[25:1]=0x0000;  右移一位,FSMC_A[24:0]=0x0000;
HADDR[25:1]=0x0001;  右移一位,FSMC_A[24:0]=0x0000;
HADDR[25:1]=0x0002;  右移一位,FSMC_A[24:0]=0x0001;
HADDR[25:1]=0x0003;  右移一位,FSMC_A[24:0]=0x0001;
这是本人理解,不知道是否正确?
如果是上述理解过程,在结合NBL[1:0]来进行两个字节的读取,是这样的吗?




正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

0

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
103
金钱
103
注册时间
2016-7-31
在线时间
17 小时
发表于 2018-6-29 11:16:26 | 显示全部楼层
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-29 04:05

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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