OpenEdv-开源电子网

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

FSMC外扩SRAM问题

[复制链接]

2

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
55
金钱
55
注册时间
2017-11-17
在线时间
9 小时
发表于 2017-11-17 23:34:44 | 显示全部楼层 |阅读模式
1金钱
遇到一个问题,STM32F103ZET6的开发板,外扩的SRAM是256K*16bit的,连接在FSMC bank1 块3(地址范围:0x6800 0000~0x6bff ffff)上,在keil设置里面没有设置,使用的是    __attribute__  写入绝对地址的,按照道理来说256K的SRAM起始地址是0x6800 0000,那么结束地址应该是0x6803 ffff.再往大的地址写读数据都没用了,可是我用__attribute__ 往更大的地址写读数据 (创建了数组,比如说:long test[10000]__attribute__((at(0x680F3850)));  )都没有出现问题,1.编译通过,2.在线调试看地址是否写入数据,结果正常,3.看变量是否能正常写入数据,也是正常的。最后把在地址之外的数组能否应用到工程,最后结果也没问题    鄙人陋见觉得数据应该是成功写入了 可是这不是很奇怪吗?那数据也没重新覆盖原来地址的数据,那它储存到哪了呢?而且能正常写到0x6bff fffc,直到了0x6c00 0000往后就的写进去了。这究竟是怎么回事???

FSMC配置

FSMC配置

FSMC的读写函数

FSMC的读写函数
捕获2.PNG

最佳答案

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

当然是覆盖前面的数据了。你可以做个简单的测试,比如写入32位的数字,从0开始写,一直写到超过这个地址,你会发现超过以后,就把开始的位置覆盖了。
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2017-11-17 23:34:45 | 显示全部楼层
当然是覆盖前面的数据了。你可以做个简单的测试,比如写入32位的数字,从0开始写,一直写到超过这个地址,你会发现超过以后,就把开始的位置覆盖了。
回复

使用道具 举报

2

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
55
金钱
55
注册时间
2017-11-17
在线时间
9 小时
 楼主| 发表于 2017-11-18 07:43:50 | 显示全部楼层
正点原子 发表于 2017-11-17 23:34
当然是覆盖前面的数据了。你可以做个简单的测试,比如写入32位的数字,从0开始写,一直写到超过这个地址, ...

原子哥,256K*16bit的SRAM不是最多放u16的变量262,144个吗?我最大的时候都放了100,000,00还是没有覆盖前面的数据啊(用在线调试看的),
还有呢,如果是覆盖了前面的数据,那么,long test[10000]__attribute__((at(0x680F3850)));
0x680F3850都大于0x6803ffff了,那这个数组是往哪个地址覆盖了呢?写的不是绝对地址吗?
谢谢原子哥的解答
回复

使用道具 举报

2

主题

6

帖子

0

精华

初级会员

Rank: 2

积分
55
金钱
55
注册时间
2017-11-17
在线时间
9 小时
 楼主| 发表于 2017-11-19 16:25:35 | 显示全部楼层
啊啊。我的问题还没解决呢,别变成勾勾啊!
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-9 16:46

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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