
MOTOROLA
10-42
MAIN TIMER AND REAL-TIME INTERRUPT
M68HC11
REFERENCE MANUAL
In the normal compare match situation, the timer count is compared to the value in a
TOCx register during PH2 high. Timer counting occurs at the falling edges of PH2 to
prevent interference between counting and comparisons. PH2 is an internal clock that
leads E by 90
°
. When the match is detected [1], OCxF is set at the falling edge PH2
where the match was true. The pin-state change (if any) is delayed by another quarter
cycle so changes will occur at the falling edge of the E clock. If there were a prescale
factor, the compare true would occur during the first PH2 cycle where the count
matched the TOCx value. Additional matches would be inhibited until the next timer
clock or until TOCx is written. This inhibit mechanism protects against multiple com-
pare matches during a prescaled timer count (the TOCx register actually matches the
timer count for several PH2 cycles when there is a prescale factor). In the unlikely case
of a big prescale factor (e.g.,
÷
16) and a match at the start of count $nnnn, if the user
wrote $nnnn to the TOCx register while the count was still $nnnn, the output-compare
actions would be retriggered.
Figure 10-16 Output-Compare Timing Details
At [4] in
Figure 10-16
, the one-cycle compare inhibit results from a write to TOCx dur-
ing cycle [3]. This inhibit mechanism prevents an erroneous compare during the write
to the low-order half of TOCx. If the output compare were not inhibited here, the TOCx
register would contain an erroneous value composed of the new high byte written at
[3] and the low byte from the former value in TOCx. This inhibit mechanism is separate
from the compare mechanism discussed in the previous paragraph.
10.6 Listing of Timer Examples
The following listing is a composite of timer section Examples 10–1 through 10–7.
Since many of the references and equates are common for all the examples, it saves
space to group them. All the examples can be assembled and loaded into an EVB
board for evaluation at the same time. In general, the user must set up some initial sig-
nals and variables, and then execute an EVB "go" command to start each example
routine.
TIMER COUNT
N 1
N+1
N
N+2
N+3
N+4
PH2
E
WRITE TOCx (HI)
WRITE TOCx (LO)
OCx PIN
[3]
[1]
OCxF
[2]
COMPARE
ENABLE
MATCH
[4]
PREVIOUS PIN STATE
NEW PIN STATE