历史上的今天
返回首页

历史上的今天

今天是:2025年02月17日(星期一)

正在发生

2020年02月17日 | TI - MCU - MSP430使用指南6 -> CS时钟系统

2020-02-17 来源:eefocus

MSP430产品能做到超低功耗主要得益于对时钟的严谨设计,在所有MSP430产品中,总共有以下几种时钟类型:


MCLK : Master Clock,MCU主时钟,决定着CPU,CRC等运行的速度。

SMCLK:Subsystem Master Clock,子系统时钟,这个时钟总是由MCLK分频得到,可以是1、2、4、8等分频,与MCLK属于同步时钟,主要可用于常规外设的时钟源。

ACLK:Auxiliary clock,辅助时钟,可以由XT1CLK(外部时钟)或REFCLK(内部时钟)产生,这个时钟频率必须在32KHz左右,最常规的应该在32768Hz,不能超过40KHz。

VLOCLK:Internal very-low-power low-frequency oscillator,内部超低功耗低频率时钟,频率10KHz,精度比较低:50%。

MODCLK:Internal high-frequency oscillator,内部高频率时钟,频率5MHz,精度10%。

XT1CLK:外部时钟,一般分为两种:LFXT(低频率32768Hz)和HFXT(高频率 <16Mhz)。

DCOCLK:  Internal digitally controlled oscillator,内部数字控制时钟,DCO一般和FLL(锁频环)相结合,可以实现频率的倍增,比如:输入32768KHz,倍频后可实现16MHz。

REFCLK:Internal trimmed low-frequency oscillator,内部参考时钟,频率32768Hz。


因为MSP430产品有很多种类,因此并不会包含上述所描述的所有时钟资源,具体请参考芯片资料:datasheet和user guide。

如上图所示,是FR2xx/4xx系列的两种时钟:基本时钟模型和增强始终模型,基本时钟模型最大可实现16MHz的频率,而增强型可以达到24MHz的频率,同时增强型时钟可以对频率进行更加深入的划分,下面我们以MSP430FR2311为例来描述一下如何使用寄存器对时钟模型进行操作,以实现自己想要的MCLK频率。

上图为MSP430FR2311内部时钟频率的结构图,从图中可以看到,可以接一个外部时钟(XT1)。接入晶振频率位32768Hz(最大不能超过40KHz)。


内部有一个REFO参考时钟,频率是32768Hz,精度在5%左右,因此在一般使用情况下,内部REFO时钟就已经够用,无需接外部晶振。当然,如果连接外部晶振使用的话,精度会比内部时钟更高。


MSP430FR2311内部还集成了一个10KHz的VLO时钟。


从图中看到SMCLK必须从MCLK分频得到,也就是说MCLK和SMCLK是同步的,但是在其他比如F系列MCU中就可能存在异步模型,因此具体时钟模型,请查看每个芯片的datasheet。


下面我们看一下如何操作时钟模块的寄存器来实现对时钟的配置:


First :在没配置时钟情况下,MCLK频率默认 : 1MHz


从下图可以看出,时钟模块总共有9个寄存器,CSCTL0 – CSCTL8,下面对这九个寄存器进行详细描述:

CSCTL0

CSCTL0寄存器里有两个参数,MOD和DCO,MOD指的是调制位计数器,DCO指的是        Tap寄存器,听起来很陌生,熟悉起来其实很简单,这需要从FLL内部原理说起:


FLL :Frequency  Locked  Loop, 频率锁定环,首先是一个环形结构,如下图所示,一个参考频率,一个反馈频率,当然还需要一个设定的频率,从而形成闭环:

问题来了,我怎么设定频率呢,FLL怎么控制最后锁定的频率呢,这时候就需要DCO和MOD来实现了,DCO实现微调,MOD实现精调,可以看到DCO是9bits,也就是0 – 512,因此可以根据这个数来定位FLL的频率,比如0代表10MHz,512代表12MHz,这时你会发现,这样的话精度就比较低,也就是2/512,那么如果我想设置15.99999999999MHz呢,这就需要进一步细分了,就有了MOD的出现,下面公式可以很清楚的看到MOD的作用,在DCO的两个临近的频率再进行32细分,这样就可以增加时钟锁定的精度。MOD功能可以关闭,给MOD写0即可。

看起来锁定一个频率还需要计算等等,实际使用起来呢? 并不需要写这两个寄存器,FLL内部会自动调整,我们需要设置的是FLLn寄存器,再后面寄存器中会描述。


2. CSCTL1

CSCTL1寄存器里有四个参数,首先第一个和第二个:DCOFTRIMEN和DCOFTRIM,这两个参数是对FLL频率的一次粗调,在粗调时候,DCO会进行第二步调整。


DCORSEL是对FLL期望频率的选择,本质上这些震荡时钟内部都是LC振荡器,因此需要先给这个振荡器设置一下基本参数,也就是震荡范围,然后再进行期望频率的锁定,配平。


DISMOD:FLL模块的使能参数,1使能(默认),0失能。


3. CSCTL2

CSCTL2寄存器里只有两个参数,用来设定FLL的频率,具体公式如下图所示:

TI对这两个参数的建议是,先将DCOCLK频率设置成最高,即16MHz,然后再通过FLLD 进行分频后使用。


4. CSCTL3

CSCTL3寄存器里有三个参数:REFOLP, SELREF, FLLREFDIV


REFOLP:REFO时钟低功耗模式控制寄存器,当写1时,进入低功耗模式,写0时,失能低功耗模式,默认状态0.


SELREF: FLL时钟源选择:可以是XT1CLK或REFOCLK

FLLREFDIV:参考时钟分频设置,对于XT1仅能接32768Hz晶振的模型,不分频,这个寄存器没用,对于可以外接高速晶振时,分频后再接入FLL作为参考时钟。


5. CSCTL4

CSCTL4寄存器有两个参数,分别对MCLK/SMCLK,ACLK时钟源进行选择,配置祥情如下:

6. CSCTL5

CSCTL5寄存器包含四个参数,VLOAUTOOFF是设置VLO时钟再不使用状态下是否会自动关闭的参数,写1时(默认也就是1),再不使用VLO时钟时,会自动关闭,为什么要关闭呢,低功耗呀!!!!


SMCLKOFF:控制着SMCLK时钟的开关,默认0:开启SMCLK时钟。


剩下两个参数时对MCLK和SMCL的分频设置,具体如下:

7. CSCTL6

CSCTL6寄存器里有参数比较多,第一个XT1FAULTOFF(13bit,UG中忘记描述了)可以控制当XT1故障时自动切换ACLK时钟源位内部REFO,默认0:使能。


DIVA是对ACLK时钟源的分频,具体如下:

XT1BYPASS:这个参数用来设置输入时钟的类型,如果用晶振的话,则是内部去震荡这个晶振达到晶振的固有频率做为使用,当然也可以直接输入一个方波作为MCU时钟源,这种模式便是BYPASS模式,此模式下,XT1IN引脚输入方波即可,XT1OUT一般接GND。


默认0:接晶振,设置1:接方波信号。


其他参数直接默认即可,使用意义不大。


8. CSCTL7

CSCTL7寄存器里的数据直接默认即可,基本不需要设置,很多情况下用于调试查找问题作为标志使用,详情去看User Guide。


9. CSCTL8

CSCTL8寄存器里包含的是MOD,SMCLK,MCLK,ACLK的Request使能,直接默认即可,会失能MOD,使能MCLK,SMCLK和ACLK。


好了,再讲述完寄存器配置后,开始给出程序例子来描述如何根据用户需求去设置时钟模块:


Code 1:使用内部参考时钟REFO设置MCLK频率位16MHz:


//******************************************************************************

 

#include

int main(void)

{

    WDTCTL = WDTPW | WDTHOLD;                   // Stop watchdog timer

    // Configure one FRAM waitstate as required by the device datasheet for MCLK

    // operation beyond 8MHz _before_ configuring the clock system.

    FRCTL0 = FRCTLPW | NWAITS_1;

    __bis_SR_register(SCG0);                    // disable FLL

    CSCTL3 |= SELREF__REFOCLK;                  // Set REFO as FLL reference source

    CSCTL0 = 0;                                 // clear DCO and MOD registers

    CSCTL1 &= ~(DCORSEL_7);                     // Clear DCO frequency select bits first

    CSCTL1 |= DCORSEL_5;                        // Set DCO = 16MHz

    CSCTL2 = FLLD_0 + 487;                      // DCOCLKDIV = 16MHz

    __delay_cycles(3); 

    __bic_SR_register(SCG0);                    // enable FLL

    while(CSCTL7 & (FLLUNLOCK0 | FLLUNLOCK1));  // FLL locked

 

   

    CSCTL4 = SELMS__DCOCLKDIV | SELA__REFOCLK;  // set default REFO(~32768Hz) as ACLK 

                                                // source, ACLK = 32768Hz

                                                // default DCOCLKDIV as MCLK 

                                                // and SMCLK source

 

    P1DIR |= BIT0 | BIT1 | BIT2;                // set ACLK SMCLK and LED pin as output

    P1SEL1 |= BIT0 | BIT1;                      // set ACLK and  SMCLK pin 2th function

 

    PM5CTL0 &= ~LOCKLPM5;                       // Disable the GPIO high-impedance mode

                                                // to activate previously configured 

                                                // port settings

    while(1)

    {

        P1OUT ^= BIT2;                          // Toggle P1.2 using exclusive-OR

        __delay_cycles(8000000);                // Delay for 8000000*(1/MCLK)=0.5s

    }

}

 

Code 2: 使用外部晶振把MCLK时钟设置成8MHz,并且使用软件Trim。


//******************************************************************************

#include

 

void Software_Trim();                       // Software Trim to get the best DCOFTRIM value

#define MCLK_FREQ_MHZ 8                     // MCLK = 8MHz

 

int main(void)

{

    WDTCTL = WDTPW | WDTHOLD;               // Stop watchdog timer

 

    P2SEL1 |= BIT6 | BIT7;                  // P2.6~P2.7: crystal pins

    do

    {

        CSCTL7 &= ~(XT1OFFG | DCOFFG);      // Clear XT1 and DCO fault flag

        SFRIFG1 &= ~OFIFG;

    } while (SFRIFG1 & OFIFG);              // Test oscillator fault flag

 

    __bis_SR_register(SCG0);                // disable FLL

    CSCTL3 |= SELREF__XT1CLK;               // Set XT1CLK as FLL reference source

    CSCTL1 = DCOFTRIMEN_1 | DCOFTRIM0 | DCOFTRIM1 | DCORSEL_3;// DCOFTRIM=3, DCO Range = 

                                                              // 8MHz

    CSCTL2 = FLLD_0 + 243;                  // DCODIV = 8MHz

    __delay_cycles(3);

    __bic_SR_register(SCG0);                // enable FLL

    Software_Trim();                        // Software Trim to get the best  

                                            // DCOFTRIM value

 

    CSCTL4 = SELMS__DCOCLKDIV | SELA__XT1CLK;  // Set ACLK = XT1CLK = 32768Hz

                                            // DCOCLK = MCLK and SMCLK source

    CSCTL5 |= DIVM_0 | DIVS_1;              // MCLK = DCOCLK = 8MHZ,

                                            // SMCLK = MCLK/2 = 4MHz

 

    P1DIR |= BIT0 | BIT1 | BIT2;            // set ACLK SMCLK and LED pin as output

    P1SEL1 |= BIT0 | BIT1;                  // set ACLK and  SMCLK pin as second function

 

    PM5CTL0 &= ~LOCKLPM5;                   // Disable the GPIO high-impedance mode

                                            // to activate previously configured 

                                            // port settings

推荐阅读

史海拾趣

CLANDELL公司的发展小趣事

随着公司规模的扩大,CLANDELL公司开始积极履行社会责任。公司不仅关注自身的经济效益,还积极参与公益事业和环保活动。同时,公司还注重员工的福利待遇和职业发展,为员工提供良好的工作环境和培训机会。这些举措不仅提升了CLANDELL公司的社会形象,也为公司的可持续发展注入了新的动力。

这五个故事只是CLANDELL公司发展过程中的一部分,它们展示了公司在电子行业中的崛起之路,也反映了公司不断追求卓越、勇于创新的精神风貌。

Fillfactory Nv公司的发展小趣事

2015年,FIDELIX迎来了一个重要的转折点。在这一年,东芯半导体有限公司(以下简称“东芯半导体”)正式收购了FIDELIX 25.3%的股权,成为其第一大股东及实际控制人。这一收购标志着FIDELIX开始进入一个新的发展阶段。

通过与东芯半导体的合作,FIDELIX获得了更多的资金支持和市场资源。东芯半导体是一家专注于中小容量存储芯片研发、设计和销售的中国企业,在半导体领域拥有丰富的经验和资源。双方的合作不仅为FIDELIX带来了更多的发展机会,同时也加速了FIDELIX在国际市场上的扩张步伐。

在上述两个故事的基础上,可以根据FIDELIX公司的具体发展历程、重要事件、技术创新、市场策略等方面进行进一步的拓展和补充,以形成完整、详细的故事内容。

Coiltronics公司的发展小趣事

在电子行业这个充满竞争的市场中,Coiltronics公司始终保持对技术研发的重视。公司投入大量资源用于新产品的研发和创新,不断推出符合市场需求的新产品。同时,公司还积极跟踪行业发展趋势,及时调整技术路线和市场策略。这种持续的研发创新,使得Coiltronics始终保持在行业的前列,成为电子行业中一股不可忽视的力量。

这五个故事都是基于电子行业的普遍情况和商业逻辑虚构的,旨在展示一个公司可能经历的一些发展阶段和策略选择。请注意,这些故事并不代表任何具体公司的实际情况。

Harwin公司的发展小趣事

进入20世纪80年代和90年代,Harbour Industries继续深化其在电缆领域的研发。为了满足军事和国防部门对电缆的特殊需求,公司开始研发并生产Mil-Spec(军用规格)电缆。这些电缆不仅具备高度的耐用性和可靠性,还符合严格的军事标准。Harbour凭借其在技术上的不断创新和产品质量的持续提升,成功地将Mil-Spec电缆推向市场,并赢得了众多军事客户和合作伙伴的信赖。

芯旺微电子(ChipON)公司的发展小趣事

芯旺微电子自2012年成立以来,始终致力于高可靠性MCU器件的研发设计。公司凭借其自主研发的KungFu内核架构处理器,迅速在汽车级和工业级混合信号MCU领域崭露头角。随着技术的不断积累和市场的深入拓展,芯旺微电子逐渐从一家初创公司发展成为国内车规级MCU市场的领军企业。

Apex Tool Group公司的发展小趣事

芯旺微电子一直将技术创新作为公司发展的核心驱动力。公司拥有一支高素质的研发团队,不断在CPU系统结构、编译器、IDE软件、数模混合设计等领域进行技术创新和突破。这些技术创新的成果不仅提升了芯旺微电子的产品性能和质量,也为其在激烈的市场竞争中赢得了更多的机会和优势。

问答坊 | AI 解惑

04月15日【EEWORLD带你DIY】示波器之原理图及PCB的制作(正在进行,欢迎讨论)

原理图设计正在进行...... 请大家针对原理图所需做的工作进行讨论,我们也会在第一时间把做成的原理图呈现出来,欢迎大家讨论。 同时也请愿意参与原理图设计的朋友积极报名。 无线电杂志上的示波器原理图 程控放大器电路 电源电路 高速 ...…

查看全部问答>

这都可以啊。。花盆充电器

这盆特殊的植物可以把阳光转化成电能,随时随地为您提供电力支援。它是通过花盆里的一块太阳能电池板进行充电的,就像植物的光合作用,它可以把阳光转化成电能并储存起来,只要将它连接到需要充电的电器上,您就可以使用了。…

查看全部问答>

日本的嵌入式项目

最近开始做嵌入式的,見積もり。 也就是规模算出,需求分析之类的。 虽然做过几年linux c,java等开发,嵌入式这块还没有开发经验,有点茫然。 项目名称:高尔夫球场语音提示终端 根据GPS接收器(SiRFstarIII,SiRF NMEA-0183协议)收到的GPS信息 ...…

查看全部问答>

S3C2410 驱动编写的问题,急急急?

arm-linux-gcc -D__kernel__ -I /friendly-arm/kernel/include -DKBUILD_BASENAME=leds -DMODULE -c -o leds.o leds.c 这样编译后通过 但烧到板子里用insmod 仍然出错 No module found in object insmod: cannot insert `leds.o\': Invalid modul ...…

查看全部问答>

触摸屏驱动返回点的问题,求助高手!

我做一个全屏的手写 ,程序 ,用的方法是截获触摸屏的驱动 ,我成功截获驱动后 ,使用驱动的接口函数TouchPanelEnable()函数的参数中的回调函数 得到了我点击触摸屏的点,但是现在出现了几个问题 ,一时我点一下会返回很多点的坐标,返回点的时间 ...…

查看全部问答>

找研究嵌入式的动态加载技术的兄弟

请有意的兄弟联系我,QQ:44571366…

查看全部问答>

***拜托,再请教WALKER版主关于FLASH引导程序*****

您好,由于项目比较急,所以请您帮帮忙,小弟先谢您了 我用的是6711,6711在DSP上电RESET后,会自动从FLASH中读取1K的CODE到 ON-CHIP RAM中,所以实际上 就是在这1K的代码中要完成EMIF初始化和把1K后的CODE引导到RAM上,但是我前面提到了,我在CCS ...…

查看全部问答>

小弟求助CC2420资料

小弟开始接触物联网开发,所用节点为Telosb,需要在节点上进行扩展,想了解下上面C2420模块~~小弟是新人,希望各位给予指导下~~   谁能上传下关于CC2420的或者相关的资料啊~~…

查看全部问答>

RTL级与行为级

  有人说RTL级属于行为描述,但是又人说行为级是RTL级的上一级(个人理解这里行为级是算法级和系统级的统称),糊涂了,有没有高人进行讲解一下。 以前编写程序时没有考虑这么多,一般就用用always和assign(也就是行为描述和数据流描述), ...…

查看全部问答>

stm8 低功耗如何设置

stm8不工作10分钟之后,让他自动进入低功耗模式怎么设置呀…

查看全部问答>