MSP430教程9:MSP430单片机时钟模块

2020-03-26来源: eefocus关键字:MSP430  单片机  时钟模块

MSP430的时钟模块由低速晶体振荡器LFXT1、高速晶体振荡器XT2(MSP430X11X,MSP430X12X没有)、数字控制振荡器DCO、琐相环FLL(MSP430X16X以上包括)和增强型琐相环FLL+等部件组成。


MSP430X1XX基本时钟模块有三个时钟输入源LFXT1CLK(低速32768Hz,高速450Hz到8MHz)、XT2CLK(450Hz到8MHz)、DCOCLK,提供以下三种时钟信号


1.ACLK辅助时钟:由LFXT1CLK信号经1、2、4、8分频后得到,可以由软件选作各个外围模块的时钟信号,一般用于低速外设。


2.MCLK系统主时钟:MCLK可由软件选择来自LFXT1CLK、XT2CLK、DCOCLK三者之一,然后经1、2、4、8分频得到,MCLK主要用于CPU和系统。


3.SMCLK子系统时钟:可由软件选自LFXT1CLK和DCOCLK(MSP430X11X、MSP430X12X系列,因其不含XT2),或XT2CLK和DCOCLK,然后经1、2、4、8分频得到。SMCLK主要用于高速外围模块。

 

系统频率与系统的工作电压密切相关(MSP430工作电压1.8V~3.6V,编程电压2.7V~3.6V),所以不同的工作电压,需要选择不同的系统时钟。当两个外部振荡器失效时,DCO振荡器会自动被选作MCLK的时钟源。PUC信号之后,DCOCLK被自动选作MCLK和SMCLK的时钟信号,LFXT1CLK被选作ACLK的时钟信号,根据需要MCLK和SMCLK的时钟源可以另外设置。

控制时钟模块的三个寄存器为DCO控制寄存器DCOCTL、基本时钟系统控制寄存器1BCSCTL1、基本时钟控制寄存器2BCSCTL2


1.DCOCTL            

7           6           5        4          3        2        1         0   
 DCO2      DCO1       DCO0       MOD4      MOD3      MOD2     MOD1      MOD0

DCO.0~DCO.2    定义8种频率之一(DCO=0~DCO=8),可分段调节DCOCLK频率,相领两种频率相差10%。

MOD.0~MOD.4   定义在32个DCO周期中插入的fdco+1周期个数,而余下的周期为fdco周期,控制切换DCO和DCO+1选择的两种频率,如果DCO常数为7,表示已经选择最高频率,此时不能利用MOD.0~MOD.4进行频率调整。

DCOCTL POR后初始值为60H。


2.BCSCTL1          

 7         6         5          4            3        2          1         0  
 XT2OFF    XTS     DIVA1       DIVA0       XT5V     RSEL2      RSEL1    RSEL0 

BCSCTL1初始值为84H

XT2OFF            控制XT2的开启和关闭 
    0                  XT2振荡器开启 
    1                  XT2振荡器关闭(默认)

XTS                控制LFXT1工作模式 
    0                  低频模式(默认) 
    1                  高频模式

DIVA1、DIVA0  控制ACLK分频 
   0          0       不分频(默认) 
   0          1       2分频 
   1          0       4分频 
   1          1       8分频

XT5V                此位设置为0 
RSEL0~RSEL2 三位控制内部电阻以决定标称频率 
          0            选择最低标称频率 
         ...            ...... 
          7            选择最高标称频率    


3.BCSCLK2          

7          6        5         4       3          2           1          0  
SELM1    SELM0    DIVM1     DIVM0     SELS      DIVS1      DIVS0       DCOR
SELM1 SELM0     选择MCLK时钟源
     0         0          DCOCLK(默认)
     0         1          DCOCLK
     1         0          LFXT1CLK对于MSP430F11/12X,XT2CLK对于MSP430F13/14/15/16X
     1         1          LFXT1CLK
DIVM1  DIVM0      选择MCLK分频
     0         0          不分频
     0         1          2分频
     1         0          4分频
     1         1          8分频
  SELS                 选择SMCLK时钟源
     0                     DCLK(默认)
     1                     LFXT1CLK对于MSP430F11/12X,XT2CLK对于MSP430F13/14/15/16X
DIVS1  DIVS0       选择SMCLK分频
     0        0           不分频
     0        1           2分频
     1        0           4分频
     1        1           8分频
  DCOR                选择DCO电阻
     0                     内部电阻
     1                     外部电阻


时钟模块的应用


一、设置MCLK=XT2,SMCLK=DCOCLK,将MCLK由P5.4输出(MSP430X14X中引脚P5.4和MCLK复用)

#include  "msp430x14x.h"
void  main(void)
{
   unsigned int i;
   WDTCTL= WDTPW+WDTHOLD;    //Stop  watchdog to  prevent  to  overflow
   P5DIR  | =  0X10;                           //Set  P5.4 to output                           
   P5SEL | =  0X10;                           //Set  P5.4 to MCLK mode
   BCSCTL1 &= ~XT2OFF;                 //Enable XT2

   do{
   IFG1 & = ~OFIFG;                         //Clear OFIFG
   for(i=0xff;i>0;i--);                            //Set a delay
   }while(IFG1&OFIFG);                     //check-up the OFIFG
   
   BCSCTL2 | = SELM_2;                  //Set  XT2CLK the clock of MCLK

   for(;;);
}

[1] [2]
关键字:MSP430  单片机  时钟模块 编辑:什么鱼 引用地址:http://news.eeworld.com.cn/mcu/ic492645.html 本网站转载的所有的文章、图片、音频视频文件等资料的版权归版权所有人所有,本站采用的非本站原创文章及图片等内容无法一一联系确认版权者。如果本网所选内容的文章作者及编辑认为其作品不宜公开自由传播,或不应无偿使用,请及时通过电子邮件或电话通知我们,以迅速采取适当措施,避免给双方造成不必要的经济损失。

上一篇:MSP430教程11:MSP430单片机低功耗结构
下一篇:MSP430教程16:MSP430单片机的框架程序

关注eeworld公众号 快捷获取更多信息
关注eeworld公众号
快捷获取更多信息
关注eeworld服务号 享受更多官方福利
关注eeworld服务号
享受更多官方福利

推荐阅读

MSP430在CCS开发环境下的内存分配
这样的分析,我们很自然地想到,如果这些字符串常量能够离程序所在的区域“近一些”,那么这个问题就能解决了。如何来控制字符串常量所在的存储区域呢?这里我们需要了解一下cmd文件。以MSP430F6638的cmd文件为例,它主要包含了两个信息。一个是关于MSP430F6638的内存映射信息,如下图所示。利用红色的区域中的信息,我们也可以计算出,6638的RAM是从0x2400开始,大小为16K,USBRAM是从0x1c00开始,大小为2k,FLASH分为两个区域总的大小为256K。另一个是关于变量、代码等分配的存储位置。如下如所示。我们需要重点关注的是红色区域内的信息。观察一下。我们不难理解红色区域内代码的含义,是将.bss段、.data段
发表于 2020-03-09
MSP430在CCS开发环境下的内存分配
msp430g2553单片机学习心得
四年前学习的TI的Msp430g2553这款单片机,最近在整理学习记录的时候把当时的学习心得重新写下来。学习单片机最早是学习的51系列的,看的也是广为推崇的郭天祥郭老师的《十天学习单片机》,个人觉得单片机学习还是最先攻克51的。学习好51之后,对单片机操作有了基本的认识,再学习其他款单片机自然是能融会贯通。TI的430系列主打是低功耗,它的技术文档和Dome程序都非常详细,尤其是技术文档真让人有种膜拜的感觉,在每个模块的时候还有个框图,对理解模块内设置非常有帮助,我当时还特意打印了。当时它的User's Guide还没有中文版,如果实在看不懂,可以借鉴F149系列的(这款有人翻译了中文版本)。个人觉得在学习g2553这款
发表于 2020-03-09
学习MSP430G2553总结
个人感觉TI做的这块430就是一坨屎,内部时钟根本不稳,而且连datesheet都没有,但作为比赛指定的东西我们还是学了,这个连51都不如的16位单片机费了我四天时间把内部的模块给调了一遍,但是我调IIC时一直调不出来连时钟都没有,估计是做这块垃圾是连这个模块都没有吧,而且还写的那么复杂,连份像样的技术文档都没有,看的是别的技术文档,真是蛋疼无比,好了牢骚就发这么多,下面开始讲讲这块片子。首先介绍下MSP430G2553的时钟,这块芯片的时钟源是四个,时钟线是4个;时钟源我们就不说了,一般都是默认的选择内部的DCO作为时钟源,然后通过一系列的嫁接到MCLK SMCLK上,至于为什么这块芯片上不用锁相环的问题我深表不解,这个解释
发表于 2020-03-09
学习MSP430G2553总结
msp430 timerA interrupt
#include <msp430x24x.h> #define uchar unsigned char#define uint unsigned intuchar   table[16] ={0x3f,0x06,0x5b,0x4f,0x66,0x6d,0x7d,0x07,                0x7f,0x6f,0x77,0x7c,0x39,0x5e,0x79,0x71};uchar  position[8] = {0xfe,0xfd,0xfb,0xf7,0xef,0xdf,0xbf
发表于 2020-03-09
MSP430:AD10
使用的MSP430G2553,为AD10,正常有8路输出,P1.0-P1.7为A0-A7有七个寄存器,参考电压可以是VCC或者内部参考电压1.5V或者2.5V参考时钟可以是内部ADC10OSC最高转换速率达200ksps转换方式四种:单通道单次,序列通道单次,单通道多次,序列通道多次。多次转换时候会用到DTC功能防止数据还没被取出就被覆盖单通道的实例程序,开启的为通道5,也就是P1.5 1 void AD_Channel5_Config(void) 2 { 3   /* Configure ADC  Channel */ 4   
发表于 2020-03-09
MSP430:AD10
MSP430低功耗设置小结
设置低功耗模式也就是对SR状态寄存器当中的位进行操作SCG0.SCG1,CPUOFF,OSCOFF等位进行操作如果我们要设置低功耗模式,那一般来说也是要设置 中断的,在中断函数中打开CPU来执行我们想要执行的程序大部分时间CPU是处于OFF状态的,这样可以达到降低功耗的目的void main{    unsigned char i;    BCSCTL1|=DIVA_2;    WDTCTL=_WDT_ADLY_1000;    IE1|=WTDIE;    while(1)    {    &
发表于 2020-03-09
小广播
何立民专栏 单片机及嵌入式宝典

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

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