OpenEdv-开源电子网

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

战舰sram实验更改SRAM 的基址为:(0x68000000 - 0x4000000)后程序运行有问题,内详。

[复制链接]

6

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
60
金钱
60
注册时间
2014-7-28
在线时间
1 小时
发表于 2014-8-14 15:01:32 | 显示全部楼层 |阅读模式
5金钱
添加宏定义#define Bank1_SRAM2_ADDR    ((u32)(0x68000000 - 0x4000000)),并将代码中的Bank1_SRAM3_ADDR替换为Bank1_SRAM2_ADDR

u32 testsram[250000] __attribute__((at(0X68000000)));改为u32 testsram[250000] __attribute__((at(0X68000000  - 0x4000000)));

FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM3;替换为FSMC_NORSRAMInitStructure.FSMC_Bank = FSMC_Bank1_NORSRAM2;

FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM3, ENABLE);  替换为FSMC_NORSRAMCmd(FSMC_Bank1_NORSRAM2, ENABLE);

更改后运行不正确,可能是什么原因?

最佳答案

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

0X68000000  - 0x4000000,都已经不是战舰板SRAM的地址了....
正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2014-8-14 15:01:33 | 显示全部楼层
0X68000000  - 0x4000000,都已经不是战舰板SRAM的地址了....
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

6

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
60
金钱
60
注册时间
2014-7-28
在线时间
1 小时
 楼主| 发表于 2014-8-15 08:14:28 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
战舰板SRAM的地址范围是什么
回复

使用道具 举报

6

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
60
金钱
60
注册时间
2014-7-28
在线时间
1 小时
 楼主| 发表于 2014-8-15 09:53:15 | 显示全部楼层
战舰板SRAM的地址 不是0 ~ (2^19 - 1)吗? 0x68000000的高8位用不到的,所以高8位应该不影响,为何高8位换成64会有问题
回复

使用道具 举报

6

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
60
金钱
60
注册时间
2014-7-28
在线时间
1 小时
 楼主| 发表于 2014-8-15 17:00:44 | 显示全部楼层
回复【2楼】正点原子:
---------------------------------
我做了个比较
战舰sram实验用的是Bank1第三区,我在main中加入
while (1) {
    *(vu16*)((u32)(0x68000000) + 2) = 0xaa55;
}

我在另一个工程中sram实验用的是Bank1第二区,在main中加入
while (1) {
    *(vu16*)((u32)(0x64000000) + 2) = 0xaa55;
}

在板子上先后运行2个工程后发现a0 ~ a18,d0 ~ d15,FSMC_NBL0 ~ FSMC_NBL1, FSMC_NOE,FSMC_NWE各个脚的电压无变化,所以不是原子所说的“0X68000000  - 0x4000000,都已经不是战舰板SRAM的地址了....”

但是为何屏幕显示的sram内的数据不对
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2014-8-15 20:18:14 | 显示全部楼层
战舰板地址:0X68000000  ~0X68000000   +1024*1024
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165524
金钱
165524
注册时间
2010-12-1
在线时间
2116 小时
发表于 2014-8-15 20:19:50 | 显示全部楼层
回复【5楼】jpg4151:
---------------------------------
那你继续慢慢折腾.
一直搞不出来,别怪我没提醒你.
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复

使用道具 举报

14

主题

73

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
296
金钱
296
注册时间
2016-6-23
在线时间
29 小时
发表于 2016-7-29 13:47:12 | 显示全部楼层
正点原子 发表于 2014-8-15 20:19
回复【5楼】jpg4151:
---------------------------------
那你继续慢慢折腾.
一直搞不出来,别怪我没提醒你.

原子哥,那就是战舰板子外部SRAM 地址是从0x6800 0000 到 0x6810 0000对吧。所以我用过FATFS实验中的malloc以后,就不可能再有地方定义大的全局数组了?是吗
回复

使用道具 举报

5

主题

26

帖子

0

精华

初级会员

Rank: 2

积分
123
金钱
123
注册时间
2016-4-4
在线时间
39 小时
发表于 2016-9-20 09:20:21 | 显示全部楼层
正点原子 发表于 2014-8-15 20:18
战舰板地址:0X68000000  ~0X68000000   +1024*1024

你好,原子哥,这个地址可以在哪里找到,我看了数据手册没找到,求指导
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-5-25 05:40

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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