OpenEdv-开源电子网

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

请大神帮我分析一下实验现象,关于FSMC的读写问题。

[复制链接]

15

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
126
金钱
126
注册时间
2014-10-13
在线时间
0 小时
发表于 2015-3-12 19:40:15 | 显示全部楼层 |阅读模式
5金钱
请前辈帮忙分析一下实验现象。
描述如下:
项目中使用STM32的FSMC与控制芯片进行总线通讯,FSMC的配置上使用的是PCCard模式,因此使用的是FSMC的BANK4地址,并且使用的是通用空间,其地址映像为0x9000 0000---0x93FF FFFF.....
在程序中,使用这样小段代码来测试通讯是否建立:
[mw_shl_code=c,true] outpw(AXIS_X+4, 0x4321); outpw(AXIS_X+6, 0x0765); p645_wcom(AXIS_X, WPRMV); p645_wcom(AXIS_X, STAUD); p645_wcom(AXIS_X, RRMV); data0 = inpw(AXIS_X+4); data1 = inpw(AXIS_X+6);[/mw_shl_code]
其中 #define AXIS_X 0x90000000 
       #define outpw(address,data) (*(volatile unsigned int *)(address)=(data));
       AXIS_X+4 表示向目标芯片的BUFW0中写入数据, AXIS_X+6 表示向目标芯片的BUFW1中写入数据
       p645_wcom(AXIS_X, WPRMV);  该语句表示把BUFW0/1 分别写入X轴的寄存器PRMV的高低16位;
       
然后,我再依次把RMV寄存器中的高低16位读出来,看是否写的正确。

实验现象如下:
这是关于FSMC_BANK4需要用到的寄存器的配置结果截图


当我在outpw(AXIS_X+4, 0x4321);单步进去的时候,我用MDK观察0x9000 0000的数据,变成了这样:


全部都被写上数据了,但是当我把光标移到Memory窗口,滚动一下滑动条的话,就只剩下第一行数据了:


个人认为这里数据消失应该是与Keil软件本身有关。  但是数据错误却不知道该作何解释,写进去的数据竟然是8F7E!!!
而且,在继续执行一下其他的语句,所有数据立马清零。
最后读数据,读出来的都是0......
还有个现象就是,当我把端点都取消之后run,读出来的data数据却又不是0,而是:


又有个数据,而且就是那些写进去就是错了的数据。

实验结果是这样,但是小弟不知道这样的结果可以反映出什么问题,应该在软件配置或者硬件电路上作何改进,希望有经验的前辈给一些指点,实在感谢!!!

正点原子逻辑分析仪DL16劲爆上市
回复

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165540
金钱
165540
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-3-12 22:21:41 | 显示全部楼层
回复

使用道具 举报

15

主题

46

帖子

0

精华

初级会员

Rank: 2

积分
126
金钱
126
注册时间
2014-10-13
在线时间
0 小时
 楼主| 发表于 2015-4-2 22:34:43 | 显示全部楼层
果然还是没有人有相关经验吗????
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-24 03:22

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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