Datasheet
PIC18(L)F2X/45K50
DS30684A-page 318  2012 Microchip Technology Inc.
19.8 Additional Comparator Features
There are four additional comparator features:
• Simultaneous read of comparator outputs
• Internal reference selection
• Hysteresis selection
• Output Synchronization
19.8.1 SIMULTANEOUS COMPARATOR 
OUTPUT READ
The MC1OUT and MC2OUT bits of the CM2CON1
register are mirror copies of both comparator outputs.
The ability to read both outputs simultaneously from a
single register eliminates the timing skew of reading
separate registers.
19.8.2 INTERNAL REFERENCE 
SELECTION
There are two internal voltage references available to
the non-inverting input of each comparator. One of
these is the Fixed Voltage Reference (FVR) and the
other is the variable Digital-to-Analog Converter (DAC).
The CxRSEL bit of the CM2CON1 register determines
which of these references is routed to the Comparator
Voltage reference output (C
XVREF). Further routing to
the comparator is accomplished by the CxR bit of the
CMxCON0 register. See Section 22.0 “Fixed Voltage
Reference (FVR)” and Figure 19-2 for more detail.
19.8.3 SYNCHRONIZING COMPARATOR 
OUTPUT TO TIMER1
The Comparator Cx output can be synchronized with
Timer1 by setting the CxSYNC bit of the CM2CON1
register. When enabled, the Cx output is latched on
the falling edge of the Timer1 source clock. To prevent
a race condition when gating Timer1 clock with the
comparator output, Timer1 increments on the rising
edge of its clock source, and the falling edge latches
the comparator output. See the Comparator Block
Diagram (Figure 19-2) and the Timer1 Block Diagram
(Figure 13-1) for more information.
Note 1: Obtaining the status of C1OUT or
C2OUT by reading CM2CON1 does not
affect the comparator interrupt mismatch
registers.
Note 1: The comparator synchronized output
should not be used to gate the external
Timer1 clock when the Timer1
synchronizer is enabled.
2: The Timer1 prescale should be set to 1:1
when synchronizing the comparator
output as unexpected results may occur
with other prescale values.










