用6736做了一块板子,在进行UCS的初始化时,运行初始化代码如下:
PJDIR |= BIT0 | BIT1 | BIT3; // ACLK, MCLK, SMCLK set out to pins PJSEL |= 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都是正确的。执行清空操作之后就不对了。
|