晶鸿兴科技 晶鸿兴科技专业晶体制造商

136 8263 7727
首页 > 新闻中心 > 知识分享

晶振在PCB上的设计与工作原理

发表时间:2023/03/20 阅读量:557 来源: 晶鸿兴科技

    一、PCB上晶体振荡电路设计步骤

    这里主要有4个简单的步骤:

    1、选择晶体振荡器

    选择晶体振荡器需要考虑到以下3个因素:

    可拉性与功耗

    振荡器对频率变化的功耗启动时间与封装尺寸

    上电后达到稳定振荡所需要的时间成本

    1)可拉性与功耗

    一般来说,拉力低的晶体振荡器需要较大的负载。每个振荡周期都必须要释放电容的能力,因此更大的负载电容意味着更高的功耗损耗。

    很多微控制器的datasheet中都会有推荐负载电容的最大值,这样的话可以减低驱动电路中的功耗。

    2)振荡器对频率变化的功耗启动时间与封装尺寸

    较小的晶体振荡器封装具有较大的ESR,较大的ESR会提供较大的临界增益(gm_crit),从而降低增益宽=裕度。

    增益裕度降低意味着晶体需要更长的时间才能启动。

    3)上电后达到稳定振荡所需要的时间成本

    其实很多时候性能和成本并不是强关联,如果在满足性能下,可以选择成本相对较低的晶体振荡器。


    2、检查微控制器是否可以驱动晶体振荡器

    通常来微控制器的datasheet中会提供一些关于怎么选择晶体振荡器。这些参数与临界增益由关,临界增益是微控制器电路启动晶体振荡器所需的最小增益。

    有的datasheet还会提供一组给定频率和负载电容的晶体振荡器允许的最大的ESR。

    如果微控制器数据表提供振荡器跨导(通常以uA/V为单位)或最大临界增益,那么我们需要计算晶体的临界增益并检查微控制器是否可以驱动它。

    下面为临界增益计算公式:

    临界增益公式

    在这个公式中:

    F是晶体振荡器的标称频率

    ESR是晶体的等效串联电阻

    CO是晶振并联电容

    CL是晶体的标称负载电容

    临界增益是晶体的一个属性,这些参数在晶体的数据手册中。

    接下来计算增益裕度。如果增益余量大于5,则振荡器将可靠启动。更大的增益余量意味着更快的振荡器启动。

    晶体振荡器的启动条件:增益余量大于5,如下公式所示:

    晶体振荡器的启动条件

    下面为增益裕度计算公式:

    增益裕度

    或者,一些微控制器数据表提供了最大临界增益gm_crit_max。在这种情况下,gm_crit必须小于gm_crit_max。

    如果微控制器不满足驱动晶振的要求,就需要重新选择晶体振荡器。

晶振PCB.webp.jpg

    3、晶体振荡器的功耗

    datasheet中会指定了晶体的驱动电平(DL),驱动电平基本上是晶振正常工作时的最大额定功率。

    驱动电平的粗略估计可以用下面这个公式计算:

    驱动电平驱动电平计算公式

    在上面这个公式中:

    △V是峰峰值振荡器电压——最坏的情况:△V=Vcc

    如果估计值低于晶体振荡器的额定驱动电平,则直接进行下一步。

    符合要求的驱动电平

    如果估计值高于晶体振荡器的额定驱动电平,你可以改进估计值或者重新另外的晶体振荡器。


    4、选择负载电容CL1和CL2

    第一次设计晶体振荡电路的时候,先假设两个负责电容是并联的。选择了CL1=CL2=0.5*CL,但经过验证过后,这是错误的。

    负载电容是晶体两端所需的电容,因此CL1和CL2串联。负载电容的计算公式如下所示:

    负载电容的计算公式

    将负载电容的计算公式简化一下,简化后的公式如下所示:

    简化后的负载电容计算公式

    Cstray是来自微控制器引脚和走线电容的杂散电容的累积,很多有经验的工程师建议,将这个值估计为5pF左右。

    则公式为以下:

    负载电容公式

    一些微控制器数据手册提供了更准确数据一一例如,msp430f22x2系列指定了1pF的杂散电容,非常适合其低功耗模型。


    二、PCB中晶体振荡电路设计

    这里希望通过PCB布局来最小化振荡器和外部信号之间的耦合,因为高频耦合会激发晶体振荡器的高次谐波,晶振是干扰外部电路的噪声源。

    具体有以下几点需要注意:

    1、晶体振荡器靠近微控制器

    短走线具有低互感和电容,长走线具有高互感和电容。使晶体靠近微控制器可以缩短走线,从而减少耦合。所以走线的长度尽可能短,但不能与其他信号线交叉。

    2、振荡器电路与高频电路隔离开

    路由非振荡器信号时,高频电路要远离振荡器电路。也可以考虑使用带有通孔的铜迹线,围绕着振荡器电路,这将减少外部信号线和振荡器之间的互感。

    振荡器电路与高频电路隔离开

    通常的做法是将振荡器电路下方的接地层分开,仅在一点点连接分离的接地层,就在微控制器接地旁边。这可以防止来自其他信号源的返回电流通过振荡器使用的接地层。

    3、晶振靠近CPU芯片摆放,但要尽量远离板边。

    因为内部石英晶体的存在,由于外部冲击或跌落容易损坏石英晶体,从而造成晶体不振荡,在设计可靠的安装电路时要考虑晶体,靠近CPU芯片的位置优先放置远离板块的一面。

    (圆柱晶振)外壳接地后,加一个与晶振形状相似的长方形焊盘,让晶振“平放”在这个焊盘上,并在焊盘的两个长边附近开一个孔(孔要落在焊盘上,最好用多层焊盘代替孔,两个多层焊盘要接矩形焊盘),然后用铜线或其他裸线将晶振“箍”起来,铜线的两端焊接在你开的两个孔或焊盘上。这样可以避免高温焊接对晶振的损坏,保证良好的接地。

    4、手工或机器焊接时,要注意焊接温度

    晶振对温度敏感,焊接时温度不宜过高,加热时间尽量短。

    5、耦合电容应尽量靠近晶振的电源管脚放置

    放置顺序:根据功率流向,按电容值从小到大排列,电容最小的电容值最接近电源引脚。

    6、晶振外壳接地

    晶振外壳接地(如果接地影响负载电容的话,就不能接地),既可以从晶振向外辐射,也可以屏蔽外界信号对晶振的干扰。

    7、不要在晶振下方布线,确保完全铺设好地线

    在晶振300mil范围内不要布线,以免晶振干扰其他布线、器件和层的性能。

    8、时钟信号的走线尽量短,线宽要大一些

    时钟信号的走线尽量短,线宽要大一些。在布线长度与热源的距离之间找到平衡点。


    三、示例1∶为STM32设计8MHZ晶体振荡器

    1、选择晶振

    STM32F427数据手册中要求:

    对于4-26MHz晶体,Gm_crit_max=1mA/V

    频率容差必须为+/-500ppm或更好

    CL1和CL2建议在5pF到25pF之间

    这里我们选择7A-8.000MAAJ-T,虽然STM32的引脚间距为0.5mm,但晶振的尺寸小,可以放置在靠近在STM32的位置。

    7A-8.000MAAJ-T晶振的特性:

    CL=18pF

    ESR=60Ω

    频率稳定性=50ppm

    频率容差=30ppm

    CO=7pFmax

    驱动电平(DL)=500uWmax

    2、检查微控制器是否可以驱动晶振,计算gm_crit(增益裕度)∶

    gm_crit计算公式

    所以gm_crit低于Gm_critmax,振荡器电路将可靠启动。

    3、晶振可以处理功率损耗吗?

    这里粗略估计电路的驱动电平∶

    驱动电平计算公式

    计算得DL=267uW,低于晶体允许的最大驱动电平500uW。

    4、选择负载电容CL1和CL2

    假设Cstray=5pF,则∶

    负载电容公式

    CL1=26pF

    STM32建议将CL1和CL2保持在25pF以下,所以可以选24pF的电容。


    四、示例2∶为ATMEGA328选择16MHZ晶体振荡器

    ATMEGA328

    1、选择晶振

    ATMega328数据手册的要求:

    16MHz的最小电压为3.78V,以适应安全操作。要驱动16MHz时钟,我们必须在3.78V或以上,对于本设计,我们在5V下工作。

    CL1和CL2建议在12pF到22pF之间

    ATMega328数据手册

    这里选择9B-16.000MAAE-B晶振。9B-16.000MAAE-B晶振的特性参数如下所示:

    CL=12pF

    ESR=30Ω

    频率稳定性=30ppm

    频率容差=30ppm

    C0=7pFmax

    驱动电平(DL)=500uWmax

    2、检查微控制器是否可以驱动晶振

    ATMega328的数据表中没有跨导规范,这里就必须让开发人员设置好保险丝,以便在填充PCB后启用振荡器。

    3、晶振可以处理功率损耗吗?

    粗略估计电路的驱动电平(DL)∶

    驱动电平计算

    驱动电平(DL)=545uW。

    驱动电平估计值太高。但是,如果选择CL1并且表明设计的功耗是可以承受的,就可以改进这个估计值。

    4、选择负载电容CL1和CL2

    假设Cstray=5pF,则∶

    负载电容计算

    CL1=14PF。