也许STM32的RTC晶振真的被误会了...

2019-12-09 19:15发布

本帖最后由 rosicky0301 于 2014-1-4 12:36 编辑

最近在使用STM32做产品,也对它的RTC晶振的选型及外部电容的选择有一些困惑,于是上网搜索。搜索到的结果中,最多的是抱怨STM32的RTC晶振不容易起振,RTC计时不准,或者对晶振的质量很挑。
我大致总结了网上的几种解决方案:
1.在晶振管脚两端并联1M以上电阻,以增加STM32对晶振的驱动能力
2.使用有源晶振
3.使用专用RTC芯片
4.还有一些说换个晶振就行了
5.再有专业一些的说PCB布线有问题

其实,无论是用STM32的RTC晶振还是系统主晶振,大家不妨先仔细阅读STM32官方的关于晶振设计的手册,手册上写的很清楚,选择晶振的要点是什么:
1.增益裕量,通过给定的公式来计算,决定晶振是否起振,计算结果如果>5就可以起振,<5就肯定不会起振。主要相关参数是ESR和CL,至于晶振参数的准确度,肯定大厂晶振会好一些。
2.晶振的负载电容,跟RTC计时的精度有关。通过晶振标称的CL可以求得外部负载电容应该选择什么大小的。6pF的晶振,未必就一定用6pF或10pF的外部电容就可以,这个需要计算。
3.外部电阻,手册里写的是串联电阻来限制驱动能力,其实对于使用杂牌晶振的来说,并联1M以上电阻增加驱动能力还是比较现实的。
4.对于不善计算或懒惰的同学,可以选择手册里推荐的晶振型号,但是外部电容还是需要自己计算求出。

手册里没有着重强调,但是也很关键的是PCB的走线,首先晶振走线不能离STM32太远,其次两根线应该是等长线,再就是晶振周围地线要环绕一圈防止干扰。
至于很多同志们说换个晶振就好了其实是晶振参数不一致造成的,其最根本的原因就是手册里写的增益裕量的计算。
大家能够通过手册明显看到LSE部分的增益裕量都是个位数,而HSE部分的增益裕量都是70+,这也解释了为什么HSE很少有不起振的,而LSE不起振的情况经常发生,大家可以从增益裕量这一最基本的参数来寻找原因。

我也是通过自己的体会来总结一下,未必都对,希望能对深陷STM32的RTC晶振门的同志们有所启发。
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
56条回答
mcu_mouse
1楼-- · 2019-12-11 19:53
被这个害过,换晶振。换电容。改PCB走线,也用过手册上推荐的晶振。
还是有那个问题,有的板子有时能起振,有时不能起振。每次1K的量,基本上有10%的不良。
说老实话。这个肯定是STM存在问题的。我用DS1302还有用S3C2410的RTC,它们的时钟晶振随便用。根本没有STM32的这么扯蛋。。。。
miraclelife
2楼-- · 2019-12-11 23:19
完全按照手册的选型还是会有不起振的路过....
caizhiwei
3楼-- · 2019-12-12 00:42
 精彩回答 2  元偷偷看……
heky
4楼-- · 2019-12-12 03:08
N个人说解决了,结果最多过一年,很多lz跑回来自己骂娘。
LZ,你先用上几十K的量再下论断吧。
wy2000
5楼-- · 2019-12-12 08:28
LZ一定没批量用过,学术派!
如果你不用那几个6P负载电容的晶振,你试试看。一定叫你痛不欲生。100次上电可能99次好的,1次就直接死在那里。1000台机器检测让你反复修的话,非抓狂不可。首次批量使用,用了EPSON的晶振,反复检测还有0.5%左右的会有不起振的状况出现。不要说其他的了。吹牛谁不会。很多经验都是不靠谱的。用严格筛选的器件和严把质量关才是正道。
leirui001
6楼-- · 2019-12-12 10:12
也许是ST现在修订一定工艺或技术没告诉我们而已

一周热门 更多>