2.112 System timer (SysTick)

The ARM Cortex CPU includes an optional system timer (SysTick) that provides a simple, 24-bit clear-on-write, decrementing, wrap-on-zero counter with a flexible control mechanism.

When enabled, the 24-bit timer counter counts down from the value in VAL. When the counter reaches zero, it reloads the value in LOAD on the next clock edge. It then decrements on subsequent clocks. This reloading when the counter reaches zero is called wrapping.

The timer interrupt is activated on the transition from 1 to 0, therefore it activates every n+1 clock ticks. If a period of 100 is required 99 should be written to the SysTick Reload Value register.

The SysTick can be polled by software or can be configured to generate an interrupt.

Using The Library

When the timer is enabled, it decrements by one on every rising edge of the input clock, and generates an interrupt when the timer value transitions to zero (Timer expiry). This is used to generate periodic interrupt generation.

The SysTick can be polled by software or can be configured to generate an interrupt.

  • With polling, the application will need to continuously poll to check if the timer has expired.

  • With interrupt, the registered callback function will be called when the timer expires. This means the application do not have to poll continuously.

Callback method

This example demonstrates how to use SysTick to generate periodic callback.

/* This function is called after Timer expires */
void SYSTICK_EventHandler(uintptr_t context)
{
    /* Toggle LED */
    LED_Toggle();
}

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

    /* Register Callback */
    SYSTICK_TimerCallbackSet(SYSTICK_EventHandler, (uintptr_t) NULL);

    /* Start the Timer */
    SYSTICK_TimerStart();
}

Library Interface

System timer peripheral library provides the following interfaces:

Functions

NameDescription
SYSTICK_TimerInitializeInitializes SysTick
SYSTICK_TimerRestartRestarts SysTick
SYSTICK_TimerStartStarts System Timer
SYSTICK_TimerStopStops System Timer
SYSTICK_TimerPeriodSetSet the SysTick Load Value
SYSTICK_TimerPeriodGetGet the SysTick Load Value
SYSTICK_TimerCounterGetGet the SysTick current Value
SYSTICK_TimerFrequencyGetGet the SysTick frequency Value
SYSTICK_TimerPeriodHasExpiredReturns the current status of the systick
SYSTICK_DelayMsBlocking function to generate delay in milliseconds
SYSTICK_DelayUsBlocking function to generate delay in micro seconds
SYSTICK_TimerCallbackSetSets the pointer to the function (and it's context) to be called when the given systick reaches 0

Data types and constants

NameTypeDescription
SYSTICK_CALLBACKTypedefDefines the data type and function signature for the SysTick callback function
Note: Not all APIs maybe implemented. See the specific device family section for available APIs.