logo
HomeAbout  |  Products  |  ApplicationsDownload  |  Contact Us  |  中文
 
Home-> Products-> 8-bit MCU
 
IC Induction
Develop & Tool
Application Project
Customer Service
 
Quick Coding
1 IO Ports 2 AD Converter
3 Timers 4 Capture
5 Compare 6 PWM 7 Interval Timer and Buzzer 8 External Interrupts
9 SPI 10 UART 11 LVR 12 Watch Dog Timer
13 STOP Mode 14 HALT Mode    

4 Capture

1. Set Timer0 as 8-bit capture operation: Input pulse high width measurement on PB0, rising edge samples data and falling edge evokes CAP0 interrupt.

  clr  P_IOB_Data,0
  clr  P_IOB_Attrib,0
  clr  P_IOB_Dir,0 ;Set PB0 as input pull low for CAP0 lda #$0
  sta  P_TMR0_Preload ;Set Timer0 preload counter= 0
   
  lda  P_TMR0_1_Ctrl1
  and  #$F0
  ora  #C_T0FCS_Div_512
  sta  P_TMR0_1_Ctrl1 ;Set Timer0 clock source is Fsys(8000000)/512=15.6KHz
   
  lda  P_TMR0_1_Ctrl0
  and  #$F0
  ora  #C_T08B_CAP
  sta  P_TMR0_1_Ctrl0 ;Set Timer0 is 8-bit capture
   
  clr  P_CAP_Ctrl, CB_CAP0_ES
     ;rising edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP0
     ;CAP0 int edge opposite to sample edge
  set  P_INT_Flag1,CB_INT_CAP0IF
     ;clear int flag
  set  P_INT_Ctrl1,CB_INT_CAP0IE
     ;set cap0 INT
  cli
     ;read idth capture result from P_TMR0_Cap

2. Set Timer0 as 8-bit capture operation: Input pulse low width measurement on PB0, falling edge samples data and rising edge evokes CAP0 interrupt.

  clr  P_IOB_Data,0
  clr  P_IOB_Attrib,0
  clr  P_IOB_Dir,0 ;Set PB0 as input pull low for CAP0 lda #$0
  sta  P_TMR0_Preload ;Set Timer0 preload counter= 0
   
  lda  P_TMR0_1_Ctrl1
  and  #$F0
  ora  #C_T0FCS_Div_512
  sta  P_TMR0_1_Ctrl1 ;Set Timer0 clock source is Fsys(8000000)/512=15.6KHz
   
  lda  P_TMR0_1_Ctrl0
  and  #$F0
  ora  #C_T08B_CAP
  sta  P_TMR0_1_Ctrl0 ;Set Timer0 is 8-bit capture
   
  set  P_CAP_Ctrl,CB_CAP0_ES
     ; falling edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP0
     ;CAP0 int edge opposite to sample edge
  set  P_INT_Flag1,CB_INT_CAP0IF
     ;clear int flag
  set  P_INT_Ctrl1,CB_INT_CAP0IE
     ;set cap0 INT
  cli
     ;read Width capture result from P_TMR0_Cap

3. Set Timer1 as 8-bit capture operation: Input pulse high width measurement on PB1, rising edge samples data and falling edge evokes CAP1 interrupt.

  clr  P_IOB_Data,1
  clr  P_IOB_Attrib,1
  clr  P_IOB_Dir,1 ;Set PB1 as input pull low for cap1 lda #$0
  sta  P_TMR1_Preload ;Set Timer1 preload counter= 0
   
  lda  P_TMR0_1_Ctrl1
  and  #$0F
  ora  #C_T1FCS_Div_512
  sta  P_TMR0_1_Ctrl1 ;Set Timer1 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR0_1_Ctrl0
  and  #$0F
  ora  #C_T18B_CAP
  sta  P_TMR0_1_Ctrl0 ;Set Timer1 is 8-bit capture
   
  clr  P_CAP_Ctrl,CB_CAP1_ES
     ;rising edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP1
     ;cap1 int edge opposite to sample edge
  set  P_INT_Flag1,CB_INT_CAP1IF
     ;clear int flag
  set  P_INT_Ctrl1,CB_INT_CAP1IE
     ;set cap1 INT
  cli
     ; read Width capture result from P_TMR1_Cap

4. Set Timer1 as 8-bit capture operation: Input pulse low width measurement on PB1, falling edge samples data and rising edge evokes CAP1 interrupt.

  clr  P_IOB_Data,1
  clr  P_IOB_Attrib,1
  clr  P_IOB_Dir,1 ;Set PB1 as input pull low for CAP1 lda #$0
  sta  P_TMR1_Preload ;Set Timer1 preload counter= 0
   
  lda  P_TMR0_1_Ctrl1
  and  #$0F
  ora  #C_T1FCS_Div_512
  sta  P_TMR0_1_Ctrl1 ;Set Timer1 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR0_1_Ctrl0
  and  #$0F
  ora  #C_T18B_CAP
  sta  P_TMR0_1_Ctrl0 ;Set Timer1 is 8-bit capture
   
  set  P_CAP_Ctrl,CB_CAP1_ES
     ;falling edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP1
     ;CAP1 int edge opposite to sample edge
  set  P_INT_Flag1,CB_INT_CAP1IF
     ;clear int flag
  set  P_INT_Ctrl1,CB_INT_CAP1IE
     ;set  cap1 INT
  cli
     ; read Width capture result from P_TMR1_Cap

5. Set Timer1 as 8-bit capture operation: Capture cycle on PB1, rising edge samples data and rising edge evokes CAP1 interrupt.

  clr  P_IOB_Data,1
  clr  P_IOB_Attrib,1
  clr  P_IOB_Dir,1 ;Set PB1 as input pull low for CAP1 lda #$0
  sta  P_TMR1_Preload ;Set Timer1 preload counter= 0
   
  lda  P_TMR0_1_Ctrl1
  and  #$0F
  ora  #C_T1FCS_Div_512
  sta  P_TMR0_1_Ctrl1 ;Set Timer1 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR0_1_Ctrl0
  and  #$0F
  ora  #C_T18B_CAP
  sta  P_TMR0_1_Ctrl0 ;Set Timer1 is 8-bit capture
   
  clr  P_CAP_Ctrl, CB_CAP1_ES
     ;rising edge sample data
  set  P_CAP_Ctrl,CB_CAP_IP1
     ; cap1 int edge same with sample edge
  set  P_INT_Flag1 ,CB_INT_CAP1IF
     ;clear int flag
  set  P_INT_Ctrl1, CB_INT_CAP1IE
     ;set cap1 INT
  cli
     ; read Width capture result from P_TMR1_Cap
     ; read Period result from P_TMR1_CapHi

6. Set Timer1 as 8-bit capture operation: Capture cycle on PB1, falling edge samples data and falling edge evokes CAP1 interrupt.

  clr  P_IOB_Data,1
  clr  P_IOB_Attrib,1
  clr  P_IOB_Dir,1 ;Set PB1 as input pull low for CAP1 lda #$0
  sta  P_TMR1_Preload ;Set Timer1 preload counter= 0
   
  lda  P_TMR0_1_Ctrl1
  and  #$0F
  ora  #C_T1FCS_Div_512
  sta  P_TMR0_1_Ctrl1 ;Set Timer1 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR0_1_Ctrl0
  and  #$0F
  ora  #C_T18B_CAP
  sta  P_TMR0_1_Ctrl0 ;Set Timer1 is 8-bit capture
   
  set  P_CAP_Ctrl,CB_CAP1_ES
     ;falling edge sample data
  set  P_CAP_Ctrl,CB_CAP_IP1
     ;CAP1 int edge same with sample edge
  set  P_INT_Flag1,CB_INT_CAP1IF
     ;clear int flag
  set  P_INT_Ctrl1,CB_INT_CAP1IE
     ;set cap1 INT
  cli
     ; read Period result from P_TMR1_CapHi and P_TMR1_Cap

7. Set Timer1 as 16-bit capture operation: Input pulse high width measurement on PB1, rising edge samples data and falling edge evokes CAP1 interrupt.

  clr  P_IOB_Data,1
  clr  P_IOB_Attrib,1
  clr  P_IOB_Dir,1 ;Set PB1 as input pull low for CAP1 lda #$0
  sta  P_TMR1_Preload ;Set Timer1 preload counter= 0
   
  lda  P_TMR0_1_Ctrl1
  and  #$0F
  ora  #C_T1FCS_Div_512
  sta  P_TMR0_1_Ctrl1 ;Set Timer1 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR0_1_Ctrl0
  and  #$0F
  ora  #C_T116B_CAP
  sta  P_TMR0_1_Ctrl0 ;Set Timer1 is 16-bit capture
   
  clr  P_CAP_Ctrl,CB_CAP1_ES
     ;rising edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP1
     ;CAP1 int edge opposite to sample edge
  set  P_INT_Flag1,CB_INT_CAP1IF
     ;clear int flag
  set  P_INT_Ctrl1,CB_INT_CAP1IE
     ;set cap1 INT
  cli
     ; read Period result from P_TMR1_CapHi and P_TMR1_Cap

8. Set Timer1 as 16-bit capture operation: Input pulse low width measurement on PB1, falling edge samples data and rising edge evokes CAP1 interrupt.

  clr  P_IOB_Data,1
  clr  P_IOB_Attrib,1
  clr  P_IOB_Dir,1 ;Set PB1 as input pull low for CAP1 lda #$0
  sta  P_TMR1_Preload ;Set Timer1 preload counter= 0
   
  lda  P_TMR0_1_Ctrl1
  and  #$0F
  ora  #C_T1FCS_Div_512
  sta  P_TMR0_1_Ctrl1 ;Set Timer1 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR0_1_Ctrl0
  and  #$0F
  ora  #C_T116B_CAP
  sta  P_TMR0_1_Ctrl0 ;Set Timer1 is 16-bit capture
   
  set  P_CAP_Ctrl,CB_CAP1_ES
     ;falling edge sample data
  clr P_CAP_Ctrl,CB_CAP_IP1
     ;CAP int edge opposite to sample edge
  set P_INT_Flag1,CB_INT_CAP1IF
     ;clear int flag
  set P_INT_Ctrl1,CB_INT_CAP1IE
     ;set cap1 INT
  cli
     ; read Period result from P_TMR1_CapHi and P_TMR1_Cap

9. Set Timer2 as 8-bit capture operation: Input pulse high width measurement on PB4, rising edge samples data and falling edge evokes CAP2 interrupt.

  clr  P_IOB_Data,4
  clr  P_IOB_Attrib,4
  clr  P_IOB_Dir,4 ;Set PB4 as input pull low for CAP2 lda #$0
  sta  P_TMR2_Preload ;Set Timer2 preload counter= 0
   
  lda  P_TMR2_3_Ctrl1
  and  #$F0
  ora  #C_T2FCS_Div_512
  sta  P_TMR2_3_Ctrl1 ;Set Timer2 clock source is Fsys(8000000)/512=15.6KHz
   
  lda  P_TMR2_3_Ctrl0
  and  #$F0
  ora  #C_T28B_CAP
  sta  P_TMR2_3_Ctrl0 ;Set Timer2 is 8-bit capture
   
  clr  P_IRQ_Opt1,CB_IRQOpt1_CAP2ES
  clr  P_IRQ_Opt1,CB_IRQOpt1_CAP2ES
     ;rising edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP2
     ;CAP2 int edge opposite to sample edge
  set  P_INT_Flag0,CB_INT_CAP2IF
     ;clear int flag
  set  P_INT_Ctrl0,CB_INT_CAP2IE
     ;set cap2 INT
  cli
     ;read Width capture result from P_TMR2_Cap

10. Set Timer2 as 8-bit capture operation: Input pulse low width measurement on PB4, falling edge samples data and rising edge evokes CAP2 interrupt.

  clr  P_IOB_Data,4
  clr  P_IOB_Attrib,4
  clr  P_IOB_Dir,4 ;Set PB4 as input pull low for CAP2 lda #$0
  sta  P_TMR2_Preload ;Set Timer2 preload counter= 0
   
  lda  P_TMR2_3_Ctrl1
  and  #$F0
  ora  #C_T2FCS_Div_512
  sta  P_TMR2_3_Ctrl1 ;Set Timer2 clock source is Fsys(8000000)/512=15.6KHz
   
  lda  P_TMR2_3_Ctrl0
  and  #$F0
  ora  #C_T28B_CAP
  sta  P_TMR2_3_Ctrl0 ;Set Timer2 is 8-bit capture
   
  set  P_IRQ_Opt1,CB_IRQOpt1_CAP2ES
  set  P_IRQ_Opt1,CB_IRQOpt1_CAP2ES
     ;falling edge sample data,need write twice
  clr  P_CAP_Ctrl,CB_CAP_IP2
     ;CAP2 int edge opposite to sample edge
  set  P_INT_Flag0,CB_INT_CAP2IF
     ;clear int flag
  set  P_INT_Ctrl0,CB_INT_CAP2IE
     ;set cap2 INT
  cli
     ;read Width capture result from P_TMR2_Cap

11. Set Timer3 as 8-bit capture operation: Input pulse high width measurement on PB5, rising edge samples data and falling edge evokes CAP3 interrupt.

  clr  P_IOB_Data,5
  clr  P_IOB_Attrib,5
  clr  P_IOB_Dir,5 ;Set PB5 as input pull low for cap3 lda #$0
  sta  P_TMR3_Preload ;Set Timer3 preload counter= 0
   
  lda  P_TMR2_3_Ctrl1
  and  #$0F
  ora  #C_T3FCS_Div_512
  sta  P_TMR2_3_Ctrl1 ;Set Timer3 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR2_3_Ctrl0
  and  #$0F
  ora  #C_T38B_CAP
  sta  P_TMR2_3_Ctrl0 ;Set Timer3 is 8-bit capture
   
  clr  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
  clr  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
     ;rising edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP3
     ;cap3 int edge opposite to sample edge
  set  P_INT_Flag0,CB_INT_CAP3IF
     ;clear int flag
  set  P_INT_Ctrl0,CB_INT_CAP3IE
     ;set cap3 INT
  cli
     ; read Width capture result from P_TMR3_Cap  

12. Set Timer3 as 8-bit capture operation: Input pulse low width measurement on PB5, falling edge samples data and rising edge evokes CAP3 interrupt.

  clr  P_IOB_Data,5
  clr  P_IOB_Attrib,5
  clr  P_IOB_Dir,5 ;Set PB5 as input pull low for cap3
   
  lda  #$0
  sta  P_TMR3_Preload ;Set Timer3 preload counter= 0
   
  lda  P_TMR2_3_Ctrl1
  and  #$0F
  ora  #C_T3FCS_Div_512
  sta  P_TMR2_3_Ctrl1 ;Set Timer3 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR2_3_Ctrl0
  and  #$0F
  ora  #C_T38B_CAP
  sta  P_TMR2_3_Ctrl0 ;Set Timer3 is 8-bit capture
   
  set  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
  set  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
     ;falling edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP3
     ;cap3 int edge opposite to sample edge
  set  P_INT_Flag0,CB_INT_CAP3IF
     ;clear int flag
  set  P_INT_Ctrl0,CB_INT_CAP3IE
     ;set cap3 INT
  cli
     ; read Width capture result from P_TMR3_Cap

13. Set Timer3 as 8-bit capture operation: Capture (Width, Cycle) on PB5, falling edge samples data and falling edge evokes CAP3 interrupt.

  clr  P_IOB_Data,5
  clr  P_IOB_Attrib,5
  clr  P_IOB_Dir,5 ;Set PB5 as input pull low for cap3
   
  lda  #$0
  sta  P_TMR3_Preload ;Set Timer3 preload counter= 0
   
  lda  P_TMR2_3_Ctrl1
  and  #$0F
  ora  #C_T3FCS_Div_512
  sta  P_TMR2_3_Ctrl1 ;Set Timer3 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR2_3_Ctrl0
  and  #$0F
  ora  #C_T38B_CAP
  sta  P_TMR2_3_Ctrl0 ;Set Timer3 is 8-bit capture
   
  set  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
  set  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
     ;falling edge sample data
  set  P_CAP_Ctrl,CB_CAP_IP3
     ;cap3 int edge same with sample edge
  set  P_INT_Flag0,CB_INT_CAP3IF
     ;clear int flag
  set  P_INT_Ctrl0,CB_INT_CAP3IE
     ;set cap3 INT
  cli
     ; read Width capture result from P_TMR3_Cap
     ; read Period result from P_TMR3_CapHi

14. Set Timer3 as 8-bit capture operation: Capture (Width, Cycle) on PB5, rising edge samples data and rising edge evokes CAP3 interrupt.

  clr  P_IOB_Data,5
  clr  P_IOB_Attrib,5
  clr  P_IOB_Dir,5 ;Set PB5 as input pull low for cap3
   
  lda  #$0
  sta  P_TMR3_Preload ;Set Timer3 preload counter= 0
   
  lda  P_TMR2_3_Ctrl1
  and  #$0F
  ora  #C_T3FCS_Div_512
  sta  P_TMR2_3_Ctrl1 ;Set Timer3 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR2_3_Ctrl0
  and  #$0F
  ora  #C_T38B_CAP
  sta  P_TMR2_3_Ctrl0 ;Set Timer3 is 8-bit capture
   
  clr  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
  clr  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
     ;rising edge sample data
  set  P_CAP_Ctrl,CB_CAP_IP3
     ;cap3 int edge same with sample edge
  set  P_INT_Flag0,CB_INT_CAP3IF
     ;clear int flag
  set  P_INT_Ctrl0,CB_INT_CAP3IE
     ;set cap3 INT
  cli
     ; read Width capture result from P_TMR3_Cap
     ; read Period result from P_TMR3_CapHi

15. Set Timer3 as 16-bit capture operation: Input pulse high width measurement on PB5, rising edge samples data and falling edge evokes CAP3 interrupt.

  clr  P_IOB_Data,5
  clr  P_IOB_Attrib,5
  clr  P_IOB_Dir,5 ;Set PB5 as input pull low for cap3
   
  lda  #$0
  sta  P_TMR3_Preload ;Set Timer3 preload counter= 0
   
  lda  P_TMR2_3_Ctrl1
  and  #$0F
  ora  #C_T3FCS_Div_512
  sta  P_TMR2_3_Ctrl1 ;Set Timer3 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR2_3_Ctrl0
  and  #$0F
  ora  #C_T316B_CAP
  sta  P_TMR2_3_Ctrl0 ;Set Timer3 is 16-bit capture
   
  clr  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
  clr  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
     ;rising edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP3
     ;cap3 int edge opposite to sample edge
  set  P_INT_Flag0,CB_INT_CAP3IF
     ;clear int flag
  set  P_INT_Ctrl0,CB_INT_CAP3IE
     ;set cap3 INT
  cli
     ; read Period result from P_TMR3_CapHi and P_TMR3_Cap

16. Set Timer3 as 16-bit capture operation: Input pulse low width measurement on PB5, falling edge samples data and rising edge evokes CAP3 interrupt.

  clr  P_IOB_Data,5
  clr  P_IOB_Attrib,5
  clr  P_IOB_Dir,5 ;Set PB5 as input pull low for cap3
   
  lda  #$0
  sta  P_TMR3_Preload ;Set Timer3 preload counter= 0
   
  lda  P_TMR2_3_Ctrl1
  and  #$0F
  ora  #C_T3FCS_Div_512
  sta  P_TMR2_3_Ctrl1 ;Set Timer3 clock source is Fsys(8000000)/512=15.6KHz
  lda  P_TMR2_3_Ctrl0
  and  #$0F
  ora  #C_T316B_CAP
  sta  P_TMR2_3_Ctrl0 ;Set Timer3 is 16-bit capture
   
  set  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
  set  P_IRQ_Opt1,CB_IRQOpt1_CAP3ES
     ;falling edge sample data
  clr  P_CAP_Ctrl,CB_CAP_IP3
     ;cap3 int edge opposite to sample edge
  set  P_INT_Flag0,CB_INT_CAP3IF
     ;clear int flag
  set  P_INT_Ctrl0,CB_INT_CAP3IE
     ;set cap3 INT
  cli
     ; read Period result from P_TMR3_CapHi and P_TMR3_Cap
Copyright © BEIJING SUNNORTH TECHNOLOGY CO., LTD Web site:mcu.sunplusmcu.com online real name:凌阳单片机
Unauthorized copy or republish to the content of this website is forbidden. Any one cannot resume on ICP备05061966号