请选择 进入手机版 | 继续访问电脑版

你的浏览器版本过低,可能导致网站不能正常访问!
为了你能正常使用网站功能,请使用这些浏览器。

提高SPI时钟时通信异常的案例分享

[复制链接]
eefishing 发布时间:2020-7-6 12:38
有人采用STM32H743ZI芯片的SPI外设跟ADC器件通信,发现一旦SPI的SCK时钟超过25MHz时,比如50Mhz,就会发生读取数据失败,并提示Busy忙信息或ERR错误信息。反正只要串行时钟不超过25Mhz,收发都很正常。
1 p8 Y) B( ~& u9 J( ]% ~
但是STM32H743芯片手册上明白地说了SPI时钟最高可达150MHz,这会是什么原因呢?

! `0 V% I; a: ~& Y
根据他所提到的异常现象初步判断,不论他的硬件方面还是软件配置方面都应该没有很大的问题,不然根本没法通信。像这种情况有可能是下面几种原因之一或组合原因【当然不仅限于这些】:

- s$ [$ n: E' Q' l$ W: |, f$ x
第一种情况就是通信速率明显提高时,由于通信速率加快,而接收处理的相关代码本身所用时间相对固定,这样可能导致不能及时读走数据而发生溢出,尤其是基于查询方式或中断方式接收处理时。这时我们可以考虑对接收代码做进一步的精简优化,压缩接收处理时间,或者改用DMA方式进行数据的收发。
4 {& s5 W3 ^1 P6 m/ |/ e' d# K6 S2 r
第二种情况就是当通信速率明显提高时,跟外设复用的GPIO输出速率档位的配置没有跟上来。以本案例来说,当我们将SPI的时钟上到50MHz甚至更高时,若相应的GPIO的输出速率配置还维持在相对低速水平,与实际输出需求不相匹配时往往就会出现异常。
6 ^5 [! M8 U8 o
11.jpg

3 `9 g1 l5 s+ I* u+ B8 d# j
关于这个配置,如果使用STM32CubeMx配置的话就非常简单,通过菜单选择即可完成。如下图所示:
: M: K3 @5 a$ c6 x; n, p
22.jpg
: D4 }% f& `& M! X6 c  W+ A5 K
# A6 `; m- |8 ?. S
第三种情况就是当通信速率明显提高时,即使相应的GPIO输出能力配置也匹配了,但有些情况下还是有可能出通信异常的问题。我们知道,当GPIO输出速率越来越高的时候,GPIO模块带来的噪声也越大,作为通信口时其信号质量也会随着通信速率的提升而变差,当然,此时芯片所需的功耗也随之增大。对于很多STM32系列芯片,当GPIO输出速率达到一定程度时,建议开启片内GPIO补偿单元。【下面截图是两个STM32系列关于GPIO补偿单元的介绍文字】

3 G" e/ J( N! W( P& L+ i/ `: x& f
33.jpg

+ ]$ _* e7 H. C' V: M! F; K  p
该GPIO补偿单元的作用就是通过控制IO口的输出斜率,降低GPIO的噪声对整个电源的影响并尽力改善信号质量,所以当我们基于STM32芯片实现较高速率的通信时,比方50Mhz甚至上百兆的SPI或USB通信时,如果芯片有GPIO补偿单元的话,建议将其开启。顺便提醒下,使用GPIO补偿单元的话,往往对电源电压有相应要求,具体依手册而定。

' C7 P" E" w& i9 k, X/ I
下面是分别基于STM32F4和STM32F7系列的HAL库相关开启GPIO补偿单元的函数。
8 r% X0 m* z+ `1 h4 C
44.jpg

, `8 k" O; l, G1 E. r
至于本案例异常的真正原因是什么呢?后来经确认属于上面提到的第二种情况,GPIO输出速率挡位选择与实际输出需求不匹配,稍加调整配置就好。

$ d( v/ h" b7 e' L$ u; m* x) G5 t4 O
! S8 m  d( `$ P% N, B* L8 W3 Q* j
收藏 评论0 发布时间:2020-7-6 12:38

举报

0个回答

所属标签

相似分享

关于意法半导体
我们是谁
投资者关系
意法半导体可持续发展举措
创新和工艺
招聘信息
联系我们
联系ST分支机构
寻找销售人员和分销渠道
社区
媒体中心
活动与培训
隐私策略
隐私策略
Cookies管理
行使您的权利
关注我们
st-img 微信公众号
st-img 手机版