2.79 Periodic Interval Timer 64-bit (PIT64B)

The 64-bit Periodic Interval Timer (PIT64B) provides the operating system scheduler interrupt, as well as any periodic source of interrupt to software. It is designed to offer maximum accuracy and efficient management, even for systems with long response times.

  • 4-bit Prescaler

  • Single Shot or Continuous Mode

Using The Library

PIT64B peripheral library can be used to poll for a periodic timeout, generate periodic interrupts or generate timed waits. The following examples shows different modes of its usage.

Polling method

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

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

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

    return ( EXIT_FAILURE );
}

Interrupt method

static void timerHandler (uintptr_t context)
{    
    (void)context;
    
    LED_BLUE_Toggle(); 
}

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

    PIT64B_TimerCallbackSet(timerHandler, 0);
    PIT64B_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 );
}

Delay routines

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

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

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

    return ( EXIT_FAILURE );
}

Library Interface

Periodic Interval Timer 64-bit peripheral library provides the following interfaces:

Functions

NameDescription
PIT64B_TimerInitializeInitialize PIT64B registers per user config
PIT64B_TimerRestartRestart the PIT64B counter
PIT64B_TimerStartStart the PIT64B counter
PIT64B_TimerStopStop the PIT64B counter
PIT64B_TimerPeriodSetSet the timer period value
PIT64B_TimerPeriodGetGet the timer period value
PIT64B_TimerCounterGetGet the timer counter value
PIT64B_TimerFrequencyGetGet the timer clock frequency
PIT64B_TimerPeriodHasExpiredReturn whether or not the Timer Period has expired
PIT64B_DelayMsDelays processing for x milliseconds
PIT64B_DelayUsDelays processing for x microseconds
PIT64B_TimerCallbackSetRegister callback for PIT64B interrupt
PIT64B_ClearInterruptPIT64B Clear Interrupt

Data types and constants

NameTypeDescription
PIT64B_CALLBACKTypedefPIT64B Interrupt Callback Function definition
Note: Not all APIs maybe implemented. See the specific device family section for available APIs.