Datasheet
© 2008 Microchip Technology Inc. DS39646C-page 203
PIC18F8722 FAMILY
18.4.9 SETUP FOR PWM OPERATION
The following steps should be taken when configuring
the ECCP1 module for PWM operation using Timer2:
1. Configure the PWM pins, P1A and P1B (and
P1C and P1D, if used), as inputs by setting the
corresponding TRIS bits.
2. Set the PWM period by loading the PR2 register.
3. If auto-shutdown is required do the following:
• Disable auto-shutdown (ECCP1AS = 0)
• Configure source (FLT0, Comparator 1 or 
Comparator 2)
• Wait for non-shutdown condition
4. Configure the ECCP1 module for the desired
PWM mode and configuration by loading the
CCP1CON register with the appropriate values:
• Select one of the available output 
configurations and direction with the 
P1M<1:0> bits.
• Select the polarities of the PWM output 
signals with the CCP1M<3:0> bits.
5. Set the PWM duty cycle by loading the CCPR1L
register and CCP1CON<5:4> bits.
6. For Half-Bridge Output mode, set the
dead-band delay by loading ECCP1DEL<6:0>
with the appropriate value.
7. If auto-shutdown operation is required, load the
ECCP1AS register:
• Select the auto-shutdown sources using the 
ECCP1AS<2:0> bits.
• Select the shutdown states of the PWM 
output pins using the PSS1AC<1:0> and 
PSS1BD<1:0> bits.
• Set the ECCP1ASE bit (ECCP1AS<7>).
• Configure the comparators using the CMCON 
register.
• Configure the comparator inputs as analog 
inputs.
8. If auto-restart operation is required, set the
P1RSEN bit (ECCP1DEL<7>).
9. Configure and start TMR2:
• Clear the TMR2 interrupt flag bit by clearing 
the TMR2IF bit (PIR1<1>).
• Set the TMR2 prescale value by loading the 
T2CKPS bits (T2CON<1:0>).
• Enable Timer2 by setting the TMR2ON bit 
(T2CON<2>).
10. Enable PWM outputs after a new PWM cycle
has started:
• Wait until TMRx overflows (TMRxIF bit is set).
• Enable the ECCP1/P1A, P1B, P1C and/or 
P1D pin outputs by clearing the respective 
TRIS bits.
• Clear the ECCP1ASE bit (ECCP1AS<7>).
18.4.10 OPERATION IN POWER-MANAGED 
MODES
In Sleep mode, all clock sources are disabled. Timer2 or
Timer4 will not increment and the state of the module will
not change. If the ECCP1 pin is driving a value, it will
continue to drive that value. When the device wakes up,
it will continue from this state. If Two-Speed Start-ups are
enabled, the initial start-up frequency from INTOSC and
the postscaler may not be stable immediately.
In PRI_IDLE mode, the primary clock will continue to
clock the ECCP1 module without change. In all other
power-managed modes, the selected power-managed
mode clock will clock Timer2 or Timer4. Other
power-managed mode clocks will most likely be
different than the primary clock frequency. 
18.4.10.1 Operation with Fail-Safe 
Clock Monitor
If the Fail-Safe Clock Monitor is enabled, a clock failure
will force the device into the power-managed RC_RUN
mode and the OSCFIF bit (PIR2<7>) will be set. The
ECCP1 will then be clocked from the internal oscillator
clock source, which may have a different clock
frequency than the primary clock.
See the previous section for additional details.
18.4.11 EFFECTS OF A RESET
Both Power-on Reset and subsequent Resets will force
all ports to Input mode and the CCP registers to their
Reset states.
This forces the Enhanced CCP module to reset to a
state compatible with the standard CCP module.










