9-7
PROGRAMMABLE COUNTER ARRAY
9.3.2
Compare Modes
The compare function provides the capability for operating the five modules as timers, event
counters, or pulse width modulators. Four modes employ the compare function: 16-bit software
timer mode, high-speed output mode, WDT mode, and PWM mode. In the first three of these, the
compare/capture module continuously compares the 16-bit PCA timer/counter value with the 16-
bit value pre-loaded into the module’s CCAPxH/CCAPxL register pair. In the PWM mode, the
module continuously compares the value in the low-byte PCA timer/counter register (CL) with
an 8-bit value in the CCAPxL module register. Comparisons are made three times per peripheral
cycle to match the fastest PCA timer/counter clocking rate (F
OSC
/4). For a description of periph-
eral cycle timing, see section 2.2.2, “Clock and Reset Unit.”
Setting the ECOMx bit in a module’s mode register (CCAPMx) selects the compare function for
that module (Figure 9-9 on page 9-15). To use the modules in the compare modes, observe the
following general procedure:
1.
Select the module’s mode of operation.
2.
Select the input signal for the PCA timer/counter.
3.
Load the comparison value into the module’s compare/capture register pair.
4.
Set the PCA timer/counter run control bit.
5.
After a match causes an interrupt, clear the module’s compare/capture flag.
9.3.3
16-bit Software Timer Mode
To program a compare/capture module for the 16-bit software timer mode (Figure 9-3), set the
ECOMx and MATx bits in the module’s CCAPMx register. Table 9-3 lists the bit combinations
for selecting module modes.
A match between the PCA timer/counter and the compare/capture registers (CCAPxH/CCAPxL)
sets the module’s compare/capture flag (CCFx in the CCON register). This generates an interrupt
request if the corresponding interrupt enable bit (ECCFx in the CCAPMx register) is set. Since
hardware does not clear the compare/capture flag when the interrupt is processed, the user must
clear the flag in software. During the interrupt routine, a new 16-bit compare value can be written
to the compare/capture registers (CCAPxH/CCAPxL).
NOTE
To prevent an invalid match while updating these registers, user software
should write to CCAPxL first, then CCAPxH. A write to CCAPxL clears the
ECOMx bit disabling the compare function, while a write to CCAPxH sets the
ECOMx bit re-enabling the compare function.
Summary of Contents for 8XC251SA
Page 2: ......
Page 3: ...May 1996 8XC251SA 8XC251SB 8XC251SP 8XC251SQ Embedded Microcontroller User s Manual...
Page 18: ......
Page 19: ...1 Guide to This Manual...
Page 20: ......
Page 30: ......
Page 31: ...2 Architectural Overview...
Page 32: ......
Page 41: ...3 Address Spaces...
Page 42: ......
Page 63: ...4 Device Configuration...
Page 64: ......
Page 81: ...5 Programming...
Page 82: ......
Page 102: ......
Page 103: ...6 Interrupt System...
Page 104: ......
Page 120: ......
Page 121: ...7 Input Output Ports...
Page 122: ......
Page 132: ......
Page 133: ...8 Timer Counters and Watchdog Timer...
Page 134: ......
Page 153: ...9 Programmable Counter Array...
Page 154: ......
Page 170: ......
Page 171: ...10 Serial I O Port...
Page 172: ......
Page 187: ...11 Minimum Hardware Setup...
Page 188: ......
Page 197: ...12 Special Operating Modes...
Page 198: ......
Page 206: ......
Page 207: ...13 External Memory Interface...
Page 208: ......
Page 239: ...14 Programming and Verifying Nonvolatile Memory...
Page 240: ......
Page 250: ......
Page 251: ...A Instruction Set Reference...
Page 252: ......
Page 390: ......
Page 391: ...B Signal Descriptions...
Page 392: ......
Page 400: ......
Page 401: ...C Registers...
Page 402: ......
Page 436: ......
Page 437: ...Glossary...
Page 438: ......
Page 446: ......
Page 447: ...Index...
Page 448: ......
Page 458: ......