

# Politechnika Wrocławska



CortexM0 SysTick



### Cortex MO

- Cortex-M0 processor includes
  - Cortex-M0 processor core
  - Nested Vectored Interrupt Controller (NVIC)
  - System Timer (SysTick)





## System Timer - SysTick

- SysTick: 24-bit clear-on-write, decrementing, wrap-on-zero counter.
- be used as a Real Time Operating System (RTOS) tick timer or as a simple counter.
- When enabled, count down from SysTick Current Value Register (SYST\_CVR) to zero, and reload SysTick Reload Value Register (SYST\_RVR), then continue decrement.
- When count down to zero, COUNTFLAG=1. COUNTFLAG=0, on reads.
- SYST\_CVR value is UNKNOWN on reset.
- SYST\_RVR =0, timer=0. (disable timer even if timer enable)

# System Timer - SysTick

 The reference clock can be the core clock or an external clock source.



#### System timer register

| Address    | Name       | Function                                                                                 | Туре | Reset Value |
|------------|------------|------------------------------------------------------------------------------------------|------|-------------|
| 0xE000E010 | SYST_CSR   | SysTick Control and Status Enables counting and interrupt Selects reference clock source | R/W  | 0x00000000  |
| 0xE000E014 | SYST_RVR   | SysTick Reload value Copied to current value register when counter reaches 0             | R/W  | UNKNOWN     |
| 0xE000E018 | SYST_CVR   | SysTick Current value Keeps current counter value                                        | R/W  | UNKNOWN     |
| 0xE000E01C | SYST_CALIB | SysTick Calibration value Defined by implementation                                      | RO   | IMP DEF     |



### **ARM documentation**



Table 4.22. SYST\_CVR bit assignments

Bits Name Function [31:24] - Reserved.

[23:0] CURRENT Reads return the current value of the SysTick counter.

A write of any value clears the field to 0,

and also clears the SYST\_CSR.COUNTFLAG bit to 0.



## SysTick Control and Status Register



#### SysTick Control and Status (SYST\_CSR)

| Bits | Name      | Function                                                                                                             |
|------|-----------|----------------------------------------------------------------------------------------------------------------------|
| [16] | COUNTFLAG | =1, if timer counted to 0.<br>=0, <del>read</del> or write to the Current Value register.                            |
| [2]  | CLKSRC    | 1 = Core clock used for SysTick.<br>0 = Clock source is external reference clock                                     |
| [1]  | TICKINT   | 1 = Counting down to 0 will cause the SysTick exception. 0 = does not cause the SysTick exception. (check COUNTFLAG) |
| [0]  | ENABLE    | 1 = The counter will operate in a multi-shot manner<br>0 = The counter is disabled                                   |



#### STM32F0xxx Cortex-M0 programming manual

#### SysTick timer (STK)

When enabled, the timer:

- counts down from the reload value to zero,
- reloads (wraps to) the value in the STK\_RVR on the next clock cycle,
- then decrements on subsequent clock cycles.

Writing a value of zero to the STK\_RVR disables the counter on the next wrap.

When the counter transitions to zero, the COUNTFLAG status bit is set to 1.

Reading STK\_CSR clears the COUNTFLAG bit to 0.

Writing to the STK\_CVR clears the register and the COUNTFLAG status bit to 0. The write does not trigger the SysTick exception logic. Reading the register returns its value at the time it is accessed.