初级会员

- 积分
- 59
- 金钱
- 59
- 注册时间
- 2013-6-8
- 在线时间
- 6 小时
|
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]来进行两个字节的读取,是这样的吗?
|
|