?? fet140_uart01_19200_2.s43
字號(hào):
;******************************************************************************
; MSP-FET430P140 Demo - USART0, UART 19200 Echo ISR, XT2 HF XTAL SMCLK
;
; Description: This program will echo a received character, RX interrupt
; service used. XT2 oscillator used in this example.
; ACLK = MCLK = SMCLK = UCLK0 = XT2 = 8MHz
; Baud rate divider with 8Mhz XTAL @19200 = 8MHz/19200 = 416.66 ~ 417
; //* An external 8MHz XTAL on X2IN X2OUT is required for XT2CLK *//
; //* Min Vcc required varies with MCLK frequency - refer to datasheet *//
;
; MSP430F149
; -----------------
; /|\| XT2IN|-
; | | | 8Mhz
; --|RST XT2OUT|-
; | |
; | P3.4|------------>
; | | 19200 - 8N1
; | P3.5|<------------
;
; M. Buccini
; Texas Instruments Inc.
; Feb 2005
; Built with IAR Embedded Workbench Version: 3.21A
;******************************************************************************
#include <msp430x14x.h>
;------------------------------------------------------------------------------
ORG 01100h ; Progam Start
;------------------------------------------------------------------------------
RESET mov.w #0A00h,SP ; Initialize stackpointer
StopWDT mov.w #WDTPW+WDTHOLD,&WDTCTL ; Stop WDT
SetupP3 bis.b #030h,&P3SEL ; P3.4,5 = USART0 TXD/RXD
SetupBC bic.b #XT2OFF,&BCSCTL1 ; XT2on
SetupOsc bic.b #OFIFG,&IFG1 ; Clear OSC fault flag
mov.w #0FFh,R15 ; R15 = Delay
SetupOsc1 dec.w R15 ; Additional delay to ensure start
jnz SetupOsc1 ;
bit.b #OFIFG,&IFG1 ; OSC fault flag set?
jnz SetupOsc ; OSC Fault, clear flag again
bis.b #SELM_2+SELS,BCSCTL2 ; MCLK = SMCLK = XT2
;
SetupUART0 bis.b #UTXE0+URXE0,&ME1 ; Enable USART0 TXD/RXD
bis.b #CHAR,&UCTL0 ; 8-bit characters
mov.b #SSEL1,&UTCTL0 ; UCLK = SMCLK
mov.b #0A0h,&UBR00 ; 8Mhz/19200 ~ 417
mov.b #001h,&UBR10 ;
mov.b #000h,&UMCTL0 ; no modulation
bic.b #SWRST,&UCTL0 ; **Initialize USART state machine**
bis.b #URXIE0,&IE1 ; Enable USART0 RX interrupt
;
Mainloop bis.b #CPUOFF+GIE,SR ; Enter LPM0, interrupts enabled
nop ; Needed only for debugger
;
;------------------------------------------------------------------------------
USART0RX_ISR; Echo back RXed character, confirm TX buffer is ready first
;------------------------------------------------------------------------------
TX1 bit.b #UTXIFG0,&IFG1 ; USART1 TX buffer ready?
jz TX1 ; Jump is TX buffer not ready
mov.b &RXBUF0,&TXBUF0 ; TX -> RXed character
reti ;
;
;------------------------------------------------------------------------------
; Interrupt Vectors
;------------------------------------------------------------------------------
ORG 0FFFEh ;
DW RESET ; POR, ext. Reset, Watchdog
ORG 0FFF2h ;
DW USART0RX_ISR ; USART0 receive
END
?? 快捷鍵說明
復(fù)制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號(hào)
Ctrl + =
減小字號(hào)
Ctrl + -