//****************************************************************************** // MSP430xG46x Demo - USART1, Ultra-Low Pwr UART 2400 Echo ISR, 32kHz ACLK // // Description: Echo a received character, RX ISR used. In the Mainloop USART1 // is made ready to receive one character with interrupt active. The Mainloop // waits in LPM3. The USART1 ISR forces the Mainloop to exit LPM3 after // receiving one character which echo's back the received character. // ACLK = UCLK1 = LFXT1 = 32768, MCLK = SMCLK = DCO~ 1048k // Baud rate divider with 32768kHz XTAL @2400 = 32768Hz/2400 = 13.65 (000Dh) // //* An external watch crystal is required on XIN XOUT for ACLK *// // // MSP430xG461x // ----------------- // /|\| XIN|- // | | | 32kHz // --|RST XOUT|- // | | // | P4.0|-----------> // | | 2400 - 8N1 // | P4.1|<----------- // // // K. Quiring/ M. Mitchell // Texas Instruments Inc. // October 2006 // Built with IAR Embedded Workbench Version: 3.41A //****************************************************************************** #include void main(void) { volatile unsigned int i; WDTCTL = WDTPW + WDTHOLD; // Stop WDT FLL_CTL0 |= XCAP14PF; // Configure load caps do { IFG1 &= ~OFIFG; // Clear OSCFault flag for (i = 0x47FF; i > 0; i--); // Time for flag to set } while ((IFG1 & OFIFG)); // OSCFault flag still set? P4SEL |= 0x03; // P4.1,0 = USART1 TXD/RXD ME2 |= UTXE1 + URXE1; // Enable USART1 TXD/RXD U1CTL |= CHAR; // 8-bit character U1TCTL |= SSEL0; // UCLK = ACLK U1BR0 = 0x0D; // 32k/2400 - 13.65 U1BR1 = 0x00; // U1MCTL = 0x6B; // Modulation U1CTL &= ~SWRST; // Initialize USART state machine IE2 |= URXIE1; // Enable USART1 RX interrupt // Mainloop for (;;) { _BIS_SR(LPM3_bits + GIE); // Enter LPM3 w/interrupt while (!(IFG2 & UTXIFG1)); // USART1 TX buffer ready? TXBUF1 = RXBUF1; // RXBUF1 to TXBUF1 } } // USART1 RX ISR will for exit from LPM3 in Mainloop #pragma vector=USART1RX_VECTOR __interrupt void USART1_rx (void) { _BIC_SR_IRQ(LPM3_bits); // Clear LPM3 bits from 0(SR) }