OpenEdv-开源电子网

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

用FSMC控制IS62WV51216时关于地址和数据大小的问题

[复制链接]

2

主题

10

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2015-4-12
在线时间
0 小时
发表于 2016-5-10 13:02:52 | 显示全部楼层 |阅读模式
1金钱
外部内存的首地址是0X68000000,我想问一下,每个地址是存放一字节数据吗? 原子哥以及各位大神给小白解释下吧  谢谢

最佳答案

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

得根据位宽来算。但是对于STM32内部来说,事实上是固定一个地址对应一个字节的。 对于16位数据位宽的时候,对外设来说,一个地址2个字节,但是对于STM32来说,他内部通过HADDR的偏移(右移一位对齐),来实现字节访问,6800 000对应外设地址0的低字节,6800 0001对应外设地址0的高字节。 6800 0000和6800 0001,右移一位后,实际上就是6800 000了,地址一样。最低位用来控制UB/LB实现字节访问。从而可以以:8位/16位/32位 ...
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2016-5-10 13:02:53 | 显示全部楼层
得根据位宽来算。但是对于STM32内部来说,事实上是固定一个地址对应一个字节的。


对于16位数据位宽的时候,对外设来说,一个地址2个字节,但是对于STM32来说,他内部通过HADDR的偏移(右移一位对齐),来实现字节访问,6800 000对应外设地址0的低字节,6800 0001对应外设地址0的高字节。

6800 0000和6800 0001,右移一位后,实际上就是6800 000了,地址一样。最低位用来控制UB/LB实现字节访问。从而可以以:8位/16位/32位来访问外部sram,都是没问题的。

回复

使用道具 举报

7

主题

188

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2285
金钱
2285
注册时间
2013-12-16
在线时间
448 小时
发表于 2016-5-10 16:56:44 | 显示全部楼层
本帖最后由 zdfwyh 于 2016-5-10 16:58 编辑

16位总线宽度,每个地址就是两个字节,每次读写会读写两个字节。8位总线宽度,每个地址就是一个字节,每次读写会读写一个字节,IS62WV51216是16位宽度,所以要采用16位总线,每个地址两个字节,你也可以定义为8位总线,不过IS62WV51216可使用容量就减半
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2015-4-12
在线时间
0 小时
 楼主| 发表于 2016-5-10 17:20:02 | 显示全部楼层
zdfwyh 发表于 2016-5-10 16:56
16位总线宽度,每个地址就是两个字节,每次读写会读写两个字节。8位总线宽度,每个地址就是一个字节,每次 ...

F原子哥的例程里FSMC部分 设置的16位数据宽度  为什么每个地址付给了八位数据,还说如果要是16位位宽应该地址+2?这里好不明白
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2015-4-12
在线时间
0 小时
 楼主| 发表于 2016-5-10 17:22:07 | 显示全部楼层
zdfwyh 发表于 2016-5-10 16:56
16位总线宽度,每个地址就是两个字节,每次读写会读写两个字节。8位总线宽度,每个地址就是一个字节,每次 ...

是原子哥的手册上写错了吗
回复

使用道具 举报

7

主题

188

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2285
金钱
2285
注册时间
2013-12-16
在线时间
448 小时
发表于 2016-5-10 17:31:56 | 显示全部楼层
journey 发表于 2016-5-10 17:22
是原子哥的手册上写错了吗

没有问题,我说的是对应存储器的地址而言,IS62WV51216有几个地址引脚?容量多大?你可以算算,是不是只有一半容量的引脚?所以对于设备来说,每个地址有两个字节,但是对于CPU来说尤其STM32做了兼容处理,这个是CPU自己的特性,不需要你关心,塔会在处理16位总线外设是自动将地址总线向右移动1外来操作外设,对于程序来说就像处理8位总线数据一样,所以还是可以用8位数据进行编程,唯一需要注意的就是外设的基地址,在16位总线是要注意右移位的特性.对于8位总线就没有区别了,地址不进行移位.
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2015-4-12
在线时间
0 小时
 楼主| 发表于 2016-5-10 18:02:55 | 显示全部楼层
zdfwyh 发表于 2016-5-10 17:31
没有问题,我说的是对应存储器的地址而言,IS62WV51216有几个地址引脚?容量多大?你可以算算,是不是只有一半 ...

也就是说在用FSMC时,如果写入八位数据,它硬件会自动通过控制UB和LB来进行操作?原子哥的程序里,写入了八位数据后,地址就+1了,是不是使得SRAM容量减半了呢?那个学习手册还说如果读取16位数据的话,每读一次地址要+2?  这里好不明白,希望解答下  谢谢~~
回复

使用道具 举报

7

主题

188

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2285
金钱
2285
注册时间
2013-12-16
在线时间
448 小时
发表于 2016-5-10 18:19:02 | 显示全部楼层
本帖最后由 zdfwyh 于 2016-5-10 18:20 编辑

硬件会自动通过控制UB和LB来进行操作,这个不用程序上处理,假设外部存储器首地址是0x68000000,你可以定义u8* tmp1=(u8*)0x68000000;也可以定义u16 * tmp2=(u16*)0x68000000;操作tmp1[0]和tmp1[1]时,CPU会自动适应8位操作.操作tmp2[0],tmp2[1]时会自动适应16位操作,tmp[1]比tmp1[0]地址大1,tmp2[1]比tmp2[0]地址大2,这都没关系,CPU会处理,你不需要太纠结这个问题,8位时地址加1,16位时地址加2,32位时地址加4都能适应
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2015-4-12
在线时间
0 小时
 楼主| 发表于 2016-5-10 18:28:09 | 显示全部楼层
zdfwyh 发表于 2016-5-10 18:19
硬件会自动通过控制UB和LB来进行操作,这个不用程序上处理,假设外部存储器首地址是0x68000000,你可以定义u8* ...

如果我16位时地址+1  他怎么适应?会有什么结果呢?
回复

使用道具 举报

7

主题

188

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2285
金钱
2285
注册时间
2013-12-16
在线时间
448 小时
发表于 2016-5-10 18:44:50 | 显示全部楼层
(u16*)0x68000000和(u16*)0x68000001是同一个数据,(u16*)0x68000002和(u16*)0x68000003是同一个数据,即最低位如果为1是无效的
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2015-4-12
在线时间
0 小时
 楼主| 发表于 2016-5-10 19:55:00 | 显示全部楼层
zdfwyh 发表于 2016-5-10 18:44
(u16*)0x68000000和(u16*)0x68000001是同一个数据,(u16*)0x68000002和(u16*)0x68000003是同一个数据,即最低 ...

一个地址可以放2字节数据,为什么(u16*)0x68000000和(u16*)0x68000001是一个数据呢
回复

使用道具 举报

7

主题

188

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2285
金钱
2285
注册时间
2013-12-16
在线时间
448 小时
发表于 2016-5-10 20:17:52 | 显示全部楼层
我叫你打败了,不是说过吗,16位宽度时CPU访问外设时会自动右移1位吗?所以在16位宽度时你访问(u16*)0x68000001时最低位就移掉了,所以最低位就无效了和访问(u16*)0x68000000一样得到的数据都0地址的2个字节
回复

使用道具 举报

2

主题

10

帖子

0

精华

新手上路

积分
35
金钱
35
注册时间
2015-4-12
在线时间
0 小时
 楼主| 发表于 2016-5-10 20:43:58 | 显示全部楼层
本帖最后由 journey 于 2016-5-10 20:46 编辑
zdfwyh 发表于 2016-5-10 20:17
我叫你打败了,不是说过吗,16位宽度时CPU访问外设时会自动右移1位吗?所以在16位宽度时你访问(u16*)0x6800000 ...

我写入呢  会是什么情况呢  我想写入16位数据的   还有就是外部RAM的地址最高是0x69000000左右是吧?   谢谢大神解答哈
回复

使用道具 举报

1

主题

6

帖子

0

精华

新手上路

积分
34
金钱
34
注册时间
2010-12-27
在线时间
1 小时
发表于 2016-12-10 11:11:21 | 显示全部楼层
话说我本来是很明白的,现在被你们说晕了!
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-7-11 12:52

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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