[讨论] MSP430默认的MCLK、SMCLK、ACLK时钟频率

fish001   2020-9-6 09:07 楼主

使用定时器中断方法测出各个时钟频率。实验所用平台是MSP-EXP430G2 LaunchPad,MCU为MSP430G2553。
1、查阅datasheet。
  手册原文:After a PUC,MCLK and SMCLK are sourced from DCOCLK at ~1.1Mhz (see the device-specific data sheet for parameters) and ACLK is sourced from LFXT1CLK in LF mode with an internal load capacitance of 6pF.
  从上边我们不难发现,主时钟MCLK和子时钟SMLK由内部数控震荡器DCO产生,大约在1.1MHz左右,需要声明一点的是,内部数控振荡器受电源电压和外界温度影响比较大,范围在800kHz~1.5MHz,室温下,3.5V时测得DCO频率为1.04Mhz。辅助时钟ACLK由外部低频晶振产生,一般为32.768kHz。

image-20200906090515-1.png
2、通过寄存器默认设置判定
这里写图片描述
  从上图我们发现这些寄存器初始值并非全0,这样我们可以查看寄存器对应为的含义从而确定各个时钟的默认值。

image-20200906090600-2.png image-20200906090619-3.png
2.1、先确定DCO
  这里写图片描述
这里写图片描述
  从上边我们得到RSELx = 7,DCOx = 3,MODx = 0,然后查看下表:
image-20200906090638-4.png
  从上表得到DCO默认值再1Mhz附近,这与前面所说的一致,范围在800kHz~1.5MHz。
2.2、主时钟MCLK、子时钟SMCLK
image-20200906090704-5.png
  很容易发现MCLK、SMCLK时钟源均来自DCO且分频系数为1,故MCLK、SMCLK默认时钟频率为DCO,大小为1MHz左右。
  同样,辅助时钟ACLK也可以通过查看手册得到其时钟源来自于外部低频晶振,大小一般为32.768kHz。而且430系列单片机大部分辅助时钟默认时钟源均来自外部低频晶振。
3、定时器法
  也可使用一下代码进行验证,例如验证ACLK。

#include <msp430g2553.h>

void main(void)
{
        WDTCTL = WDTPW + WDTHOLD;
        P1DIR |= BIT0;
        P1OUT |= BIT0;
        /*  时钟源ACLK 清计数器 增模式 开启定时器A中断  */
        TACTL |= TASSEL_1 + TACLR + MC_1 + TAIE;
        TACCR0 = 1024;    //频率:32768/1024/2=16Hz
        _EINT();          //开总中断

        while(1)
        {
            LPM3;         //进入低功耗模式3
        }
}
#pragma vector = TIMER0_A1_VECTOR
__interrupt void Timer_A(void)
{
        switch(TAIV)
        {
          case  2:  break;
          case  4:  break;
          case 10:  P1OUT ^= BIT0;  //中断任务
                    break;
        }
}

  将以上代码编译并载入g2553开发板上,能看到红色LED等在闪烁,用示波器测量P1.0端口后,我们发现其频率为15.98Hz。由此往上推断定时器A所使用的辅助时钟的确是外部低频晶振32.768kHz。
总结:
  以上,我们介绍了三种方法判定G2553系统的三种时钟的默认时钟频率,其中第三种方法我们尽可能的动手实践一下,可以很直观的看到系统的时钟频率值。

回复评论 (1)

非常棒,讲的太高了,价值非常高,收获很多啊

点赞  2020-9-19 11:16
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 京公网安备 11010802033920号
    写回复