MSP430F169的时钟设置
MSP430F169的时钟设置
- 设置使用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信号分频
- 设置使用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信号分频
- 设置使用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信号分频
人就像是被蒙着眼推磨的驴子,生活就像一条鞭子;当鞭子抽到你背上时,你就只能一直往前走,虽然连你也不知道要走到什么时候为止,便一直这么坚持着。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· AI技术革命,工作效率10个最佳AI工具