关于MSP430F6736 UCS的问题!

2019-03-24 10:37发布

用6736做了一块板子,在进行UCS的初始化时,运行初始化代码如下:
PJDIR |= BIT0 | BIT1 | BIT3;           // ACLK, MCLK, SMCLK set out to pinsPJSEL |= BIT0 | BIT1 | BIT3;           // PJ.0,1,3 for debugging purposes.
UCSCTL6 &= ~(XT1OFF);                   // Enable XT1   UCSCTL6 |= XCAP_1;                      // Internal load cap   // Loop until XT1, XT2 & DCO fault flag is cleared   do   {       UCSCTL7 &= ~(XT2OFFG | XT1LFOFFG | DCOFFG);       // Clear XT2,XT1,DCO fault flags       SFRIFG1 &= ~OFIFG;                  // Clear fault flags       //for(unsigned int i=0;i<50000;i++);   }   while (SFRIFG1 & OFIFG);              // Test oscillator fault flag
虽然能够从while( SFRIFG1 & OFIFG )里面跳出来,可是OFIFG的值仍然是1,同时DCOFFG的值也是1,从PJ.3管脚也看不到32k的波形。换了好几个晶振了仍然不行,这是为什么,OFIFG置位了自检还能通过?
同时我看到了UG上说,DCO=0或者31时DCOFFG会置位,可是DCO的值似乎不是用户软件可以设置的啊,请大神赐教啊!
补充一个,在单步运行时,运行完了SFRIFG1 &= ~OFIFG; 这一句之后,UCSCTL0寄存器会变成0x00F8也就是DCO的值变成了0。DCOFFG为1,XT1LFOFFG和XT2OFFG为0。在清空OFIFG之前,从PJ管脚读出来的ACLK,SMCLK和MCLK都是正确的。执行清空操作之后就不对了。
此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
4条回答
lonerzf
2019-03-24 17:29
< :TI_MSP430_内容页_SA7 --> 应该支持32768HZ晶振啊。既然这段程序能通过while循环,OFIFG怎能够又变了呢。奇怪,既然能跳出,很可能是已经配置成功了。楼主试试定时器中断,看时间对不对。

一周热门 更多>

相关问题

    相关文章