OpenEdv-开源电子网

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

惨痛经历,STM32L4的SPI总线真坑

[复制链接]

3

主题

9

帖子

0

精华

初级会员

Rank: 2

积分
61
金钱
61
注册时间
2017-5-22
在线时间
11 小时
发表于 2019-4-16 16:42:14 | 显示全部楼层 |阅读模式
最近想把潘多拉板子的SD SPI驱动增加DMA功能,结果发现STM32L4的SPI总线巨坑
第一,不用SPI DMA功能时,接收一字节数据之前一定要发送一字节无效数据以保证时钟有效,否则就接收不到;
第二,启用DMA功能,发送没问题,可接收就一直不能等待DMA传输结束,原因就是第一点,接收时,DMA每传输一
         字节之前没有发送一字节无效数据以保证时钟有效,坑
第三,我试过不用HAL库,用LL库重写SD SPI驱动,发现SD卡初始化完成后就使能SPI TX和RX的DMA功能,会导致在不用
         DMA传输的情况下读数据出错,最典型就是读SD卡的CSD和CID寄存器(即块读),其他SD卡的指令读写没问题,坑
第四,LL库并不完善,STM32L4的SPI总线添加了FIFO功能,导致每次传输都要检查FIFO是否为空和总线忙,F1和F4没这情况,
         按照F1和F4的思路会掉坑
最后一点,潘多拉板子裸机例程的SD SPI驱动中SD卡初始化有些问题,我用V2HC的SD卡一直初始化失败,直到我参考官方
SD SPI初始化流程(即Physical Layer Simplified Specification Version 6.00文档):
Snipaste_2019-04-16_16-29-28.png
大概就是如果是V2的SD卡要在发送CMD8后先发送CMD58检查OCR(即卡兼容电压),之后才发送ACMD41直到返回0 。按照官方的初始化流程是
成功的;而按照例程的SD SPI驱动(发送CMD8后不发送CMD58,直接发送ACMD41直到返回0 )是一直失败。

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

使用道具 举报

109

主题

5562

帖子

0

精华

资深版主

Rank: 8Rank: 8

积分
10540
金钱
10540
注册时间
2017-2-18
在线时间
1908 小时
发表于 2019-4-16 20:51:09 | 显示全部楼层
多谢分享,提醒后来者少走些弯路
回复 支持 反对

使用道具 举报

0

主题

4

帖子

0

精华

初级会员

Rank: 2

积分
54
金钱
54
注册时间
2019-7-19
在线时间
21 小时
发表于 2019-8-15 15:57:05 | 显示全部楼层
惨痛经历呀,用LL库按照原来的思路写被坑好久。。。
回复 支持 反对

使用道具 举报

8

主题

73

帖子

0

精华

高级会员

Rank: 4

积分
697
金钱
697
注册时间
2014-5-24
在线时间
145 小时
发表于 2020-8-26 22:37:42 | 显示全部楼层
想知道楼主怎么使用潘多拉上面的SPI+DMA的,能否共享下工程,参考以下?
回复 支持 反对

使用道具 举报

0

主题

11

帖子

0

精华

初级会员

Rank: 2

积分
103
金钱
103
注册时间
2013-5-24
在线时间
19 小时
发表于 2024-8-22 16:02:32 | 显示全部楼层
STM32L4的SPI总线真的太坑!!
回复 支持 反对

使用道具 举报

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

本版积分规则



关闭

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

正点原子公众号

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

GMT+8, 2024-11-22 10:02

Powered by OpenEdv-开源电子网

© 2001-2030 OpenEdv-开源电子网

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