MSP430F169的时钟设置

  1. 设置使用DCOCLK时钟源
  • 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信号分频
  1. 设置使用XT2CLK时钟源
  • 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信号分频
  1. 设置使用LFXT1CLK时钟源
  • 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信号分频
人就像是被蒙着眼推磨的驴子,生活就像一条鞭子;当鞭子抽到你背上时,你就只能一直往前走,虽然连你也不知道要走到什么时候为止,便一直这么坚持着。