data:image/s3,"s3://crabby-images/9162f/9162fabf2356f81e9eb9dff0c7878ad73118ee63" alt=""
13.4.5
Pulse width measurement mode
In the pulse width measurement mode, the up counter starts counting at the rising/falling edge(s) of the input
to the TCA0 pin and measures the input pulse width based on the internal clock.
13.4.5.1
Setting
Setting the operation mode selection TA0MOD<TA0M> to "110" activates the pulse width measurement
mode. Select the source clock at TA0MOD<TA0CK>.
Select the trigger edge at the trigger edge input selection TA0MOD<TA0TED>. Setting
TA0MOD<TA0TED> to "0" selects the rising edge, and setting it to "1" selects the falling edge as a trigger
to start the capture.
The operation after capturing is determined by the pulse width measurement mode control
TA0MOD<TA0MCAP>. Setting TA0MOD<TA0MCAP> to "0" selects the double-edge capture. Setting
TA0MOD<TA0MCAP> to "1" selects the single-edge capture.
The operation to be executed in case of an overflow of the up counter can be selected at the overflow
interrupt control TA0CR<TA0OVE>. Setting TA0OVE to "1" makes an INTTCA0 interrupt request occur
in case of an overflow. Setting TA0OVE to "0" makes no INTTCA0 interrupt request occur in case of an
overflow.
Note that this mode uses the TA0 input pin, and the TCA0 pin must be set to the input mode beforehand
in port settings.
The operation is started by setting TA0CR<TA0S> to "1". In this time, TA0DRA and TA0DRB register
are initialized to "0x0000". After the timer is started, writing to TA0MOD and TA0CR<TA0OVE> is disabled.
Be sure to complete the required mode settings before starting the timer.
13.4.5.2
Operation
After the timer is started, when the selected trigger edge (start edge) is input to the TCA0 pin, INTTCA0
interrupt request is generated, and then the up counter increments according to the selected source clock.
Subsequently, when the edge opposite to the selected edge is detected, the up counter value is captured into
TA0DRB, an INTTCA0 interrupt request is generated, and TA0SR<TA0CPFB> is set to "1". Depending on
the TA0MOD<TA0MCAP> setting, the operation differs as follows:
·
Double-edge capture (When TA0MOD<TA0MCAP> is "0")
The up counter continues counting up after the edge opposite to the selected edge is detected.
Subsequently, when the selected trigger edge is input, the up counter value is captured into
TA0DRA, an INTTCA0 interrupt request is generated, and TA0SR<TA0CPFA> is set to "1". At
this time, the up counter is cleared to "0x0000".
·
Single-edge capture (When TA0MOD<TA0MCAP> is "1")
The up counter stops counting up and is cleared to "0x0000" when the edge opposite to the
selected edge is detected. Subsequently, when the start edge is input, INTTCA0 interrupt request
is generated, and then the up counter restarts increment.
When the up counter overflows during capturing, the overflow flag TA0SR<TA0OVF> is set to "1". At
this time, an INTTCA0 interrupt request occurs if the overflow interrupt control TA0CR<TA0OVE> is set
to "1".
The capture completion flags (TA0SR<TA0CPFA, TA0CPFB> and the overflow flag
(TA0SR<TA0OVF>) are cleared to "0" automatically when TA0SR is read.
TMP89FH42
Page 167
RB002