OpenEdv-开源电子网

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

FSMC写外部SRAM,比如我给a地址写1字节数据,为何实际写到了a地址+1的地址里去了?而且SRAM的起始地址里的数据会跟着一起变

[复制链接]

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
69
金钱
69
注册时间
2016-8-11
在线时间
17 小时
发表于 2016-8-19 11:43:15 | 显示全部楼层 |阅读模式
2金钱
本帖最后由 jeffreymiau 于 2016-8-19 11:45 编辑

如题,不知我是否表达的明白?外部SRAM挂在FSMC存储块一的第一区,即NE1。所以首地址是0x60000000。另数据线宽度是8bit。我在首地址定义了一个数组u8 testsram[256] __attribute__((at(0X60000000)));然后给这个数组写的0-255这256个数据:for(ts=0;ts<256;ts++) {testsram[ts] = ts;},实际写完后发现数据0没有写在testsram[0]而是写在了testsram[1],数据1没有写在testsram[1]而是写在了testsram[2],以此类推,其实就是整体偏了一位,而testsram[0]里面的数据永远跟着你在其他地址写的数据一起变,这是为何?

最佳答案

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

如果语法上没有问题,那就有可能是时序或者硬件了。 比如原理图错误、SRAM反应太慢什么的, 原理图错误的话,单步调试(汇编模式)然后一根根线测量电平,看是否对应。 SRAM有问题的话,不知道怎么测试,替换法或者挂到GPIO上,用GPIO模拟时序,GPIO设置为输入输出,不开启FSMC。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

33

主题

984

帖子

1

精华

论坛元老

Rank: 8Rank: 8

积分
8017
金钱
8017
注册时间
2014-8-13
在线时间
1594 小时
发表于 2016-8-19 11:43:16 | 显示全部楼层
本帖最后由 mack13013 于 2016-8-20 16:02 编辑

如果语法上没有问题,那就有可能是时序或者硬件了。
比如原理图错误、SRAM反应太慢什么的,
原理图错误的话,单步调试(汇编模式)然后一根根线测量电平,看是否对应。

SRAM有问题的话,不知道怎么测试,替换法或者挂到GPIO上,用GPIO模拟时序,GPIO设置为输入输出,不开启FSMC。
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
69
金钱
69
注册时间
2016-8-11
在线时间
17 小时
 楼主| 发表于 2016-8-19 13:27:05 | 显示全部楼层
有高手帮忙指点一下吗
回复

使用道具 举报

19

主题

430

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1341
金钱
1341
注册时间
2016-4-22
在线时间
187 小时
发表于 2016-8-19 13:30:44 | 显示全部楼层
外部地址不是0X68000000开始的吗?
伤情最是晚凉天,憔悴斯人不堪怜。
邀酒摧肠三杯醉,寻香惊梦五更寒。
钗头凤斜卿有泪,荼蘼花了我无缘。
小楼寂寞新雨月,也难如钩也难圆。
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
69
金钱
69
注册时间
2016-8-11
在线时间
17 小时
 楼主| 发表于 2016-8-19 14:24:27 | 显示全部楼层
ysq7120 发表于 2016-8-19 13:30
外部地址不是0X68000000开始的吗?

0X68000000是因为原子哥把sram接在了存储块1的第三区,即用的NE3,所以例程上是0x68000000,我这边接在了存储块1的第1区,用的NE1,所以应该是0x60000000
回复

使用道具 举报

69

主题

978

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3772
金钱
3772
注册时间
2015-4-26
在线时间
765 小时
发表于 2016-8-19 15:15:45 | 显示全部楼层
是不是因为sram是16bit的,你定义的u8 数组其实是按u16写入的。过几天要用到外部sram还没仔细看。楼主解决后请发一下,谢谢
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
69
金钱
69
注册时间
2016-8-11
在线时间
17 小时
 楼主| 发表于 2016-8-19 16:50:27 | 显示全部楼层
来俩不甜的 发表于 2016-8-19 15:15
是不是因为sram是16bit的,你定义的u8 数组其实是按u16写入的。过几天要用到外部sram还没仔细看。楼主解决 ...

好像不是,我改成16bit之后依旧如此
回复

使用道具 举报

69

主题

978

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3772
金钱
3772
注册时间
2015-4-26
在线时间
765 小时
发表于 2016-8-20 11:07:55 | 显示全部楼层
jeffreymiau 发表于 2016-8-19 16:50
好像不是,我改成16bit之后依旧如此

解决后,@ 下我,我也想知道。多谢
我有故事,你有酒吗
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
69
金钱
69
注册时间
2016-8-11
在线时间
17 小时
 楼主| 发表于 2016-8-20 11:48:23 | 显示全部楼层
来俩不甜的 发表于 2016-8-20 11:07
解决后,@ 下我,我也想知道。多谢

恩,还在研究中
回复

使用道具 举报

20

主题

122

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
407
金钱
407
注册时间
2016-3-27
在线时间
104 小时
发表于 2016-8-20 15:43:26 | 显示全部楼层
帮顶
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
69
金钱
69
注册时间
2016-8-11
在线时间
17 小时
 楼主| 发表于 2016-8-22 09:52:11 | 显示全部楼层
mack13013 发表于 2016-8-20 15:59
如果语法上没有问题,那就有可能是时序或者硬件了。
比如原理图错误、SRAM反应太慢什么的,
原理图错误的 ...

多谢,确实是SRAM慢了,改了初始化的时序就好了
回复

使用道具 举报

6

主题

29

帖子

0

精华

初级会员

Rank: 2

积分
69
金钱
69
注册时间
2016-8-11
在线时间
17 小时
 楼主| 发表于 2016-8-22 09:53:11 | 显示全部楼层
来俩不甜的 发表于 2016-8-20 11:07
解决后,@ 下我,我也想知道。多谢

时序的配置问题,一定要照着sram的datasheet的时序配置
回复

使用道具 举报

69

主题

978

帖子

0

精华

论坛元老

Rank: 8Rank: 8

积分
3772
金钱
3772
注册时间
2015-4-26
在线时间
765 小时
发表于 2016-8-22 13:26:09 | 显示全部楼层
jeffreymiau 发表于 2016-8-22 09:53
时序的配置问题,一定要照着sram的datasheet的时序配置

哦,谢谢
我有故事,你有酒吗
回复

使用道具 举报

5

主题

23

帖子

0

精华

初级会员

Rank: 2

积分
102
金钱
102
注册时间
2016-5-16
在线时间
13 小时
发表于 2016-9-12 16:24:49 | 显示全部楼层
谢谢!有点懂了!
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-25 13:47

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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