与51、AVR等单片机不同msp430的时钟信号源有LFXT1,XT2,DCO三种。
1、LFXT1:可接高速和低速晶振,在低速模式下,它可以外接32k的晶振而不需要负载电容,这种方式较为常见主要用来为ACLK提供低速的时钟信号,以供低速外设使用。
2、XT2:高速振荡器,它可以接一个0.4~16M的晶振,它相当于高速模式下的LFXT1。通常将它配置成一个高速的振荡源,为MCLK何SMCLK提供高速时钟信号。
3、DCO:内部数字控制振荡器,它的频率可以通过DCOCLK进行配置。在系统PUC之后,DCOx=7,MODx=3,表示选择了最高的频率。
前面介绍了MSP430中有三个个时钟信号源,MSP430的时钟信号也有三种主时钟MCLK,子系统时钟SMCLK,辅助时钟ACLK。
其中MCLK是用给系统使用的,SMCLK用给高速外设使用的,而ACLK主要用给低速外设使用。
在系统PUC之后,默认SMCLK与MCLK都以DCO作为时钟源,震荡频率在1.1M左右,ACLK以LFXT1作为时钟源,工作在LF模式下内部6pF的负载电容。
一般情况下选择XT2作为主时钟,时钟模块初始化程序如下:
WDTCTL = WDTPW + WDTHOLD; //关闭看门狗
/*------选择系统主时钟为8MHz-------*/
BCSCTL1 &= ~XT2OFF; // 打开XT2高频晶体振荡器
do
{
IFG1 &= ~OFIFG; //清除晶振失败标志
for (i = 0xFF; i > 0; i--); // 等待8MHz晶体起振
}
while ((IFG1 & OFIFG)); // 晶振失效标志仍然存在?
BCSCTL2 |= SELM_2 + SELS; //主时钟和从时钟都选择高频晶振
注意:
a.最好将IFG1&=~OFIFG;放入do –while循环中,我调了好一阵程序,发现IFG1似乎置位之后不能自动复位。
b.在XT2出现错误的情况下将XT2设定为MCLK SMCLK的时钟源,单片机会自动的把时钟源更换为DCO振荡器。当时钟信号丢失50us时,振荡器失效。如果MCLK信号来自LFXT1或者XT2,
那么MSP430自动把MCLK的信号切换为DCO,这样可以保证程序继续运行。MSP430不对低频
模式的LFXT1进行监测。
b.BCSCTL2=SELM_2+SELS;语句必须放在while之后,因为当XT2没有起振之前,XT2处于错误
阶段,因此在XT2没有起振之前将它设定为主时钟与子系统时钟后,单片机会自动的将DCO
设定为SMCLK MCLK的时钟源。
上一篇:MSP430学习笔记4-两个定时器产生步进单频音
下一篇:MSP430寄存器中文注释
推荐阅读最新更新时间:2024-11-21 10:44
设计资源 培训 开发板 精华推荐
- AM2G-1215SH30Z 15V 2 瓦 DC/DC 转换器的典型应用
- 具有停机功能的 LTC1409、12 位、800ksps 采样 A/D 转换器的典型应用
- EVL6599A-90WADP,使用 L6563H 和 L6599A 19V - 90W 适配器和 PFC 的评估板,用于笔记本电脑
- 使用 Cypress Semiconductor 的 CY8C26443 的参考设计
- XDPL8105 40W参考设计
- ADM8845EB-EVAL,评估板允许快速轻松地评估用于 LCD 白光 LED 背光的 ADM8846 电荷泵驱动器
- LTC2945IMS 双电源监视器的典型应用,具有用于电流隔离的通用光电耦合器
- EVAL-AD8476,D8476 差分放大器评估板
- LT3756EUD-2 94% 效率 30W 白光 LED 前照灯驱动器的典型应用电路
- 使用 Analog Devices 的 LTC1472 的参考设计