专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
TI
UCS模块的问题
2019-08-04 17:34
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
TI MCU
15059
11
953
我XT2外接的是16M的晶振,我想利用DCO给他升到32M,但是程序有时候是32M,有时候是8M等等等等,代码是
请用过的帮帮我呀 或者有类似的例程也行
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
11条回答
zhenykun
1楼-- · 2019-08-04 18:59
程序看看
加载中...
heweibig
2楼-- · 2019-08-04 22:03
void main(void) {
WDTCTL = WDTPW+WDTHOLD;
P1DIR |= BIT0;
P1SEL |= BIT0; //可以看ACLK的频率
P2DIR |= BIT2;
P2SEL |= BIT2; //SMCLK
P7DIR |= BIT7;
P7SEL |= BIT7; //MCLK
P5SEL |= BIT2+BIT3;
UCSCTL6 &= ~XT2OFF; //打开XT2
do
{
UCSCTL7 &= ~XT2OFFG;
加载中...
yszong
3楼-- · 2019-08-04 23:08
发错了?
加载中...
heweibig
4楼-- · 2019-08-05 01:52
void main(void) {
WDTCTL = WDTPW+WDTHOLD;
P1DIR |= BIT0;
P1SEL |= BIT0; //可以看ACLK的频率
P2DIR |= BIT2;
P2SEL |= BIT2; //SMCLK
P7DIR |= BIT7;
P7SEL |= BIT7; //MCLK
P5SEL |= BIT2+BIT3;
UCSCTL6 &= ~XT2OFF; //打开XT2
do
{
UCSCTL7 &= ~XT2OFFG; //清除振荡器XT2失效标志
SFRIFG1 &= ~OFIFG; // 清除振荡器失效标志
//上面这句必须有,否则起振了也不会分配成功
}while (UCSCTL7 & XT2OFFG);
/*********************寄存器配置部分******************************/
__bis_SR_register(SCG0);
UCSCTL0 = 0; //设为0
UCSCTL1 = DCORSEL_6; //DCO频率范围在50MHZ以下
UCSCTL2 = FLLD_3 + 1; //D=8,N=1
UCSCTL3 = SELREF_5 + FLLREFDIV_3; //n=8,FLLREFCLK时钟源为XT2CLK;DCOCLK=D*(N+1)*(FLLREFCLK/n);DCOCLKDIV=(N+1)*(FLLREFCLK/n);
UCSCTL4 = SELA_4 + SELS_3 +SELM_3; //ACLK的时钟源为DCOCLKDIV,MCLKSMCLK的时钟源为DCOCLK
UCSCTL5 = DIVA_5; //ACLK由DCOCLKDIV的32分频得到
__bic_SR_register(SCG0); //Enable the FLL control loop
/**********************************************************************/
while (SFRIFG1 & OFIFG){
UCSCTL7 &= ~(XT2OFFG + XT1LFOFFG + DCOFFG); // 清除三类时钟标志位
// 这里需要清除三种标志位,因为任何一种
// 标志位都会将OFIFG置位
SFRIFG1 &= ~OFIFG; // 清除时钟错误标志位
}
P8SEL &= (~(1<<1));
P8DIR |= (1<<1);
while(1){
P8OUT |= (1<<1);
Delay_ms(1000);
P8OUT &= (~(1<<1));
Delay_ms(1000);
}
}
加载中...
wyjie
5楼-- · 2019-08-05 06:45
精彩回答 2 元偷偷看……
加载中...
yszong
6楼-- · 2019-08-05 07:12
这里有一个用4MHz的XT2,得到16MHz的DCLCLK的程序,你参考下
P1DIR |= BIT0;
P1SEL |= BIT0; //可以看ACLK的频率
P2DIR |= BIT2;
P2SEL |= BIT2; //SMCLK
P7DIR |= BIT7;
P7SEL |= BIT7; //MCLK
P5SEL |= BIT2+BIT3;
UCSCTL6 &= ~XT2OFF; //打开XT2
/*********************寄存器配置部分******************************/
__bis_SR_register(SCG0);
UCSCTL0 = DCO0+DCO1+DCO2+DCO3+DCO4;
UCSCTL1 = DCORSEL_4; //DCO频率范围在28.2MHZ以下
UCSCTL2 = FLLD_4 + 1; //D=16,N=1
UCSCTL3 = SELREF_5 + FLLREFDIV_3; //n=8,FLLREFCLK时钟源为XT2CLK;DCOCLK=D*(N+1)*(FLLREFCLK/n);DCOCLKDIV=(N+1)*(FLLREFCLK/n);
UCSCTL4 = SELA_4 + SELS_3 +SELM_3; //ACLK的时钟源为DCOCLKDIV,MCLKSMCLK的时钟源为DCOCLK
UCSCTL5 = DIVA_5 +DIVS_1; //ACLK由DCOCLKDIV的32分频得到,SMCLK由DCOCLK的2分频得到
//最终MCLK:16MHZ,SMCLK:8MHZ,ACLK:32KHZ
__bic_SR_register(SCG0); //Enable the FLL control loop
/**********************************************************************/
__delay_cycles(8192);
do
{
UCSCTL7 &= ~(XT2OFFG + XT1LFOFFG + DCOFFG); //Clear XT2,XT1,DCO fault flags
SFRIFG1 &= ~OFIFG; //Clear fault flags
}while (SFRIFG1&OFIFG);
加载中...
1
2
下一页
一周热门
更多
>
相关问题
CPLD的方波输出
4 个回答
11个版本Quartus II 软件下载,安装包网盘合集,附教程,47G!
20 个回答
请大家帮忙到21IC发展大家谈支持我申请新版面
20 个回答
【通知】21ic中国电子网服务条款 (所有人员必读)
1 个回答
满载而归乙亥年,大展鸿途庚子年---集签赢好礼
20 个回答
携手ADI,踏上电子工程师之巅—车辆电气化视频,答题领奖!
1 个回答
如何提升论坛质量,看你了!
20 个回答
【最终名单】二姨家喊你来拿100份新年大礼啦~
20 个回答
相关文章
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
TI
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
void main(void) {
WDTCTL = WDTPW+WDTHOLD;
P1DIR |= BIT0;
P1SEL |= BIT0; //可以看ACLK的频率
P2DIR |= BIT2;
P2SEL |= BIT2; //SMCLK
P7DIR |= BIT7;
P7SEL |= BIT7; //MCLK
P5SEL |= BIT2+BIT3;
UCSCTL6 &= ~XT2OFF; //打开XT2
do
{
UCSCTL7 &= ~XT2OFFG;
void main(void) {
WDTCTL = WDTPW+WDTHOLD;
P1DIR |= BIT0;
P1SEL |= BIT0; //可以看ACLK的频率
P2DIR |= BIT2;
P2SEL |= BIT2; //SMCLK
P7DIR |= BIT7;
P7SEL |= BIT7; //MCLK
P5SEL |= BIT2+BIT3;
UCSCTL6 &= ~XT2OFF; //打开XT2
do
{
UCSCTL7 &= ~XT2OFFG; //清除振荡器XT2失效标志
SFRIFG1 &= ~OFIFG; // 清除振荡器失效标志
//上面这句必须有,否则起振了也不会分配成功
}while (UCSCTL7 & XT2OFFG);
/*********************寄存器配置部分******************************/
__bis_SR_register(SCG0);
UCSCTL0 = 0; //设为0
UCSCTL1 = DCORSEL_6; //DCO频率范围在50MHZ以下
UCSCTL2 = FLLD_3 + 1; //D=8,N=1
UCSCTL3 = SELREF_5 + FLLREFDIV_3; //n=8,FLLREFCLK时钟源为XT2CLK;DCOCLK=D*(N+1)*(FLLREFCLK/n);DCOCLKDIV=(N+1)*(FLLREFCLK/n);
UCSCTL4 = SELA_4 + SELS_3 +SELM_3; //ACLK的时钟源为DCOCLKDIV,MCLKSMCLK的时钟源为DCOCLK
UCSCTL5 = DIVA_5; //ACLK由DCOCLKDIV的32分频得到
__bic_SR_register(SCG0); //Enable the FLL control loop
/**********************************************************************/
while (SFRIFG1 & OFIFG){
UCSCTL7 &= ~(XT2OFFG + XT1LFOFFG + DCOFFG); // 清除三类时钟标志位
// 这里需要清除三种标志位,因为任何一种
// 标志位都会将OFIFG置位
SFRIFG1 &= ~OFIFG; // 清除时钟错误标志位
}
P8SEL &= (~(1<<1));
P8DIR |= (1<<1);
while(1){
P8OUT |= (1<<1);
Delay_ms(1000);
P8OUT &= (~(1<<1));
Delay_ms(1000);
}
}
这里有一个用4MHz的XT2,得到16MHz的DCLCLK的程序,你参考下
P1DIR |= BIT0;
P1SEL |= BIT0; //可以看ACLK的频率
P2DIR |= BIT2;
P2SEL |= BIT2; //SMCLK
P7DIR |= BIT7;
P7SEL |= BIT7; //MCLK
P5SEL |= BIT2+BIT3;
UCSCTL6 &= ~XT2OFF; //打开XT2
/*********************寄存器配置部分******************************/
__bis_SR_register(SCG0);
UCSCTL0 = DCO0+DCO1+DCO2+DCO3+DCO4;
UCSCTL1 = DCORSEL_4; //DCO频率范围在28.2MHZ以下
UCSCTL2 = FLLD_4 + 1; //D=16,N=1
UCSCTL3 = SELREF_5 + FLLREFDIV_3; //n=8,FLLREFCLK时钟源为XT2CLK;DCOCLK=D*(N+1)*(FLLREFCLK/n);DCOCLKDIV=(N+1)*(FLLREFCLK/n);
UCSCTL4 = SELA_4 + SELS_3 +SELM_3; //ACLK的时钟源为DCOCLKDIV,MCLKSMCLK的时钟源为DCOCLK
UCSCTL5 = DIVA_5 +DIVS_1; //ACLK由DCOCLKDIV的32分频得到,SMCLK由DCOCLK的2分频得到
//最终MCLK:16MHZ,SMCLK:8MHZ,ACLK:32KHZ
__bic_SR_register(SCG0); //Enable the FLL control loop
/**********************************************************************/
__delay_cycles(8192);
do
{
UCSCTL7 &= ~(XT2OFFG + XT1LFOFFG + DCOFFG); //Clear XT2,XT1,DCO fault flags
SFRIFG1 &= ~OFIFG; //Clear fault flags
}while (SFRIFG1&OFIFG);
一周热门 更多>