2.10 Capture/Compare/PWM (CCP)

A CCP module can operate in any one of the below three modes.

  • Timer mode - is used for periodic delay.

  • Output Compare/PWM mode - is used to generate waveforms

  • Input Capture mode - is used to measure delay, pulse width and frequency of the input signal.

Timer mode

The CCP channel in timer mode provides following features:

  • Periodic CPU interrupts

  • Master time base function for synchronizing other CCP modules

  • Triggering periodic ADC conversion

  • Periodic wake from Sleep (if an appropriate clock source is available)

Using The Library

When the timer is enabled, it increments by one on every rising edge of the input clock, and generates an interrupt on a period match. Timer mode is used for periodic interrupt generation.

This example demonstrates how to use CCP channel in timer mode to generate periodic callback.

/* This function is called after period expires */
void CCP0_Callback_InterruptHandler(uint32_t status, uintptr_t context)
{
    /* Toggle LED */
    LED_Toggle();
}

int main ( void )
{
    /* Initialize all modules */
    SYS_Initialize ( NULL );

    /* Register callback function for CCP0 period interrupt */
    CCP0_TimerCallbackRegister(CCP0_Callback_InterruptHandler, (uintptr_t)NULL);

    /* Start the timer channel 0*/
    CCP0_TimerStart();

    while ( true )
    {
        /* Maintain state machines of all polled MPLAB Harmony modules. */
        SYS_Tasks ( );
    }

    /* Execution should not come here during normal operation */

    return ( EXIT_FAILURE );
}

Compare mode

The CCP channel in compare mode is used for waveform generation. This provides below features:

  • Output Compare mode can generate a single output transition or a train of output pulses, and can generate interrupts on match-on-compare events.

  • Output Compare mode can function as a PWM generator.

  • In MCCP modules, multiple PWM outputs can be used for power or motor control applications.

Using The Library

This peripheral supports below output compare modes:

  • Single edge and dual edge compare modes

  • Center-aligned compare mode

MCCP (Multiple CCP) modules support below extended PWM features:

  • Single Output Steerable mode

  • Brush DC Motor (Forward and Reverse) modes

  • Half-Bridge with Dead-Time Delay mode

  • Push-Pull PWM mode

  • Output Scan mode

  • Center-Aligned Compare mode

  • Variable Frequency Pulse mode

  • Auto-Shutdown with Programmable Source and Shutdown State

  • Programmable Output Polarity

This peripheral library allows to set the period and duty cycle of the output waveform. And supports period overflow interrupt and compare match interrupt.

Capture mode

This mode is used to capture a timer value from an independent timer base on the occurrence of an event on an input pin. This mode is useful in applications requiring frequency (time period) and pulse measurement. Input Capture mode uses the CCPxTMR registers as a dedicated 16/32-bit synchronous, up counting timer used for event capture. This value is written to the FIFO buffer when a capture event occurs. The internal value may also be read with a synchronization delay from the CCPxTMR registers.

Using The Library

CCP peripheral when configured in capture mode, captures the time interval of input signal.

It provides both polling and callback methods to indicate capture event has occurred. With polling, the application will need to continuously poll to check if the capture event has occurred. With callback, the registered callback function will be called when the capture event occurs. This means the application do not have to poll continuously.

Callback method This example demonstrates how to use CCP in capture mode to measure pulse width.

/* This function is called after Capture 0 interrupt */
void CCP0_CaptureInterruptHandler(uintptr_t context)
{
    /* Read Captured values */
    pulse_width = CCP0_Capture16bitBufferRead();
}

int main(void)
{

    /* Register callback function for period interrupt */
    CCP0_CaptureCallbackRegister(CCP0_CaptureInterruptHandler, (uintptr_t)NULL);

    /* Start the Capture */
    CCP0_CaptureStart();
}

Library Interface

CCP peripheral library provides the following interfaces:

Functions

NameDescription
CCPx_TimerInitializeInitializes given instance of CCP
CCPx_TimerStartStarts the timer for given CCP instance
CCPx_TimerStopStops the timer for given CCP instance
CCPx_Timer16bitPeriodSetSets the period value of a given timer
CCPx_Timer16bitPeriodGetReads the period value of given timer
CCPx_Timer16bitCounterGetReads the timer current count value
CCPx_Timer32bitPeriodSetSets the period value of a given timer
CCPx_Timer32bitPeriodGetReads the period value of given timer
CCPx_Timer32bitCounterGetReads the timer current count value
CCPx_TimerFrequencyGetProvides the given timer's counter-increment frequency
CCPx_TimerCallbackRegisterRegisters the function to be called from interrupt
CCPx_TimerInterruptEnableEnables timer interrupt
CCPx_TimerInterruptDisableDisables timer interrupt
CCPx_CaptureInitializeInitializes given instance of CCP
CCPx_CaptureStartStarts the timer for given CCP instance
CCPx_CaptureStopStops the timer for given CCP instance
CCPx_Capture16bitBufferReadReads 16 bit capture value
CCPx_Capture32bitBufferReadReads 32 bit capture value
CCPx_CaptureStatusGetReads status capture operation
CCPx_CaptureCallbackRegisterRegisters the function to be called from interrupt
CCPx_CompareInitializeInitializes given instance of CCP
CCPx_CompareStartStarts the timer for given CCP instance
CCPx_CompareStopStops the timer for given CCP instance
CCPx_CompareAutoShutdownClearClears auto shutdown event status
CCPx_CompareAutoShutdownSetEnable auto shutdown
CCPx_Compare16bitPeriodValueSetSets the period value of a given timer
CCPx_Compare16bitPeriodValueGetReads the period value of given timer
CCPx_Compare16bitValueGetReads the timer current count value
CCPx_Compare16bitValueSetSets new timer counter value
CCPx_Compare16bitRAValueSetWrites compare value of the given compare channel 0
CCPx_Compare16bitRAValueGetGets lower 16 bits of compare value
CCPx_Compare16bitRBValueSetWrites higher 16bits of compare value
CCPx_Compare16bitRBValueGetGets higher 16 bits of compare value
CCPx_Compare32bitPeriodValueSetSets the period value of a given timer
CCPx_Compare32bitPeriodValueGetReads the period value of given timer
CCPx_Compare32bitValueGetReads the 32bit compare value
CCPx_Compare32bitValueSetSets 32bit compare value
CCPx_CompareCallbackRegisterRegisters the function to be called from interrupt

Data types and constants

NameTypeDescription
CCP_TIMER_CALLBACKTypedefDefines the function pointer data type and function signature for the ccp channel callback function
CCP_COMPARE_CALLBACKTypedefDefines the function pointer data type and function signature for the ccp channel callback function
CCP_CAPTURE_CALLBACKTypedefDefines the function pointer data type and function signature for the ccp channel callback function
Note: Not all APIs maybe implemented. See the specific device family section for available APIs.