📄 msp430x20x2_adc10_16.s43
字号:
;*******************************************************************************
; MSP430F20x2 Demo - ADC10, DTC Sample A0 -> TA1, AVcc, DCO
;
; Description: Use DTC to sample A0 with reference to AVcc and directly
; transfer code to CCR1. Timer_A has been configured for 10-bit PWM mode.
; CCR1 duty cycle is automatically proportional to ADC10 A0. WDT_ISR used
; as a period wakeup timer approximately 45ms based on default ~1.2MHz
; DCO/SMCLK clock source used in this example for the WDT clock source.
; Timer_A also uses default DCO.
;
; MSP430F20x2
; -----------------
; /|\| XIN|-
; | | |
; --|RST XOUT|-
; | |
; >---|P1.0/A0 P1.2|--> TACCR1 - 0-1024 PWM
;
; 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
SetupWDT mov.w #WDT_MDLY_32,&WDTCTL ; WDT ~45ms interval timer
bis.b #WDTIE,&IE1 ; Enable WDT interrupt
SetupADC10 mov.w #ADC10SHT_2+ADC10ON,&ADC10CTL0 ;
bis.b #01h,&ADC10AE0 ; P1.0 ADC option select
mov.b #001h,&ADC10DTC1 ; 1 conversion
SetupP1 bis.b #004h,&P1DIR ; P1.2 = output
bis.b #004h,&P1SEL ; P1.2 = TA1 output
SetupC0 mov.w #1024-1,&TACCR0 ; PWM Period
SetupC1 mov.w #OUTMOD_7,&TACCTL1 ; TACCR1 reset/set
mov.w #512,&TACCR1 ; TACCR1 PWM Duty Cycle
SetupTA mov.w #TASSEL_2+MC_1,&TACTL ; SMCLK, upmode
;
Mainloop bis.b #CPUOFF+GIE,SR ; LPM0, WDT_ISR will force exit
mov.w #TACCR1,&ADC10SA ; Data transfer location
bis.w #ENC+ADC10SC,&ADC10CTL0 ; Start sampling
jmp Mainloop ; Again
;
;-------------------------------------------------------------------------------
WDT_ISR; Exit LPM0 mode, reti returns system active
;-------------------------------------------------------------------------------
bic.w #CPUOFF,0(SP) ; Exit LPM0 on reti
reti ;
;
;-------------------------------------------------------------------------------
COMMON INTVEC ; Interrupt Vectors
;-------------------------------------------------------------------------------
ORG WDT_VECTOR ; Watchdog Timer
DW WDT_ISR
ORG RESET_VECTOR ; POR, ext. Reset
DW RESET
END
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -