您的位置 首页 基础

MSP430F149的时钟体系

1、概述MSP430F149有三个时钟源:外部LF(XT1一般为32768K),HF(XT2一般为8M),内部DCO。从时钟系统模块可得到三种时钟信号:MCLK,SMCLK,

1、概述

MSP430F149有三个时钟源:外部LF(XT1一般为32.768K),HF(XT2一般为8M),内部DCO。从时钟体系模块可得到三种时钟信号:MCLK,SMCLK,ACLK。

上电默许情况下MCLK,SMCLK信号来自DCO,ACLK来自LF。依据官方PDF说法默许情况下DCO模块装备为RSELX=4,DCO=3,因而DCO应为1M,但示波器实测MCLK/SMCLK为680K,测验温度约25摄氏度。

标示:MCLK主时钟、SMCLK子时钟、ACLK活动时钟。

P5.4,P5.5,P5.6的第二功用别离对应MCLK,SMCLK,ACLK时钟信号,可用示波器丈量。测验时发现频率后两位一直在跳动,频率稳定度很差。

MSP430系列单片机挑选晶振为时钟源时,时钟周期便是晶振周期。一个机器周期 =一个时钟周期,即430每个动作都能完结一个根本操作; 一个指令周期 = 1~6个机器周期,详细依据详细指令而定。 假如挑选8M晶振,则一个机器周期为125ns。51单片机挑选12M晶振,它的机器周期是时钟周期/12,一个机器周期为1us,可见 MSP430的的速度是51的8倍。

2、使用方法概述

2.1 程序架构

一般在体系初始化封闭看门狗后要装备体系时钟,装备过程为:

1、翻开晶振;

2、等候晶振起振。铲除OFIFG,延时,判别OFIFG是否为0,为0则晶振正常起振,退出判别;

3、挑选MCLK/SMCLK时钟源;

uchar iq0;

BCSCTL1&=~XT2OFF; //翻开XT2振荡器

do

{

IFG1 &= ~OFIFG; // 铲除振荡器失效标志

for (iq0 = 0xFF; iq0 > 0; iq0–); // 延时,等候XT2起振

}

while ((IFG1 & OFIFG) != 0); // 判别XT2是否起振

BCSCTL2 =SELM_2+SELS; //挑选MCLK、SMCLK为XT2

2.2 细节描绘

关于DCO能够经过装备电阻和DCO得到不同的频率。电阻可装备片内或片外(DCOR一般片内),片内电阻有8中挑选(RSELX),DCO有8中挑选(DCOX)。

3、相关寄存器

1、DCOCTL

DCOx Bits

7-5

DCO frequency select. These bits select which of the eight discrete DCO

frequencies of the RSELx setting is selected.

2、BCSCTL0

XT2OFF Bit 7 XT2 off. This bit turns off the XT2 oscillator

0 XT2 is on

1 XT2 is off if it is not used for MCLK or SMCLK.

RSELx Bits

2-0

Resistor Select. The internal resistor is selected in eight different steps.

The value of the resistor defines the nominal frequency. The lowest

nominal frequency is selected by setting RSELx=0.

3、BCSCTL0

SELMx Bits

7-6

Select MCLK. These bits select the MCLK source.

00 DCOCLK

01 DCOCLK

10 XT2CLK when XT2 oscillator present on-chip. LFXT1CLK when XT2

oscillator not present on-chip.

11 LFXT1CLK

SELS Bit 3 Select SMCLK. This bit selects the SMCLK source.

0 DCOCLK

1 XT2CLK when XT2 oscillator present on-chip. LFXT1CLK when XT2

oscillator not present on-chip.

DCOR Bit 0 DCO resistor select

0 Internal resistor

1 External resistor

4、实例

4.1 装备MCLK/SMCLK

见本节2.1。

4.2装备DCO

void main(void)

{

WDTCTL = WDTPW +WDTHOLD; // Stop Watchdog Timer

DCOCTL = DCO0 + DCO1 + DCO2; // Max DCO

BCSCTL1 = RSEL0 + RSEL1 + RSEL2; // XT2on, max RSEL

BCSCTL2 |= SELS; // SMCLK = XT2

P5DIR |= 0x70; // P5.6,5,4 outputs

P5SEL |= 0x70; // P5.6,5,5 options

while(1)

{

}

}

实测DCO最低128K,最高4.58M。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/zhishi/jichu/257272.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部