PIC24FJ128GA010 FAMILY
DS39747F-page 122
2005-2012 Microchip Technology Inc.
To generate a single output pulse, the following steps
are required (these steps assume the timer source is
initially turned off, but this is not a requirement for the
module operation):
1.
Determine the instruction clock cycle time. Take
into account the frequency of the external clock
to the timer source (if one is used) and the timer
prescaler settings.
2.
Calculate time to the rising edge of the output
pulse relative to the TMRy start value (0000h).
3.
Calculate the time to the falling edge of the pulse
based on the desired pulse width and the time to
the rising edge of the pulse.
4.
Write the values computed in Steps 2 and 3
above into the Compare register, OCxR, and the
Secondary
Compare
register,
OCxRS,
respectively.
5.
Set the Timer Period register, PRy, to a value
equal to or greater than the value in OCxRS, the
Secondary Compare register.
6.
Set the OCM bits to ‘100’ and the OCTSEL
(OCxCON<3>) bit to the desired timer source.
The OCx pin state will now be driven low.
7.
Set the TON (TyCON<15>) bit to ‘1’, which
enables the compare time base to count.
8.
Upon the first match between TMRy and OCxR,
the OCx pin will be driven high.
9.
When the incrementing timer, TMRy, matches the
Secondary Compare register, OCxRS, the
second and trailing edge (high-to-low) of the pulse
is driven onto the OCx pin. No additional pulses
are driven onto the OCx pin and it remains at low.
As a result of the second compare match event,
the OCxIF interrupt flag bit is set which will result
in an interrupt, if it is enabled, by setting the
OCxIE bit. For further information on periph-
10. To initiate another single pulse output, change the
Timer and Compare register settings, if needed,
and then issue a write to set the OCM bits to ‘100’.
Disabling and re-enabling of the timer, and clear-
ing the TMRy register are not required, but may
be advantageous for defining a pulse from a
known event time boundary.
The output compare module does not have to be dis-
abled after the falling edge of the output pulse. Another
pulse can be initiated by rewriting the value of the
OCxCON register.
14.3
Setup for Continuous Output
Pulse Generation
When the OCM control bits (OCxCON<2:0>) are set to
‘101’, the selected output compare channel initializes
the OCx pin to the low state, and generates output
pulses on each and every compare match event.
For the user to configure the module for the generation
of a continuous stream of output pulses, the following
steps are required (these steps assume the timer
source is initially turned off, but this is not a requirement
for the module operation):
1.
Determine the instruction clock cycle time. Take
into account the frequency of the external clock
to the timer source (if one is used) and the timer
prescaler settings.
2.
Calculate the time to the rising edge of the output
pulse relative to the TMRy start value (0000h).
3.
Calculate the time to the falling edge of the pulse,
based on the desired pulse width and the time to
the rising edge of the pulse.
4.
Write the values computed in Step 2 and 3
above, into the Compare register, OCxR, and
the Secondary Compare register, OCxRS,
respectively.
5.
Set the Timer Period register, PRy, to a value,
equal to or greater than, the value in OCxRS, the
Secondary Compare register.
6.
Set the OCM bits to ‘101’ and the OCTSEL bit to
the desired timer source. The OCx pin state will
now be driven low.
7.
Enable the compare time base by setting the TON
(TyCON<15>) bit to ‘1’.
8.
Upon the first match between TMRy and OCxR,
the OCx pin will be driven high.
9.
When the compare time base, TMRy, matches
the Secondary Compare register, OCxRS, the
second and trailing edge (high-to-low) of the pulse
is driven onto the OCx pin.
10. As a result of the second compare match event,
the OCxIF interrupt flag bit is set.
11. When the compare time base and the value in its
respective Period register match, the TMRy
register resets to 0x0000 and resumes counting.
12. Steps 8 through 11 are repeated and a continuous
stream of pulses is generated indefinitely. The
OCxIF flag is set on each OCxRS-TMRy compare
match event.