GD32W51x User Manual
458
And CHxIF is asserted. If the CHxIF is high, the CHxOF will be asserted also. The interrupt
and DMA request will be asserted based on the configuration of CHxIE and CHxDEN in
TIMERx_DMAINTEN
Direct generation
: if you want to generate a DMA request or Interrupt, you can set CHxG by
software directly.
The input capture mode can be also used for pulse width measurement from signals on the
TIMERx_CHx pins. For example, PWM signal connect to CI0 input. Select channel 0 capture
signals to CI0 by setting CH0MS to 2
’
b01 in the channel control register (TIMERx_CHCTL0)
and set capture on rising edge. Select channel 1 capture signal to CI0 by setting CH1MS to
2
’
b10 in the channel control register (TIMERx_CHCTL0) and set capture on falling edge. The
counter set to restart mode and restart on channel 0 rising edge. Then the TIMERX_CH0CV
can measure the PWM period and the TIMERx_CH1CV can measure the PWM duty.
Output compare mode
Figure 17-13. Output compare logic (with complementary output, x=0,1,2)
Capture/
compare register
CHxCV
Counter
o
u
tp
u
t
co
m
p
a
ra
to
r
Compare
output control
CHxCOMCTL
CNT>CHxCV
CNT=CHxCV
CNT<CHxCV
Output
complementary
protection
register
&Dead-Time
Output enable
and polarity
selector
CHxP,CHxNP
CHxE,CHxNE
OxCPRE
CHx_O
CHx_ON
Figure 17-14. Output compare logic (CH3_O)
Capture/
compare register
CH3CV
Counter
o
u
tp
u
t
c
o
m
p
a
ra
to
r
Compare output
control
CH3COMCTL
Output enable
and polarity
selector
CH3P,CH3E
O3CPRE
CH3_O
CNT>CH3CV
CNT=CH3CV
CNT<CH3CV
Figure 17-13. Output compare logic (with complementary output, x=0,1,2)
17-14. Output compare logic (CH3_O)
show the logic circuit of output compare mode. The
relationship between the channel output signal CHx_O/CHx_ON and the OxCPRE signal
Channel output reference signal
) is described as blew: The active
level of O0CPRE is high, the output level of CH0_O/CH0_ON depends on OxCPRE signal,
CHxP/CHxNP bit and CH0E/CH0NE bit (please refer to the TIMERx_CHCTL2 register for
more details). For examples,
1)
Configure CHxP=0 (the active level of CHx_O is high, the same as OxCPRE), CHxE=1