MSP430F169的时钟设置
- 设置使用DCOCLK时钟源
DCOCTL = DCO0 + DCO1 + DCO2; // Max DCO
BCSCTL1 = RSEL0 + RSEL1 + RSEL2; //设置成功DCOCLK时钟源, 复位后MCLK默认是DCO
//t = (32 - MODx) * t_DCO + MODx * t_DCO+1
//f_t = (f_DCO * f_DCO+1)/(32 * f_DCO+1 + MODx *(f_DCO - f_DCO+1))
DCOCTL = MOD0 + MOD1 + MOD2 + MOD3 + MOD4; //如果上述设置的频率不够就用该语句实现频率混合,MOD_N(1~31)
SCSCTL2 |= DCOR //DCOR为0时,选择内部电阻,受温度影响大;DCOR为1时,选择外部精密电阻,受温度影响小
- MCLK信号使用DCOCLK时钟源,结合DCOCLK时钟源的配置
//BCSCTL2 = SELM_(0,1,2,3); //SELM_0和SELM_1都是DCOCLK SELM_2是XT2CLK(高频) SELM_3是LFXT1CLK(低频)
BCSCTL2 |= SELM_1; //MCLK信号选择时钟源为DCOCLK
//BCSCTL2 = DIVM_(0,1,2,3); //DIVM_N就是对MCLK信号的频率进行2^N分频,依次为1、2、4、8分频
BCSCTL2 |= DIVM_0; //对MCLK信号分频
- SMCLK信号使用DCOCLK时钟源,结合DCOCLK时钟源的配置
//BCSCTL2 = SELS; //SELS为0时,选择DCOCLK时钟源;SELS为1时,选择外部时钟源,若XT2CLK时钟源,就为XT2CLK,否则就为LFXT1CLK时钟
BCSCTL2 &= ~SELS; //SMCLK信号选择时钟源为DCOCLK
//BCSCTL2 = DIVS_(0,1,2,3); //DIVS_N就是对SMCLK信号的频率进行2^N分频,依次为1、2、4、8分频
BCSCTL2 |= DIVS_0; //对SMCLK信号分频
- 设置使用XT2CLK时钟源
BCSCTL1 &= ~XT2OFF; //XT2OFF置位时关闭XT2CLK时钟源,XT2OFF复位时打开XT2CLK时钟
//BCSCTL1 |= XTS; //XTS复位时LFXT1CLK为低频模式,置位时为高频模式,此时LFXT1CLK就可以替换XT2CLK时钟源
volatile unsigned int i;
do
{
IFG1 &= ~OFIFG; //复位后OFIFG为1,使用外部时钟源必须复位OFIFG
for (i = 0xFF; i > 0; i--)
; //等待复位
}
while ((IFG1 & OFIFG)); //如果还是置位则再次复位
- MCLK信号使用XT2CLK时钟源,结合XT2CLK时钟源的配置
//BCSCTL2 = SELM_(0,1,2,3); //SELM_0和SELM_1都是DCOCLK SELM_2是XT2CLK(高频) SELM_3是LFXT1CLK(低频)
BCSCTL2 |= SELM_2; //MCLK信号选择时钟源为XT2CLK
//BCSCTL2 = DIVM_(0,1,2,3); //DIVM_N就是对MCLK信号的频率进行2^N分频,依次为1、2、4、8分频
BCSCTL2 |= DIVS_0; //对SMCLK信号分频
- SMCLK信号使用XT2CLK时钟源,结合XT2CLK时钟源的配置
//BCSCTL2 = SELS; //SELS为0时,选择DCOCLK时钟源;SELS为1时,选择外部时钟源,若XT2CLK时钟源村子,就为XT2CLK,否则就为LFXT1CLK时钟
BCSCTL2 = SELS; //SMCLK信号选择时钟源为XT2CLK
//BCSCTL2 = DIVS_(0,1,2,3); //DIVS_N就是对SMCLK信号的频率进行2^N分频,依次为1、2、4、8分频
BCSCTL2 |= DIVS_0; //对SMCLK信号分频
- 设置使用LFXT1CLK时钟源
//BCSCTL1 |= XTS; //XTS复位时LFXT1CLK为低频模式,置位时为高频模式,此时LFXT1CLK就可以替换XT2CLK时钟源
volatile unsigned int i;
do
{
IFG1 &= ~OFIFG; //复位后OFIFG为1,使用外部时钟源必须复位OFIFG
for (i = 0xFF; i > 0; i--)
; //等待复位
}
while ((IFG1 & OFIFG)); //如果还是置位则再次复位
- MCLK信号使用LFXT1CLK时钟源,结合LFXT1CLK时钟源的配置
//BCSCTL2 = SELM_(0,1,2,3); //SELM_0和SELM_1都是DCOCLK SELM_2是XT2CLK(高频) SELM_3是LFXT1CLK(低频)
BCSCTL2 |= SELM_3; //MCLK信号选择时钟源为LFXT1CLK
//BCSCTL2 = DIVM_(0,1,2,3); //DIVM_N就是对MCLK信号的频率进行2^N分频,依次为1、2、4、8分频
BCSCTL2 |= DIVS_0; //对SMCLK信号分频
- SMCLK信号使用LFXT1CLK时钟源,结合LFXT1CLK时钟源的配置,此时LFXT1CLK必须在高频模式下,LFXT1CLK时钟源的配置中的第1行不能注释
//BCSCTL2 = SELS; //SELS为0时,选择DCOCLK时钟源;SELS为1时,选择外部时钟源,若XT2CLK时钟源存在,就为XT2CLK,否则就为LFXT1CLK时钟
BCSCTL2 = SELS; //SMCLK信号选择时钟源为LFXT1CLK高频
//BCSCTL2 = DIVS_(0,1,2,3); //DIVS_N就是对SMCLK信号的频率进行2^N分频,依次为1、2、4、8分频
BCSCTL2 |= DIVS_0; //对SMCLK信号分频
- ACLK信号使用LFXT1CLK时钟源,结合LFXT1CLK时钟源的配置
//BCSCTL1 |= XTS; //XTS复位时LFXT1CLK为低频模式,置位时为高频模式,此时LFXT1CLK就可以替换XT2CLK时钟源
//BCSCTL2 = DIVA_(0,1,2,3); //DIVA_N就是对ACLK信号的频率进行2^N分频,依次为1、2、4、8分频
BCSCTL2 |= DIVA_0; //对SMCLK信号分频
人就像是被蒙着眼推磨的驴子,生活就像一条鞭子;当鞭子抽到你背上时,你就只能一直往前走,虽然连你也不知道要走到什么时候为止,便一直这么坚持着。