1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-18 11:32:45 +01:00
RIOT/tests/sys/ztimer_ondemand_benchmark/main.c

123 lines
3.1 KiB
C

/*
* Copyright (C) 2022 SSV Software Systems GmbH
*
* This file is subject to the terms and conditions of the GNU Lesser
* General Public License v2.1. See the file LICENSE in the top level
* directory for more details.
*/
/**
* @ingroup tests
* @{
*
* @file
* @brief Benchmarks ztimer_acquire() and ztimer_release()
*
* @author Juergen Fitschen <me@jue.yt>
*
* @}
*/
#include <stdio.h>
#include <inttypes.h>
#include "ztimer.h"
#include "ztimer/config.h"
#include "periph/timer.h"
#include "periph_conf.h"
#if IS_ACTIVE(MODULE_ZTIMER_SEC)
# define CLOCK ZTIMER_SEC
#elif IS_ACTIVE(MODULE_ZTIMER_MSEC)
# define CLOCK ZTIMER_MSEC
#elif IS_ACTIVE(MODULE_ZTIMER_USEC)
# define CLOCK ZTIMER_USEC
# define CLOCK_IS_ZTIMER_USEC
#else
# error "No ztimer clock selected!"
#endif
#ifndef COMPARE_TIMER_DEV
# if IS_ACTIVE(MODULE_ZTIMER_PERIPH_TIMER)
# if CONFIG_ZTIMER_USEC_DEV == TIMER_DEV(0)
# define COMPARE_TIMER_DEV TIMER_DEV(1)
# else
# define COMPARE_TIMER_DEV TIMER_DEV(0)
# endif
# else
# define COMPARE_TIMER_DEV TIMER_DEV(0)
# endif
#endif
#ifndef COMPARE_TIMER_FREQ
# define COMPARE_TIMER_FREQ 1000000U
#endif
static inline uint32_t bench_start(uint32_t adjust)
{
return timer_read(COMPARE_TIMER_DEV) + adjust;
}
static inline uint32_t bench_finish(const char *name, uint32_t start)
{
uint32_t stop = timer_read(COMPARE_TIMER_DEV);
uint32_t diff = stop - start;
if (name) {
printf(" - %s took %"PRIu32" ticks\n", name, diff);
}
return diff;
}
static inline uint32_t bench_overhead(void) {
uint32_t start = bench_start(0);
uint32_t diff = bench_finish(NULL, start);
return diff;
}
int main(void)
{
uint32_t start, adjust;
uint32_t first_acquire, second_acquire;
uint32_t poweron_diff;
timer_init(COMPARE_TIMER_DEV, COMPARE_TIMER_FREQ, NULL, NULL);
adjust = bench_overhead();
printf("Compare timer frequency: %"PRIu32"Hz\n", (uint32_t) COMPARE_TIMER_FREQ);
printf("Compare timer overhead: %"PRIu32" ticks (will be taken into account)\n", adjust);
puts("---");
puts("Benchmarking:");
start = bench_start(adjust);
ztimer_acquire(CLOCK);
first_acquire = bench_finish("ztimer_acquire() on inactive clock", start);
start = bench_start(adjust);
ztimer_acquire(CLOCK);
second_acquire = bench_finish("ztimer_acquire() on active clock", start);
start = bench_start(adjust);
ztimer_release(CLOCK);
bench_finish("ztimer_release() with users left", start);
start = bench_start(adjust);
ztimer_release(CLOCK);
bench_finish("ztimer_release() with no users left", start);
puts("---");
poweron_diff = first_acquire - second_acquire;
#if defined(CLOCK_IS_ZTIMER_USEC) && COMPARE_TIMER_FREQ == 1000000U
printf("Add this to you board.h:\n");
printf(" #define CONFIG_ZTIMER_USEC_ADJUST_CLOCK_START %"PRIu32"\n", poweron_diff);
#else
printf("If the ztimer clock runs with with a frequency of %"PRIu32"Hz, set\n",
(uint32_t) COMPARE_TIMER_FREQ);
printf(" clock->adjust_clock_start = %"PRIu32"\n", poweron_diff);
#endif
return 0;
}