📄 msp430x20x2_adc10_05.s43
字号:
;*******************************************************************************
; MSP430F20x2 Demo - ADC10, Sample A11, Lo_Batt, Set P1.0 if AVcc < 2.3V
;
; Description: A single sample is made on A11 (AVcc/2) with reference to
; internal 1.5V Vref. Software sets ADC10SC to start sample and conversion
; - ADC10SC automatically cleared at EOC. ADC10 internal oscillator times
; sample (16x) and conversion. ADC10BUSY flag is polled for EOC. If A11
; (AVcc/2) < 0311h (0.65V) indicating AVcc is less 2.3V, P1.0 set indicating
; a lo_Batt condition, else reset.
;
; MSP430F20x2
; --------------------
; /|\| XIN|-
; | | |
; --|RST XOUT|-
; | |
; |A11 (AVcc/2) P1.0 |--> LED
;
; 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 #INCH_11,&ADC10CTL1 ; AVcc/2
mov.w #SREF_1+ADC10SHT_2+REFON+ADC10ON,&ADC10CTL0;
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
SetupP1 bis.b #001h,&P1DIR ; P1.0 output
;
Mainloop bis.w #ENC+ADC10SC,&ADC10CTL0 ; Start sampling/conversion
L1 bit.w #ADC10BUSY,&ADC10CTL1 ; ADC10BUSY?
jnz L1 ;
cmp.w #0311h,&ADC10MEM ; ADC10MEM = A11 (AVcc/2) > 0.65V?
jlo lo_Batt ;
bic.b #01h,&P1OUT ; P1.0 = 0
jmp Mainloop ; Again
lo_Batt bis.b #01h,&P1OUT ; P1.0 = 1
jmp Mainloop ; Again
;
;-------------------------------------------------------------------------------
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 + -