OpenEdv-开源电子网

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

发现原子哥的F407的SDIO例程对SD卡初始化 CmdResp3Error(void)有一处小小的问题

[复制链接]

13

主题

38

帖子

0

精华

初级会员

Rank: 2

积分
112
金钱
112
注册时间
2013-7-9
在线时间
6 小时
发表于 2015-10-23 23:56:34 | 显示全部楼层 |阅读模式
将原子哥的SDIO例程中的初始化程序弄到F429上面,发现在插卡和没有插卡的时候都返回初始化成功,直觉告诉我初始化并没有真正成功,于是就ST-LINK仿真设置断点然后一个一个命令的发送并通过查看寄存器的值看是否发送成功,当发送到ACMD41时,SDIO的状态寄存器中CRC校验位置位,说明在这里出现了CRC错误,于是查看原子哥关于该命令的响应函数SD_Error CmdResp3Error(void):
先将该函数代码贴出来
[mw_shl_code=c,true]SD_Error CmdResp3Error(void) { u32 status; while(1) { status=SDIO->STA; if(status&((1<<0)|(1<<2)|(1<<6)))break;//CRC错误/命令响应错误/已经收到响应(CRC校验成功) } if(SDIO_GetFlagStatus(SDIO_FLAG_CTIMEOUT) != RESET) //响应超时± { SDIO_ClearFlag(SDIO_FLAG_CTIMEOUT); //清除超时标志 return SD_CMD_RSP_TIMEOUT; } SDIO_ClearFlag(SDIO_STATIC_FLAGS);//清除所有标记 return SD_OK; }[/mw_shl_code]
函数首先判断发生了  CRC错误/命令响应错误/已经收到响应    三种情况的的其中一种
如果是超时,那就返回超时错误,但是却没有判断是否发生了CRC校验失败,从而返回CRC错误,而我的程序恰好是在这里产生了CRC校验失败,但是仍旧返回了OK,所以我觉得还应该在里面加一句:
[mw_shl_code=c,true] if(SDIO_GetFlagStatus(SDIO_FLAG_CCRCFAIL) != RESET) { SDIO_ClearFlag(SDIO_FLAG_CCRCFAIL); return SDIO_FLAG_CCRCFAIL; } [/mw_shl_code]
不知道我的想法是不是正确的
但是为什么总在这里发生CRC校验错误呢?


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

使用道具 举报

530

主题

11万

帖子

34

精华

管理员

Rank: 12Rank: 12Rank: 12

积分
165536
金钱
165536
注册时间
2010-12-1
在线时间
2117 小时
发表于 2015-10-24 19:00:07 | 显示全部楼层
恩,你是对的,这里可以加上CRC校验错误返回失败。
我是开源电子网www.openedv.com站长,有关站务问题请与我联系。
正点原子STM32开发板购买店铺http://openedv.taobao.com
正点原子官方微信公众平台,点击这里关注“正点原子”
回复 支持 反对

使用道具 举报

13

主题

38

帖子

0

精华

初级会员

Rank: 2

积分
112
金钱
112
注册时间
2013-7-9
在线时间
6 小时
 楼主| 发表于 2015-10-26 09:10:22 | 显示全部楼层
后来我发现了一个帖子,这个帖子就是对这个问题的讨论,从这个博客证明了原子哥的程序是对的,如果是真的加入CRCfail才是错的,不好意思,误导大家了,博客的链接:http://blog.163.com/dreamatic_altezza/blog/static/119304542013112932216498/
回复 支持 反对

使用道具 举报

13

主题

87

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
421
金钱
421
注册时间
2015-12-3
在线时间
46 小时
发表于 2016-8-9 18:03:38 | 显示全部楼层
返回SD_CMD_RSP_TIMEOUT初始化不成功,请问是怎么回事啊?
学到老,活到老
回复 支持 反对

使用道具 举报

18

主题

41

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
424
金钱
424
注册时间
2016-9-2
在线时间
79 小时
发表于 2017-11-16 21:08:17 | 显示全部楼层
R3没有CRC检测 当然你检测的话 一直显示错误
回复 支持 反对

使用道具 举报

21

主题

108

帖子

0

精华

中级会员

Rank: 3Rank: 3

积分
355
金钱
355
注册时间
2017-11-25
在线时间
80 小时
发表于 2018-12-13 16:00:47 | 显示全部楼层
天际超体 发表于 2016-8-9 18:03
返回SD_CMD_RSP_TIMEOUT初始化不成功,请问是怎么回事啊?

请问你解决这个问题了吗
我也遇到了同样的问题
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2025-6-9 04:18

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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