📄 msp430x20x2_adc10_06.s43
字号:
;*******************************************************************************
; MSP430F20x2 Demo - ADC10, Output Internal Vref on P1.4 & ADCCLK on P1.3
;
; Description: Output ADC10 internal Vref on P1.4, toggling between two
; available options, 2.5V and 1.5V. ADC10OSC also output on P1.3.
;
; MSP430F20x2
; ----------------
; /|\| XIN|-
; | | |
; --|RST XOUT|-
; | |
; | P1.3/ADC10CLK|--> ADC10OSC ~ 3.5MHz - 6.5MHz
; | P1.4/A4|--> Vref
;
; L. Westlund
; Texas Instruments Inc.
; May 2006
; Built with IAR Embedded Workbench Version: 3.41A
;*******************************************************************************
#include "msp430x20x2.h"
;-------------------------------------------------------------------------------
RSEG CSTACK ; Define stack segment
;-------------------------------------------------------------------------------
RSEG CODE ; Assemble to Flash memory
;-------------------------------------------------------------------------------
RESET mov.w #SFE(CSTACK),SP ; Initialize stackpointer
StopWDT mov.w #WDTPW+WDTHOLD,&WDTCTL ; Stop WDT
SetupADC10 mov.w #CONSEQ_2,&ADC10CTL1 ; Repeat single channel
mov.w #REFOUT+REFON+MSC+ADC10ON,&ADC10CTL0; ADC10 and VRef
mov.w #30,&TACCR0 ; Delay to allow Ref to settle
bis.w #CCIE,&TACCTL0 ; Compare-mode interrupt.
mov.w #TACLR+MC_1+TASSEL_2,&TACTL; up mode, SMCLK
bis.w #LPM0+GIE,SR ; Enter LPM0, enable interrupts
bic.w #CCIE,&TACCTL0 ; Disable timer interrupt
dint ; Disable Interrupts
bis.b #010h,&ADC10AE0 ; P1.4 = ADC10 option select
bis.b #008h,&P1DIR ; P1.3 = output directon
bis.b #008h,&P1SEL ; P1.3 = ADC10OSC option select
;
Mainloop bic.w #ENC,&ADC10CTL0 ; ADC10 disable
xor.w #REF2_5V,&ADC10CTL0 ; Toggle Vref 1.5/2.5V
bis.w #ENC+ADC10SC,&ADC10CTL0 ; ADC10 enable, start conversion
Delay mov.w #00Fh,R15 ; Long Delay
mov.w #0,R14 ;
Delay_1 dec.w R14 ;
sbc.w R15 ;
jnz Delay_1 ;
jmp Mainloop ;
;
;-------------------------------------------------------------------------------
TA0_ISR; ISR for TACCR0
;-------------------------------------------------------------------------------
clr.w &TACTL ; Clear Timer_A control registers
bic.w #LPM0,0(SP) ; Exit LPM0 on reti
reti ;
;-------------------------------------------------------------------------------
COMMON INTVEC ; Interrupt Vectors
;-------------------------------------------------------------------------------
ORG TIMERA0_VECTOR ; Timer_A0 Vector
DW TA0_ISR
ORG RESET_VECTOR ; POR, ext. Reset
DW RESET
END
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -