1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2024-12-29 04:50:03 +01:00
RIOT/tests/bench_xtimer_load
2022-04-01 13:42:01 +02:00
..
tests
main.c tests/bench_xtimer_load: remove uneeded timex call 2022-03-02 08:19:22 +01:00
Makefile tests/*: CI blacklist microbit where it fails 2022-04-01 13:42:01 +02:00
Makefile.ci
README.md

bench_xtimer_load test application

This benchmark will run a periodic timer every TEST_INTERVAL microseconds (TEST_HZ). Two other threads are also running only to cause CPU load with extra interrupts and context switches.

This benchmark is heavily based on tests/xtimer_drift. It basically minimizes the per-second printout and adds statistic gathering / printing.

With low TEST_HZ (<64), this test can expose accuracy issues in the timer configuration. With high TEST_HZ (depending on the platform, 64 - 8192), it exposes issues with both high timer isr load issues in periph_timer and concurrency / race condition issues in xtimer. If it finishes, the resulting values can give an indication of the timer implementation efficiency.

The difference between the actual and expected xtimer_now() value ("drift") will be calculated, along with the drift change since the last iteration ("jitter"). Every second, a dot (".") will be printed.

After TEST_TIME seconds (defaults to 10), the minimum and maximum values for both drift and jitter will be printed, along with the final drift and average jitter (sum(abs(jitter)) / num_samples).

The default TEST_HZ is quite low (16Hz), which should result in close to zero drift and jitter.

With higher TEST_HZ, timer isr collisions are more likely, causing increased jitter.

As long as the CPU can handle the load, the final drift should stay low. If the CPU can't handle the load, drift will increase with every iteration.

Notes

This benchmark will currently get stuck due to xtimer bugs on at least native and every board where xtimer uses a <32bit hardware timer.