2011-08-29 15:28:11 +10:00
|
|
|
/*
|
2018-08-04 15:14:06 +10:00
|
|
|
* This Source Code Form is subject to the terms of the Mozilla Public
|
|
|
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
|
|
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/.
|
2011-08-29 15:28:11 +10:00
|
|
|
*
|
2022-03-22 13:18:01 +10:00
|
|
|
* Copyright 2010-2016, 2022 Danny Robson <danny@nerdcruft.net>
|
2011-08-29 15:28:11 +10:00
|
|
|
*/
|
|
|
|
|
2021-04-14 15:35:49 +10:00
|
|
|
#pragma once
|
2011-08-29 15:28:11 +10:00
|
|
|
|
2022-03-22 13:18:01 +10:00
|
|
|
#include "./std.hpp"
|
|
|
|
#include "./stats.hpp"
|
2017-11-22 16:49:37 +11:00
|
|
|
|
2016-04-05 11:02:54 +10:00
|
|
|
#include <chrono>
|
2011-08-29 15:28:11 +10:00
|
|
|
#include <cstdint>
|
2012-08-07 18:35:38 +10:00
|
|
|
#include <string>
|
|
|
|
|
2011-08-29 15:28:11 +10:00
|
|
|
|
2018-08-05 14:42:02 +10:00
|
|
|
namespace cruft {
|
2017-12-30 13:38:11 +11:00
|
|
|
///////////////////////////////////////////////////////////////////////////
|
2016-04-05 11:02:54 +10:00
|
|
|
uintmax_t nanoseconds (void);
|
|
|
|
|
2017-12-30 13:38:11 +11:00
|
|
|
|
|
|
|
//-------------------------------------------------------------------------
|
2016-04-05 11:02:54 +10:00
|
|
|
template <typename T>
|
2017-12-30 13:38:11 +11:00
|
|
|
void sleep (std::chrono::duration<T,std::nano> dt)
|
|
|
|
{
|
|
|
|
auto nano = std::chrono::duration_cast<std::chrono::nanoseconds> (dt);
|
|
|
|
sleep (nano.count ());
|
|
|
|
}
|
|
|
|
|
2016-04-05 11:02:54 +10:00
|
|
|
|
2017-12-30 13:38:11 +11:00
|
|
|
//-------------------------------------------------------------------------
|
2016-04-05 11:02:54 +10:00
|
|
|
void sleep (uint64_t ns);
|
2012-08-07 18:35:38 +10:00
|
|
|
|
2017-12-30 13:38:11 +11:00
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
2013-08-05 16:40:43 +10:00
|
|
|
class delta_clock {
|
|
|
|
public:
|
|
|
|
delta_clock ();
|
2018-04-05 18:48:23 +10:00
|
|
|
std::chrono::nanoseconds dt(void);
|
2013-08-05 16:40:43 +10:00
|
|
|
|
|
|
|
protected:
|
|
|
|
struct {
|
|
|
|
uint64_t prev;
|
|
|
|
uint64_t curr;
|
|
|
|
} time;
|
|
|
|
};
|
|
|
|
|
2017-12-30 13:38:11 +11:00
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
2013-09-20 17:33:08 +10:00
|
|
|
class period_query {
|
|
|
|
public:
|
2017-05-23 12:50:51 +10:00
|
|
|
explicit period_query (float seconds);
|
2013-09-20 17:33:08 +10:00
|
|
|
|
|
|
|
bool poll (void);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
struct {
|
|
|
|
uint64_t start;
|
|
|
|
uint64_t period;
|
|
|
|
} m_time;
|
|
|
|
};
|
|
|
|
|
2017-12-30 13:38:11 +11:00
|
|
|
|
|
|
|
///////////////////////////////////////////////////////////////////////////
|
2013-08-08 10:48:44 +10:00
|
|
|
class rate_limiter {
|
|
|
|
public:
|
2017-05-23 12:50:51 +10:00
|
|
|
explicit rate_limiter (unsigned rate);
|
2013-08-08 10:48:44 +10:00
|
|
|
|
|
|
|
void poll (void);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
uint64_t m_last;
|
|
|
|
unsigned m_target;
|
|
|
|
};
|
|
|
|
|
2017-12-30 13:38:11 +11:00
|
|
|
|
2022-03-22 13:18:01 +10:00
|
|
|
///////////////////////////////////////////////////////////////////////////
|
2022-03-30 13:29:33 +10:00
|
|
|
/// Ensured to ensure a minimum period has elapsed since a previous
|
|
|
|
/// invocation.
|
2022-03-22 13:18:01 +10:00
|
|
|
class period_limiter {
|
|
|
|
public:
|
|
|
|
explicit period_limiter (std::chrono::nanoseconds _period);
|
|
|
|
explicit period_limiter (u64);
|
|
|
|
|
2022-03-30 13:29:33 +10:00
|
|
|
/// Wait until the period has elapsed and reset the last activation
|
|
|
|
/// time.
|
2022-03-22 13:18:01 +10:00
|
|
|
void poll (void);
|
2022-03-30 13:29:33 +10:00
|
|
|
/// Wait until the period has elapsed. Does not reset the last
|
|
|
|
/// activation time.
|
|
|
|
void wait (void) const;
|
|
|
|
/// Reset the last activated time. Does not block.
|
|
|
|
void reset (void);
|
2022-03-22 13:18:01 +10:00
|
|
|
|
|
|
|
private:
|
|
|
|
u64 m_period;
|
|
|
|
u64 m_prev;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
2017-12-30 13:38:11 +11:00
|
|
|
///////////////////////////////////////////////////////////////////////////
|
2012-08-07 18:35:38 +10:00
|
|
|
class polled_duration {
|
|
|
|
public:
|
|
|
|
polled_duration (std::string name, uint64_t interval);
|
|
|
|
|
|
|
|
void start (void);
|
|
|
|
void stop (void);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
std::string m_name;
|
|
|
|
uint64_t m_last;
|
|
|
|
uint64_t m_interval;
|
|
|
|
uint64_t m_next;
|
|
|
|
|
|
|
|
stats::accumulator<uint64_t> m_series;
|
|
|
|
};
|
2011-08-29 15:28:11 +10:00
|
|
|
}
|