单片机如何才能不死机之内外部时钟

发布者:德州小孙最新更新时间:2023-03-17 来源: zhihu关键字:单片机 手机看文章 扫描二维码
随时随地手机看文章

1. 前言

时钟是嵌入式系统中非常重要,但又常常被忽视的地方。它的成本只占整个系统的一个零头,但由于时钟的停振,或其它异常最终导致厂商付出高昂代价的案例却并不少见。下面我们看一下在时钟设计中应该注意的一些问题。

2. 寄存器配置

现在单片机一般会支持四种时钟工作模式:内部低频时钟,内部高频时钟,外部低频时钟,外部高频时钟。低频时钟一般可经由单片机内部的锁频环倍频到高频时钟。(为啥这么折腾,不直接用高频时钟呢?a. 用的最多的32.768 kHz 低频时钟,经过15次分频后正好是1 Hz,可以准确的计时。b. 低频时钟功耗更低。c. 提高EMC性能。在低频时钟被瞬间干扰掉几个振荡周期的情况下,锁频环 (FLL) 仍能保证输出稳定,程序运行不受影响。)

一般单片机上电后默认工作在内部时钟,需要通过寄存器配置切换到其它时钟模式。这里需要注意,需要通过查询监控寄存器状态,来确认时钟工作模式。在实际项目中确实发生过电路板上加了外部晶振,但由于寄存器配置错误,系统仍工作在内部时钟的情况。如果配置中有不同的增益模式 (High Gain, Low Gain, or High Drive, Low Drive),要注意在不同模式下,单片机内部时钟电路对外部时钟具有不同的驱动能力。以STM32F030R8为例,在LSE 的Low Drive模式下,内部时钟电路的跨导为5uA/V。在LSE 的High Drive模式下,内部时钟电路的跨导为25uA/V。当然高的驱动能力对应着更高些的功耗。如果对功耗没有太多要求,又需要稳定的时钟振荡,可以选择High Gain, 或 High Drive 模式。

3. 时钟精度

内部时钟一般由阻容振荡电路构成,精度相对要差一些。一般厂家出厂标定 (Trim, or Calibration) 后,全温度范围内能达到 3 - 5% 的精度。如果我们基于内部时钟源去做串口通信等应用,要注意不能使用过高波特率,而且要考虑如果时钟在精度变得最差的情况下仍能正常工作,而不是仅仅在常温下进行一下简单的测试。如果实际工作电压与手册中的标定电压不同,还需要在烧写代码时重新做时钟的标定。

外部时钟以最常用的晶体振荡器 (Crystal Quartz) 为例。晶体并不是精确的振荡在标称频率上。如果需要高精度的计时,需要考虑其精度受以下几方面影响:

a. 标称公差 (Frequency Tolerance)。

b. 负载电容 (Load Capacitance)。如下图所示的例子为一个负载电容为12.5pF的晶体,当负载电容变化时其振荡频率偏差的随动特性:


c. 温度漂移。下图是一个比较典型的音叉型晶体振荡频率偏差随温度变化的曲线:


它可以用抛物线方程描述为:

Fdev = B( T - T0 ) + K

Fdev 为晶体在温度 T 的频率偏差 ∆f/f0,单位为ppm,即百万分之一。

B 为抛物线系数,跟选取的晶体有关,上图中的B为 -3.5×(10)^(-8)/℃²,即-0.035ppm/℃² 。

T0 是曲线的转折温度点,一般是 25 ±5 ℃ 。

K 为晶体在转折温度点的频率偏差。

可以看到环境温度的变化对晶体的振荡频率有较大的影响。如果需要高精度,就需要考虑温度补偿。我们千万不要小看几个ppm的影响。要知道如果有 5ppm 的偏差,那么一天会积累 60*60*24*5ppm = 0.432秒 的误差。插句题外话:仅仅在智能电表领域,由于我们没有性价比高的高精度时钟芯片,日系厂商所获得的垄断利润还是很惊人的。国货当自强!

4. 可靠起振

下图是一个典型的单片机使用外部晶体振荡器的电路。


Rf: Feedback Resistor,反馈电阻。其作用是使反相放大器工作在线性放大工作区。

Rs:Series Resistor, 串行电阻。其作用是限制流过晶体的电流,以免损坏晶体。

CL1, CL2: 负载电容。

有的单片机内部集成了其中一个,或多个元件。

可靠起振需要考虑以下几个方面:

a. 反馈电阻 (Rf),选用单片机手册中的推荐值即可。

b. 负载电容 (CL1, CL2),应该满足公式

CL – Cs = CL1 x CL2 / (CL1 + CL2)

CL (Load Capacitance): 晶振厂家给出的负载电容值。

Cs (Stray Capacitance): 为晶振两引脚之间的寄生电容(分路电容,shunt capacitance,晶体手册中 会给出),加上PCB杂散电容。

CL1, CL2:晶振两脚对地电容。其电容值需要我们根据前两者计算得出。

此公式可理解为:

晶振两引脚对地电容并联 + 晶振引脚间寄生电容 + PCB杂散电容 = 晶振负载电容

c. 增益裕量 (Gain Margin)

Gain Margin = gm / gmcrit

gm 为反相放大器的跨导。一般由单片机厂家给出。

gmcrit 由晶体参数决定。

gmcrit = 4 x ESR x (2πF)² x (C0 + CL)²

ESR:Equivalent Series Resistance.

C0 :Shun Capacitance.

CL :Load Capacitance.

保证可靠起振需要Gain Margin > 5

d. 激励功率 (Drive Level)

晶振手册会给出最大值。我们要保证激励功率不要超出此最大值。

Drive Level = ESR x I²

I: 为流经晶振的电流。可以用带电流感应测量探头的示波器直接测量晶振管脚得出。也可以通过通过测量反相放大器输入端引脚电压,然后计算间接得出 (参考附录应用手册)。

e. 看门狗 (Watchdog)

单片机上电一般会工作在内部时钟,在上电过程中干扰会比较强。使能的看门狗能在时钟没有起振的情况下可以强制系统复位,时钟再次起振。需要强调的是要注意检查代码中(包括厂家提供的启动代码)有没有先停掉,之后再打开关门狗的地方。

在实际应用中,有的官方代码也会犯这种错误:为了简化启动代码,先把看门狗关掉,初始化完成后再打开。我们要知道这样做是实验室风格的,是有很大隐患的。在关掉的瞬间如果正好碰到强干扰,会导致单片机直接挂掉。这种问题很难发现,但真的会发生!


关键字:单片机 引用地址:单片机如何才能不死机之内外部时钟

上一篇:单片机(MCU)如何才能不死机之对齐访问(Aligned Access)
下一篇:意法半导体发布STM32WBA52无线微控制器 具有SESIP3 安全性,为物联网量身定制

推荐阅读最新更新时间:2024-11-10 13:34

51单片机实验2:led灯闪烁
开发板led模块电路图如下: 在keil中,sbit的声明要放在全局变量的位置,若放在函数中,会报错。 延时函数的变量使用unsigned char,而不是int,因为char所占空间为1字节,为int所占空间为4字节,因此使用char可以节约内存。但是unsigned char仅能表示0~255,所以延时函数中的参数最大为255,若要更大,则使用int。 #include reg52.h #include intrins.h #define uc unsigned char sbit led1=P2^0; void delay(uc n) { uc i,j; for(i=1;i =n;i++) fo
[单片机]
51<font color='red'>单片机</font>实验2:led灯闪烁
最简单的程序怎么编写?(看三种单片机的闪烁灯程序套路
了解一下小小的编程序怎么回事。
[单片机]
最简单的程序怎么编写?(看三种<font color='red'>单片机</font>的闪烁灯程序套路
单片机的分类 三种常见分类方法
单片机的主要分类: 1、 按应用领域可分为:家电类,工控类,通信类,个人信息终端类等等; 2、 按通用性可分为:通用型和专用型。 通用型单片机的主要特点是:内部资源比较丰富,性能全面,而且通用性强,可履盖多种应用要求。所谓资源丰富就是指功能强。性能全面通用性强就是指可以应用在非常广泛的领域。通用型单片机的用途很广泛,使用不同的接口电路及编制不同的应用程序就可完成不同的功能。小到家用电器仪器仪表,大到机器设备和整套生产线都可用单片机来实现自动化控制。 专用型单片机的主要特点是:针对某一种产品或某一种控制应用而专门设计的,设计时已使结构最简,软硬件应用最优,可靠性及应用成本最佳。专用型单片机用途比较专一,出厂时程序已经一次性固化
[单片机]
单片机(51) 循环流动数字“16617200230”
#include regx51.h unsigned char code number ={0x06,0x7d,0x7d,0x06,0x07,0x5b,0x3f,0x3f,0x5b,0x4f,0x3f,0x06,0x7d,0x7d,0x06,0x07,0x5b,0x3f,0x3f,0x5b,0x4f,0x3f}; unsigned char code com = {0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf,0x7f}; void delay_ms(unsigned char i){ unsigned char n=0; while(i--){ for(n=0;n 123;n++);
[单片机]
51单片机控制的智能台灯设计
功能及概述 本系统组成如图一所示,主要由三部分组成: 传感器及信号处理部分:检测人体辐射红外信号及光强信号经过处理后变成可处理的数字信号 以80C51组成的中央处理单元:处理信号并发出控制命令 提醒电路及灯光控制电路 :给出提醒信号并根据80C51给出的命令控制灯光 整个系统是以80C51控制下工作的。其工作过程为:当环境光比较强时,光敏电阻阻值比较小,信号处理电路检测到低电平信号,禁止热释电红外传感器工作,省去了80C51处理过程。当环境光比较弱时,光敏电阻阻值变大,信号处理电路接收到高电平,从而启动热释电红外传感器工作。热释电红外传感器1探测比较远的距离,当人体进入到传感器1的控测范围内且光强较弱时,信号检测电
[单片机]
51<font color='red'>单片机</font>控制的智能台灯设计
学习51单片机晶振这21问题搞懂了学单片机就简单了
在初学51单片机的时候,总是伴随很多有关与晶振的问题,其实晶振就是如同人的心脏,是血液的是脉搏,把单片机的晶振问题搞明白了,51单片机的其他问题迎刃而解…… 有关51单片机有关晶振的问题一并总结出来,希望对学51的童鞋来说能有帮助。 一,为什么51单片机爱用11.0592MHZ晶振? 其一:因为它能够准确地划分成时钟频率,与UART(通用异步接收器/发送器)量常见的波特率相关。特别是较高的波特率(19600,19200),不管多么古怪的值,这些晶振都是准确,常被使用的。 其二:用11.0592晶振的原因是51单片机的定时器导致的。用51单片机的定时器做波特率发生器时,如果用11.0592Mhz的晶振,根据公式算下来需要定时器设
[单片机]
学习51<font color='red'>单片机</font>晶振这21问题搞懂了学<font color='red'>单片机</font>就简单了
采用单片机和传感器实现温湿度检测系统的设计
引言 随着社会经济的发展和科学技术的不断进步,许多情况下都需要对环境的温湿度进行限定,因此,必须在某些特定环境安装温湿度报警器以进行监控。为此,本文利用集成温湿度传感器HM1500的测温快速、使用简便等特点,同时结合MSP430单片机强大的功能,设计了一个监控系统来对温湿度进行实时监控以进行超限报警。本系统测量准确、调试方便、可实时记录报警信息、方便工作人员排故,并可广泛应用于条件恶劣、人员不便进入的场合。 1 系统结构和总体设计方案 本系统的总体设计方案如图1所示。本方案采用分别设计温度和湿度采样电路的方法,将集成温度传感器AD590采集得到的电流信号和湿度传感器HM1500采集到的电压信号转换为给定范围内的电压信号。然后由
[单片机]
采用<font color='red'>单片机</font>和传感器实现温湿度检测系统的设计
基于单片机设计的无线终端温度测试系统
  随着人们生活水平的提高,食品的安全卫生越来越受到人们的重视。每年技术监督部门都要对全市各冷库食品进行抽检,检查后发现市民每年消费的农产品及其他易腐食品中有很大部分就是因为冷藏、冷冻未达到要求而变质的,因此对冷库温度的实时监测对于贮藏品的质量保证显得尤为重要。由于ZigBee应用的低带宽要求,ZigBee节点可以在大部分时间内为睡眠模式,以节省电池能量。当接收到广播信标时被唤醒并迅速发送数据,然后重新进入睡眠模式。ZigBee可以在15毫秒或更短的时间内由睡眠模式进入活动模式,因此即使处于睡眠的节点也可以实现低时延的目的。   系统硬件电路设计   单个冷库温度无线监测系统的下位机主要是由单片机与温度传感器、无线射频收发器、键盘
[单片机]
基于<font color='red'>单片机</font>设计的无线终端温度测试系统

推荐帖子

altare的nios怎么样啊?
altare的nios怎么样啊?大家说的白话点太专业了看不懂我好久以前建议管理员建一个软件方面的板块比如我现在要学nios软件设计要用c和C++资料在这儿就很难找啊altare的nios怎么样啊?我现在用的是xilinx的microblaze个人感觉挺好用!它一般有什么用刚接触啊他用来做什么东西比较好比较方便啊回复沙发daicheng的帖子
heningbo FPGA/CPLD
常用芯片分享
VGA接口常用的芯片型号:LT8712EXI/LT8712EXC/LT8712XLT8711VLT8612EX-E3/LT8612X-M/LT8612UX/LT8612SXLT8522X/LT8522EXVGA接口的芯片详述:LT8712EXI/LT8712EXC/LT8712X是一款C/DP1.2到HDMI2.0和VGA转换器,设计用于将USBC类型源或DP1.2源连接到HDMI2.0和VGA接收器。提供两个数字音频输出接口:I2S和SPDIF。支持E
mcu01 玄铁RISC-V活动专区
献给电子类的大学生---一点心得 转贴
献给电子类的大学生---一点心得很久没来这里转转,今天发点牢骚吧,本人专职电源,其他系统也做,主要是硬件,软件丢光了.五年前的10月份开始,我也是一个即将毕业的大学生(二流的),同样在为工作而到处奔波,经过一个月的奔波应聘进入联想深圳研发中心,现在在一家外企做电源FAE.结合大学及这几年的想法谈谈大学的学习.大学--我的理解是大大的学,能精固然是好,但最重要的是能博而不要求懂,工作的时候碰到问题就会知道说我当初学过什么,应该从哪里找资料,知道从哪入手那么问题自然就简单了.有句话
fighting 模拟电子
一种非接触式扭矩测试系统的设计
在旋转动力传递系统中,扭矩是众多机械测量中的一个重要的参数。由于在这类系统中的转动部件高速旋转的特点,相比传统的接触式测量方法,使得扭矩测量中的传感器供电和数据传输过程比较困难。目前,传统的扭矩测试从供电方式上可分为接触式和非接触式供电,前者常采用导电滑环来实现,但由于其采用摩擦接触,因此不可避免的产生发热和磨损,影响了转轴的转速及滑环的使用寿命,还有些系统采用电池供电,而电池储能有限,给测量带来不便,因此,非接触式供电成为解决以上问题的有效方法。目前常用的非接触式供电有光电能传输,
一世轮回 综合技术交流
一个好用的MPU6050程序
发一个网上买的MPU6050程序,超级好用。https://download.eeworld.com.cn/detail/pleasemissme/551475一个好用的MPU6050程序感谢分享,学习了
快羊加鞭 下载中心专版
保安队HMI开发板-STM32H7S7(焊接篇)
MCU:STM32H7S7NORFLASH:MX25UW256PSRAM:APS256XXNEMMC:THGBMJG6C1LBAIL保安队HMI开发板-STM32H7S7(焊接篇)STM32H7S不是今年刚出的芯片吗?这就有人用上了? 趁热乎
bloody41760 stm32/stm8
小广播
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved