aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/include/uhdlib/rfnoc
diff options
context:
space:
mode:
Diffstat (limited to 'host/lib/include/uhdlib/rfnoc')
-rw-r--r--host/lib/include/uhdlib/rfnoc/clock_iface.hpp22
1 files changed, 21 insertions, 1 deletions
diff --git a/host/lib/include/uhdlib/rfnoc/clock_iface.hpp b/host/lib/include/uhdlib/rfnoc/clock_iface.hpp
index 807382f13..ae61a645e 100644
--- a/host/lib/include/uhdlib/rfnoc/clock_iface.hpp
+++ b/host/lib/include/uhdlib/rfnoc/clock_iface.hpp
@@ -8,6 +8,8 @@
#define INCLUDED_UHD_RFNOC_CLOCK_IFACE_HPP
#include <uhd/config.hpp>
+#include <uhd/exception.hpp>
+#include <uhd/utils/log.hpp>
#include <atomic>
#include <string>
@@ -16,12 +18,18 @@ namespace uhd { namespace rfnoc {
class clock_iface
{
public:
- clock_iface(const std::string& name) : _name(name)
+ clock_iface(const std::string& name) : _name(name), _is_mutable(true)
{
_is_running = false;
_freq = 0.0;
}
+ clock_iface(const std::string& name, const double freq, const bool is_mutable = true)
+ : _name(name), _freq(freq), _is_mutable(is_mutable)
+ {
+ _is_running = false;
+ }
+
clock_iface() = delete;
clock_iface(const clock_iface& rhs) = delete;
clock_iface(clock_iface&& rhs) = delete;
@@ -38,6 +46,11 @@ public:
return _is_running;
}
+ inline bool is_mutable() const
+ {
+ return _is_mutable;
+ }
+
inline void set_running(bool is_running)
{
_is_running = is_running;
@@ -48,8 +61,14 @@ public:
return _freq;
}
+ //! If the clock is immutable, this will throw if freq is different from the
+ // current frequency.
inline void set_freq(double freq)
{
+ if (!_is_mutable && freq != _freq.load()) {
+ UHD_LOG_ERROR(_name, "Trying to change an immutable clock!");
+ throw uhd::runtime_error("Trying to change an immutable clock!");
+ }
_freq = freq;
}
@@ -57,6 +76,7 @@ private:
const std::string _name;
std::atomic<bool> _is_running;
std::atomic<double> _freq;
+ const bool _is_mutable;
};
}} // namespace uhd::rfnoc