aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--host/lib/include/uhdlib/utils/compat_check.hpp13
-rw-r--r--host/lib/utils/compat_check.cpp18
2 files changed, 31 insertions, 0 deletions
diff --git a/host/lib/include/uhdlib/utils/compat_check.hpp b/host/lib/include/uhdlib/utils/compat_check.hpp
index b2d7652d0..8fe96d118 100644
--- a/host/lib/include/uhdlib/utils/compat_check.hpp
+++ b/host/lib/include/uhdlib/utils/compat_check.hpp
@@ -25,6 +25,19 @@ namespace uhd {
const bool fail_on_minor_behind=false
);
+ /*! Checks for FPGA compatibility, and throws an exception on mismatch.
+ *
+ * \throws uhd::runtime_error on mismatch.
+ */
+ void assert_fpga_compat(
+ const size_t uhd_major,
+ const size_t uhd_minor,
+ const uint32_t fpga_compat,
+ const std::string& fpga_component,
+ const std::string& log_component,
+ const bool fail_on_minor_behind=false
+ );
+
} /* namespace uhd */
#endif /* INCLUDED_UHDLIB_UTILS_COMPATCHECK_HPP */
diff --git a/host/lib/utils/compat_check.cpp b/host/lib/utils/compat_check.cpp
index f15ba8bba..e340e5c67 100644
--- a/host/lib/utils/compat_check.cpp
+++ b/host/lib/utils/compat_check.cpp
@@ -112,3 +112,21 @@ void uhd::assert_fpga_compat(
}
// We got here? Then all is good.
}
+
+void uhd::assert_fpga_compat(const size_t uhd_major,
+ const size_t uhd_minor,
+ const uint32_t fpga_compat,
+ const std::string& fpga_component,
+ const std::string& log_component,
+ const bool fail_on_minor_behind)
+{
+ const size_t fpga_major = fpga_compat >> 16;
+ const size_t fpga_minor = fpga_compat & 0xFFFF;
+ const uint64_t fpga_scaled = uint64_t(fpga_major) << 32 | fpga_minor;
+ uhd::assert_fpga_compat(uhd_major,
+ uhd_minor,
+ fpga_scaled,
+ fpga_component,
+ log_component,
+ fail_on_minor_behind);
+}