aboutsummaryrefslogtreecommitdiffstats
path: root/mpm/lib/mykonos/ad937x_ctrl.cpp
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2017-12-11 18:02:14 -0800
committerMartin Braun <martin.braun@ettus.com>2017-12-22 15:05:58 -0800
commitb5404ef75f8b08e51311c16c0a435b1bbb2ff807 (patch)
tree43d8c32cba6022f67b94bd443bdfffc5659aa793 /mpm/lib/mykonos/ad937x_ctrl.cpp
parent66af893e43af6d628c40d26529c154bb7a1f6d97 (diff)
downloaduhd-b5404ef75f8b08e51311c16c0a435b1bbb2ff807.tar.gz
uhd-b5404ef75f8b08e51311c16c0a435b1bbb2ff807.tar.bz2
uhd-b5404ef75f8b08e51311c16c0a435b1bbb2ff807.zip
mpm: Fix floating-point errors in MCR configuration
Use fuzzy comparisons for setting the MCR. Reviewed-By: Trung Tran <trung.tran@ettus.com>
Diffstat (limited to 'mpm/lib/mykonos/ad937x_ctrl.cpp')
-rw-r--r--mpm/lib/mykonos/ad937x_ctrl.cpp22
1 files changed, 20 insertions, 2 deletions
diff --git a/mpm/lib/mykonos/ad937x_ctrl.cpp b/mpm/lib/mykonos/ad937x_ctrl.cpp
index 2642e3858..1dd118e8b 100644
--- a/mpm/lib/mykonos/ad937x_ctrl.cpp
+++ b/mpm/lib/mykonos/ad937x_ctrl.cpp
@@ -19,7 +19,9 @@
#include "adi/mykonos.h"
#include "mpm/ad937x/ad937x_ctrl.hpp"
#include <mpm/exception.hpp>
+#include "../../../host/include/uhd/utils/math.hpp"
+#include <boost/format.hpp>
#include <sstream>
#include <set>
#include <functional>
@@ -482,8 +484,24 @@ public:
virtual void set_master_clock_rate(const double rate)
{
std::lock_guard<std::mutex> lock(*spi_mutex);
- // FIXME: Add check for valid rates
- device.set_master_clock_rate(rate);
+ ad937x_device::mcr_t mcr;
+ if (uhd::math::frequencies_are_equal(rate, 122.88e6)) {
+ mcr = ad937x_device::MCR_122_88MHZ;
+ }
+ else if (uhd::math::frequencies_are_equal(rate, 125e6)) {
+ mcr = ad937x_device::MCR_125_00MHZ;
+ }
+ else if (uhd::math::frequencies_are_equal(rate, 153.6e6)) {
+ mcr = ad937x_device::MCR_153_60MHZ;
+ }
+ else {
+ throw mpm::value_error(boost::str(
+ boost::format("Requested invalid master clock rate: %f MHz")
+ % (rate / 1e6)
+ ));
+ }
+
+ device.set_master_clock_rate(mcr);
}
virtual void set_enable_gain_pins(const std::string &which, bool enable)