📄 fet120_adc10_11.s43
字号:
;******************************************************************************
; MSP-FET430P120 Demo - ADC10, Sample A0, 1.5V, TA1 Trig, Set P1.0 if > 0.5V
;
; Description: A0 is sampled 16/second (ACLK/2048) with reference to 1.5V.
; Timer_A is run in upmode and TA1 is used to automatically trigger
; ADC10 conversion, TA0 defines the period. Internal oscillator times sample
; (16x) and conversion (13x). Inside ADC10_ISR if A0 > 0.5Vcc, P1.0 is set,
; else reset. Normal mode is LPM3.
; //* An external watch crystal on XIN XOUT is required for ACLK *//
; //* MSP430F1232 or MSP430F1132 Device Required *//
;
; MSP430F1232
; -----------------
; /|\| XIN|-
; | | | 32kHz
; --|RST XOUT|-
; | |
; >---|A0 P1.0 |--> LED
;
; M. Buccini
; Texas Instruments Inc.
; Feb 2005
; Built with IAR Embedded Workbench Version: 3.21A
;******************************************************************************
#include <msp430x12x2.h>
;------------------------------------------------------------------------------
ORG 0E000h ; Program Start
;------------------------------------------------------------------------------
RESET mov.w #0300h,SP ; Initialize stackpointer
StopWDT mov.w #WDTPW+WDTHOLD,&WDTCTL ; Stop WDT
SetupADC10 mov.w #SHS_1+CONSEQ_2,&ADC10CTL1 ; TA1 trigger sample start
mov.w #SREF_1+ADC10SHT_2+REFON+ADC10ON+ADC10IE,&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
bis.w #ENC,&ADC10CTL0 ; ADC10 enable set
bis.b #001h,&ADC10AE ; P2.0 ADC10 option select
SetupP1 bis.b #001h,&P1DIR ; P1.0 output
SetupC0 mov.w #2048-1,&CCR0 ; PWM Period
SetupC1 mov.w #OUTMOD_3,&CCTL1 ; CCR1 set/reset
mov.w #2047,&CCR1 ; CCR1 PWM Duty Cycle
SetupTA mov.w #TASSEL_1+MC_1,TACTL ; ACLK, up mode
;
Mainloop bis.w #LPM3+GIE,SR ; Enter LPM3
nop ; Required only for debugger
;
;------------------------------------------------------------------------------
TA0_ISR; ISR for CCR0
;------------------------------------------------------------------------------
clr &TACTL ; clear Timer_A control registers
bic #LPM0,0(SP) ; Exit LPMx, interrupts enabled
reti ;
;------------------------------------------------------------------------------
;------------------------------------------------------------------------------
ADC10_ISR;
;------------------------------------------------------------------------------
bic.b #01h,&P1OUT ; P1.0 = 0
cmp.w #0155h,&ADC10MEM ; ADC10MEM = A0 > 0.5V?
jlo ADC10_Exit ; Again
bis.b #01h,&P1OUT ; P1.0 = 1
ADC10_Exit reti ;
;
;------------------------------------------------------------------------------
; Interrupt Vectors
;------------------------------------------------------------------------------
ORG 0FFFEh ; MSP430 RESET Vector
DW RESET ;
ORG 0FFEAh ; ADC10 Vector
DW ADC10_ISR ;
ORG 0FFF2h ; Timer_A0 Vector
DW TA0_ISR ;
END
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -