OpenEdv-开源电子网

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

使用uSDHC读写eMMC出现数据错误问题

[复制链接]

15

主题

49

帖子

0

精华

初级会员

Rank: 2

积分
94
金钱
94
注册时间
2014-10-22
在线时间
24 小时
发表于 2019-4-12 21:06:47 | 显示全部楼层 |阅读模式
10金钱
各位大神,请教一个奇怪的问题,问题描述如下:

定义了两个数组:
char read_buf[1024] 地址为0x821010AC
char write_buf[1024] 地址为0x821014AC,
这两个数组是用来读写文件操作的缓存,两个数组是相邻的,并且内存属性配置都是一样的。
调用read(fd,read_buf,1024)去循环读取一个文件,发现read_buf的前20字节都是0(数据不应该为0),其他读取的数据都是正常,通过read(fd,write_buf,1024),则读取的数据完全正确,怀疑地址对齐问题(实际不是,0x821010AC地址是4字节对齐的)或则其他地址问题,通过其他修改代码人为开辟数组等方式改变read_buf的地址,则此时read(fd,read_buf,1024)就是正常。

怀疑是地址0x821010AC有问题,专门测试了下这地址上的数据读写,没问题,然后通过__no_init char read_buf[1024] @0x821010AC 这样的方式指定read_buf的地址,这样读取又是正确的

也就是说通过iar环境编译后自动分配的read_buf的地址为0x821010AC时就会有问题,但是人为指定read_buf的地址为0x821010AC时就正常,这是为什么呢?可以确定read_buf的空间没有出现越界等或者被其他任务修改的可能。

继续验证:在read(fd,read_buf,1024)之前,memset(read_buf,0x55,sizeof(read_buf)),然后发现每次读写时,前面的20字节全部都是0x55,更本没有改变,因此应该断定是cache的问题。
但是查看nxp的关于rt1052的应用手册《Using the i.MXRT L1 Cache.pdf》
在章节 4.2. Cache maintenance in SDK Driver,明确说了官方的SDK对于Ethernet和uSDHC外设的操作维护数据的一致性,也就是说我不需要管使用的buf的属性。
也稍微研究了下uSDHC的SDK函数,里面确实对cache进行了维护。

目前暂时可以将read_buf这个数据定义在non-cache段可以解决此问题,但问题的根本原因我还没理解。
因此这个问题我现在完全没有头绪了。求大神指点!

芯片是rt1052.

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

使用道具 举报

558

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
164867
金钱
164867
注册时间
2010-12-1
在线时间
2099 小时
发表于 2019-4-13 01:54:56 | 显示全部楼层
回复

使用道具 举报

1

主题

3

帖子

0

精华

新手入门

积分
6
金钱
6
注册时间
2022-7-13
在线时间
0 小时
发表于 2022-10-27 09:42:55 | 显示全部楼层
大神,RT1052怎么驱动EMMC啊,求协助
回复

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-5-14 16:29

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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