zoukankan      html  css  js  c++  java
  • MSP430F169的时钟设置

    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信号分频
    
    人就像是被蒙着眼推磨的驴子,生活就像一条鞭子;当鞭子抽到你背上时,你就只能一直往前走,虽然连你也不知道要走到什么时候为止,便一直这么坚持着。
  • 相关阅读:
    K8s网络插件flannel与calico
    calico部署与网卡绑定
    脚本基本函数
    k8s迁移工具-helm
    mysql不识别中文
    日志收集系统对比
    VM虚拟机安装后的网络设置
    微擎目录结构介绍
    amazeui笔记-web组件
    jQuery 数据
  • 原文地址:https://www.cnblogs.com/guochaoxxl/p/14600498.html
Copyright © 2011-2022 走看看