msp430x24x_adc12_04.s43
来自「步进电机驱动程序msp430f247单片机」· S43 代码 · 共 61 行
S43
61 行
;*******************************************************************************
; MSP430x24x Demo - ADC12, Extend Sampling Period with SHT Bits
;
; This example shows how to extend the sampling time using the sampling
; timer. In this example, the ADC12OSC is used to provide the sampling period
; and the SHT0 bits are set to extend the sampling period to 4xADC12CLKx256.
; A single conversion is performed on channel A0. The A/D conversion results
; are stored in ADC12MEM0 and are moved to R5 upon completion of the
; conversion. Test by setting and running to a break point at "jmp Mainloop."
; To view the conversion results, open a register window in debugger and view
; the contents of R5.
;
; MSP430x24x
; ---------------
; | XIN|-
; Vin -->|P6.0/A0 | 32kHz
; | XOUT|-
;
;
; B. Nisarga
; Texas Instruments Inc.
; September 2007
; Built with IAR Embedded Workbench Version: 3.42A
;*******************************************************************************
#include "msp430x24x.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 watchdog
;
SetupADC12 mov.w #ADC12ON+SHT0_15,&ADC12CTL0 ; Turn on ADC12, set SHT0
; for longer sampling
mov.w #SHP,&ADC12CTL1 ; Use sampling timer
bis.w #01h,&ADC12IE ; Enable ADC12IFG.0 for ADC12MEM0
bis.w #ENC,&ADC12CTL0 ; Enable conversions
;
Mainloop bis.w #ADC12SC,&ADC12CTL0 ; Start conversions
bis.w #LPM0+GIE,SR ; Wait for conversion completion
; Enable interrupts
nop ; Only required for CSPY
jmp Mainloop ; SET BREAKPOINT HERE
;
;-------------------------------------------------------------------------------
ADC12_ISR ; Interrupt Service Routine for ADC12
;-------------------------------------------------------------------------------
mov.w &ADC12MEM0,R5 ; Move result, IFG is reset
bic.w #CPUOFF,0(SP) ; Return active
reti ;
;
;-------------------------------------------------------------------------------
COMMON INTVEC ; Interrupt Vectors
;-------------------------------------------------------------------------------
ORG ADC12_VECTOR ; ADC12 Vector
DW ADC12_ISR
ORG RESET_VECTOR ; POR, ext. Reset
DW RESET
END
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?