Implementing the microsecond ticker enables Mbed OS to perform operations that require precise timing. You can use this API to schedule events, record elapsed time and perform submillisecond delays.
Warning: We are changing the microsecond ticker HAL API in an upcoming release of Mbed OS. You can find details on how it may affect you in the implementing the microsecond ticker API section.
- Has a reported frequency between 250KHz and 8MHz.
- Has a counter that is at least 16 bits wide.
- The function
ticker_init
is safe to call repeatedly. - The function
ticker_init
allows the ticker to keep counting and disables the ticker interrupt. - Ticker frequency is nonzero, and the counter is at least 8 bits.
- The ticker rolls over at (1 << bits) and continues counting starting from 0.
- The ticker counts at the specified frequency plus or minus 10%.
- The ticker increments by 1 each tick.
- The ticker interrupt fires only when the ticker time increments to or past the value set by
ticker_set_interrupt
. - It is safe to call
ticker_set_interrupt
repeatedly before the handler is called. - The function
ticker_fire_interrupt
causesticker_irq_handler
to be called immediately from interrupt context. - The ticker operations
ticker_read
,ticker_clear_interrupt
,ticker_set_interrupt
andticker_fire_interrupt
take less than 20us to complete.
- Calling any function other than
ticker_init
before the initialization of the ticker. - Whether
ticker_irq_handler
is called a second time if the time wraps and matches the value set byticker_set_interrupt
again. - Calling
ticker_set_interrupt
with a value that has more than the supported number of bits. - Calling any function other than
us_ticker_init
after callingus_ticker_free
.
Be careful around these common trouble areas when implementing this API:
- The ticker cannot drift when rescheduled repeatedly
- The ticker keeps counting when it rolls over
- The ticker interrupt fires when the compare value is set to 0 and overflow occurs
To implement this API, the device must have a hardware counter that has a count value at least 16 bits wide and can operate between 250KHz and 8MHz.
We are working on the new HAL microsecond ticker API, which will replace the current version in an upcoming release of Mbed OS. You need to implement the microsecond ticker API in both variants. First, you need to implement the current API. You can find it on the master branch:
To make sure your platform is ready for the upcoming changes, you need to implement the future API and submit it in a separate pull request against the feature-hal-spec-ticker
branch. You can find the API and specification for the new microsecond ticker API in the following header file:
To enable microsecond ticker support in Mbed OS, add the USTICKER
label in the device_has
option of the target's section in the targets.json
file.
The Mbed OS HAL provides a set of conformance tests for the microsecond ticker. You can use these tests to validate the correctness of your implementation. To run the microsecond ticker HAL tests, use the following command:
mbed test -t <toolchain> -m <target> -n tests-mbed_hal-common_ticker*,tests-mbed_hal-us_ticker*
You can read more about the test cases: