mirror of
https://github.com/RIOT-OS/RIOT.git
synced 2025-01-18 01:32:44 +01:00
98 lines
2.7 KiB
C
98 lines
2.7 KiB
C
|
/*
|
||
|
* Copyright (C) 2019 Kaspar Schleiser <kaspar@schleiser.de>
|
||
|
* 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_ztimer_mock ztimer mock clock backend
|
||
|
* @ingroup sys_ztimer
|
||
|
* @brief ztimer mock clock backend
|
||
|
*
|
||
|
* This ztimer module implements a virtual clock that can be used for unittests.
|
||
|
* It can be manually adjusted to different timestamps and manually fired to
|
||
|
* simulate different scenarios and test the ztimer implementation using this
|
||
|
* as a backing timer.
|
||
|
*
|
||
|
* @{
|
||
|
* @file
|
||
|
* @brief ztimer mock clock backend API
|
||
|
* @author Joakim Nohlgård <joakim.nohlgard@eistec.se>
|
||
|
* @author Kaspar Schleiser <kaspar@schleiser.de>
|
||
|
*/
|
||
|
|
||
|
#ifndef ZTIMER_MOCK_H
|
||
|
#define ZTIMER_MOCK_H
|
||
|
|
||
|
#include <stdint.h>
|
||
|
#include "ztimer.h"
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
extern "C" {
|
||
|
#endif
|
||
|
|
||
|
/**
|
||
|
* @brief ztimer mock clock class
|
||
|
*/
|
||
|
typedef struct {
|
||
|
ztimer_clock_t super; /**< superclass instance */
|
||
|
uint32_t mask; /**< counter mask */
|
||
|
uint32_t now; /**< current counter value */
|
||
|
uint32_t target; /**< ticks left until alarm is hit */
|
||
|
unsigned armed; /**< flag for checking if a target has been set */
|
||
|
|
||
|
struct {
|
||
|
unsigned now; /**< Number of calls to ztimer_ops_t::now */
|
||
|
unsigned set; /**< Number of calls to ztimer_ops_t::set */
|
||
|
unsigned cancel; /**< Number of calls to ztimer_ops_t::cancel */
|
||
|
} calls; /**< Struct holding number of calls to each
|
||
|
operation */
|
||
|
} ztimer_mock_t;
|
||
|
|
||
|
/**
|
||
|
* @brief Advance the mock clock counter and update target
|
||
|
*
|
||
|
* This will call @ref ztimer_handler if the target was passed.
|
||
|
*
|
||
|
* @param[in] self instance to operate on
|
||
|
* @param[in] val counter increment value
|
||
|
*/
|
||
|
void ztimer_mock_advance(ztimer_mock_t *self, uint32_t val);
|
||
|
|
||
|
/**
|
||
|
* @brief Set the mock clock counter value without updating timer target
|
||
|
*
|
||
|
* This will not touch the timer target.
|
||
|
*
|
||
|
* @param[in] self instance to operate on
|
||
|
* @param[in] target new absolute counter value
|
||
|
*/
|
||
|
void ztimer_mock_jump(ztimer_mock_t *self, uint32_t target);
|
||
|
|
||
|
/**
|
||
|
* @brief Trigger the timer handlers
|
||
|
*
|
||
|
* This is equivalent to a hardware timer interrupt
|
||
|
*
|
||
|
* @param[in] self instance to operate on
|
||
|
*/
|
||
|
void ztimer_mock_fire(ztimer_mock_t *self);
|
||
|
|
||
|
/**
|
||
|
* @brief Constructor
|
||
|
*
|
||
|
* @param[in] self instance to operate on
|
||
|
* @param[in] width counter width, 1 <= width <= 32
|
||
|
*/
|
||
|
void ztimer_mock_init(ztimer_mock_t *self, unsigned width);
|
||
|
|
||
|
#ifdef __cplusplus
|
||
|
}
|
||
|
#endif
|
||
|
|
||
|
#endif /* ZTIMER_MOCK_H */
|
||
|
/** @} */
|