msp430 的DCO怎么校正啊

2019-03-24 10:42发布

DCO怎么校正啊,网上找了半天也没有 此帖出自小平头技术问答
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
2条回答
迈尔风随
1楼-- · 2019-03-24 20:11
一般官方在出厂的时候就设置了一些校准值,分别有1M,8M,12M和16M,如果这些特定频率不是你想要的,你可以先将DCO作为MCLK的时钟源,然后设置(P1.1还是P1.2,忘记了)输入MCLK,外部用示波器或者其他测量设备进行测量,再通过逐步调节DCO相关的寄存器以达到你想要的频率
Study_Stellaris
2楼-- · 2019-03-25 02:03
< :TI_MSP430_内容页_SA7 --> 本帖最后由 Study_Stellaris 于 2014-11-19 13:28 编辑

有一个官方的校准程序,我曾经也遇到过这个问题。这个是 G 系列的,你参考一下
  1. /******************************************************************************
  2. //  MSP430G2xx3 Demo - Basic Clock, Output Buffered clocks with preloaded DCO
  3. //                     calibration constants for BCSCTL1 and DCOCTL.
  4. //  
  5. //  Description: Buffer ACLK on P2.0, default SMCLK(DCO) on P1.4 and MCLK/10 on
  6. //  P1.1. DCO is software selectable to 1, 8, 12, or 16Mhz using calibration
  7. //  contstants in INFOA.
  8. //
  9. //  ACLK = LFXT1 = 32768, MCLK = SMCLK = Selectable at 1, 8, 12 or 16Mhz
  10. //  //* External watch crystal installed on XIN XOUT is required for ACLK *//       
  11. //
  12. //               MSP430G2xx3
  13. //             -----------------
  14. //         /||              XIN|-
  15. //          | |                 | 32kHz
  16. //          --|RST          XOUT|-
  17. //            |                 |
  18. //            |       P1.4/SMCLK|-->SMCLK = Default DCO
  19. //            |             P1.1|-->MCLK/10 = DCO/10
  20. //            |        P1.0/ACLK|-->ACLK = 32kHz
  21. //
  22. //  D. Dang
  23. //  Texas Instruments Inc.
  24. //  December 2010
  25. //   Built with IAR Embedded Workbench Version: 3.42A
  26. //******************************************************************************

  27. #include  <msp430g2553.h>

  28. void main(void)
  29. {
  30.   WDTCTL = WDTPW +WDTHOLD;                  // Stop Watchdog Timer
  31.   if (CALBC1_1MHZ ==0xFF || CALDCO_1MHZ == 0xFF)                                    
  32.   {  
  33.     while(1);                               // If calibration constants erased
  34.                                             // do not load, trap CPU!!
  35.   }
  36. //1Mhz
  37.   BCSCTL1 = CALBC1_1MHZ;                    // Set range
  38.   DCOCTL = CALDCO_1MHZ;                     // Set DCO step + modulation */

  39. /* //8Mhz
  40.   BCSCTL1 = CALBC1_8MHZ;                    // Set range
  41.   DCOCTL = CALDCO_8MHZ;                     // Set DCO step + modulation */

  42. /* //12Mhz
  43.   BCSCTL1 = CALBC1_12MHZ;                   // Set range
  44.   DCOCTL = CALDCO_12MHZ;                    // Set DCO step + modulation*/

  45. /* //16Mhz
  46.   BCSCTL1 = CALBC1_16MHZ;                   // Set range
  47.   DCOCTL = CALDCO_16MHZ;                    // Set DCO step + modulation*/

  48.   P1DIR |= 0x13;                            // P1.0,1 and P1.4 outputs
  49.   P1SEL |= 0x11;                            // P1.0,4 ACLK, SMCLK output

  50.   while(1)
  51.   {
  52.     P1OUT |= 0x02;                                // P1.1 = 1
  53.     P1OUT &= ~0x02;                         // P1.1 = 0
  54.   }
  55. }
复制代码


一周热门 更多>

相关问题

    相关文章