1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 21:32:43 +01:00
RIOT/tests/bench_timers/spin_random.h
Joakim Nohlgård 2006937ee6 tests/bench_timers: Add benchmark for periph_timer and xtimer
This test is intended to collect statistics about the runtime delays in
the periph_timer implementation. This tool is mainly intended to detect
problems in the low level driver implementation which can be difficult
to detect from higher level systems such as xtimer.
2018-06-11 13:19:13 +02:00

71 lines
1.9 KiB
C

/*
* Copyright (C) 2018 Eistec AB
*
* 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.
*/
/**
* @defgroup sys_spin_random Spin_random - random CPU delays
* @ingroup sys
* @brief CPU spinning routines for random runtime delays
*
* @{
* @file
* @brief spin_random declarations
*
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
*/
#ifndef SPIN_RANDOM_H
#define SPIN_RANDOM_H
#include <stdint.h>
#include "periph/timer.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @brief Spin for a short random delay to increase fuzziness of a test
*
* The amount of time spent in this function will be between 0 and up to at
* least the amount of time that the spin_random_calibrate function was called
* with.
* The spin duration is < 2 * spin_max_target, in timer ticks of the timer that
* was used by spin_random_calibrate.
*
* @pre spin_random_calibrate must have been run beforehand to calibrate the
* maximum spin count
*/
void spin_random_delay(void);
/**
* @brief Calibrate the maximum spin count
*
* The calibration function will ensure that @ref spin_random_delay will give a
* random delay up to at least @p spin_max_target counts on the timer device
* given by @p timer_dev.
*
* The new maximum spin count will ensure that the maximum random spin in
* @ref spin_random_delay will be at least @p spin_max_target ticks long, and
* no more than 2 * @p spin_max_target ticks.
*
* @pre The periph_timer @p timer_dev must be initialized and running (counting).
*
* @param[in] timer_dev Timer device to use as reference
* @param[in] spin_max_target Spin duration target time in @p timer_dev ticks.
*
* @return the new maximum spin count
*/
uint32_t spin_random_calibrate(tim_t timer_dev, uint32_t spin_max_target);
#ifdef __cplusplus
}
#endif
#endif /* SPIN_RANDOM_H */
/** @} */