#counter #cortex-m #dwt #measure-time #duration #cyccnt #microseconds

cortex-m-microclock

A simple software clock for Cortex-M devices based on the CYCCNT hardware counter

1 unstable release

0.1.0 Oct 4, 2023

#315 in Profiling

MIT/Apache

15KB
105 lines

cortex-m-microclock

This crate provides a software clock which relies on the CYCCNT counter present in most Cortex-M chips to allow user to measure time and produce delays. The precision of the clock depends on your microcontroller core frequency. If you have a core running at at least 1MHZ, you will have a microsecond precision.

Note 0: Some Cortex-M cores like M0, M0+ and M23 cores does not have a CYCCNT counter. Therefore, the present crate cannot be used on these chips Note 1 The present crate does not work on multicore systems.

Underlaying hardware

The clock is based on the CYCCNT counter from the Cortex-M DWT peripheral, which increments with each processor clock cycle. However as the CYCCNT upcounter is only 32 bits wide, it may overflow quite rapidly depending on your SYSCLK frequency. The CYCCNTClock keeps track of multiple CYCCNT cycles using an internal counter so it can be used to evaluate very large durations of time.

Crate structure

The CYCCNTClock is the structure representing the software clock. This structure is a singleton exposing all the methods of the crate available to user. All these methods are static and can be called from any thread without concurrency issues.

How to use this crate

In order to use the clock you should first call the [CYCCNTClock::init()] method which takes ownership of the DWT peripheral. From this point you can use [CYCCNTClock::now()] and [CYCCNTClock::delay()] methods. The [CYCCNTClock::update()] method should be called periodically to avoid missing the CYCCNT wrapping around. Use the following equation to find the minimum update frequency:

min_update_freq = SYS_CLK_FREQ/(2³²)

Note that the [CYCCNTClock::now()] and [CYCCNTClock::delay()] methods implicitely call the [CYCCNTClock::update()] method.

Example

A complete example of the use of this crate on a STMF103 blue pill is featured in the examples directory of this project.

Credits

Many thanks to the authors of fugit and rtic::dwt_systick_monotonic crates

Dependencies

~790KB