This thread has been locked.
If you have a related question, please click the "Ask a related question" button in the top right corner. The newly created question will be automatically linked to this question.
使用了MSP430FR5994单片机,使用8MHz的晶体,连接至XT2OUT和XT2IN,作为高速时钟使用。通过配置PJSEL1.6=0,PJSEL0.6=1,并关闭HFXTOFF。在晶振错误标识为0,时,切换至HF,但是输出是4.MHz。通过CTL2可以正确设置MCLK和SMCLK为DCO、MODCLK、ACLk,但是就是无法使用HF。选择了HF后得到的依然是MODCLK时钟,也就是4.8MHz。不知何故?请指教!谢谢!
请问您是否有测试下面的例程?在此例程中使用的是8Mhz的晶振
// Description: Configure ACLK = LFXT, SMCLK = HFXT and MCLK = DCO
// NOTE1: 32768Hz and 8MHz crystals required!
/* --COPYRIGHT--,BSD_EX * Copyright (c) 2015, Texas Instruments Incorporated * All rights reserved. * * Redistribution and use in source and binary forms, with or without * modification, are permitted provided that the following conditions * are met: * * * Redistributions of source code must retain the above copyright * notice, this list of conditions and the following disclaimer. * * * Redistributions in binary form must reproduce the above copyright * notice, this list of conditions and the following disclaimer in the * documentation and/or other materials provided with the distribution. * * * Neither the name of Texas Instruments Incorporated nor the names of * its contributors may be used to endorse or promote products derived * from this software without specific prior written permission. * * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. * ******************************************************************************* * * MSP430 CODE EXAMPLE DISCLAIMER * * MSP430 code examples are self-contained low-level programs that typically * demonstrate a single peripheral function or device feature in a highly * concise manner. For this the code may rely on the device's power-on default * register values and settings such as the clock configuration and care must * be taken when combining code from several examples to avoid potential side * effects. Also see www.ti.com/grace for a GUI- and www.ti.com/msp430ware * for an API functional library-approach to peripheral configuration. * * --/COPYRIGHT--*/ //****************************************************************************** // MSP430FR5x9x Demo - ACLK = XT1 = 32768Hz, SMCLK= XT2 = 8MHz, MCLK = DCO // // Description: Configure ACLK = LFXT, SMCLK = HFXT and MCLK = DCO // NOTE1: 32768Hz and 8MHz crystals required! // // MSP430FR5994 // --------------- // /|\| | // | | |-LFXIN // --|RST |-LFXOUT // | | // | |-HFXIN // | |-HFXOUT // | | // | P1.0|---> LED // | P2.0|---> ACLK = 32768Hz // | P3.4|---> SMCLK = 8MHz // // William Goh // Texas Instruments Inc. // October 2015 // Built with IAR Embedded Workbench V6.30 & Code Composer Studio V6.1 //****************************************************************************** #include <msp430.h> int main(void) { WDTCTL = WDTPW | WDTHOLD; // Configure GPIO P1OUT = 0; P1DIR = BIT0; // For LED P2DIR |= BIT0; P2SEL0 |= BIT0; // Output ACLK P2SEL1 |= BIT0; P3DIR |= BIT4; P3SEL1 |= BIT4; // Output SMCLK P3SEL0 |= BIT4; PJSEL0 |= BIT4 | BIT5 | BIT6 | BIT7; // For XT1 and XT2 // Disable the GPIO power-on default high-impedance mode to activate // previously configured port settings PM5CTL0 &= ~LOCKLPM5; CSCTL0_H = CSKEY_H; // Unlock CS registers CSCTL1 = DCOFSEL_6; // Set DCO to 8MHz CSCTL2 = SELA__LFXTCLK | SELS__HFXTCLK | SELM__DCOCLK; CSCTL3 = DIVA__1 | DIVS__1 | DIVM__1; // Set all dividers to 1 CSCTL4 |= LFXTDRIVE_3 | HFXTDRIVE_3; CSCTL4 &= ~(LFXTOFF | HFXTOFF); do { CSCTL5 &= ~(LFXTOFFG | HFXTOFFG); // Clear XT1 and XT2 fault flag SFRIFG1 &= ~OFIFG; } while (SFRIFG1 & OFIFG); // Test oscillator fault flag CSCTL0_H = 0; // Lock CS registers while (1) { P1OUT ^= 0x01; // Toggle LED __delay_cycles(8000000); // Wait 8,000,000 CPU Cycles } }