From 454307a8845a3bc697531df5fd2e245233ed5218 Mon Sep 17 00:00:00 2001 From: Mark Meserve Date: Fri, 3 Feb 2017 16:25:34 -0600 Subject: Revise calculation of ADF5355 FRAC2 register Corrected residue formula Fixed cast to uint16_t that was behaving differently in msvc14 32-bit vs 64-bit --- host/lib/usrp/common/adf5355.cpp | 11 ++++------- 1 file changed, 4 insertions(+), 7 deletions(-) (limited to 'host/lib/usrp') diff --git a/host/lib/usrp/common/adf5355.cpp b/host/lib/usrp/common/adf5355.cpp index e3fd66bc2..80c300d47 100644 --- a/host/lib/usrp/common/adf5355.cpp +++ b/host/lib/usrp/common/adf5355.cpp @@ -48,6 +48,7 @@ static const double ADF5355_PHASE_RESYNC_TIME = 400e-6; static const uint32_t ADF5355_MOD1 = 16777216; static const uint32_t ADF5355_MAX_MOD2 = 16384; +static const uint32_t ADF5355_MAX_FRAC2 = 16384; //static const uint16_t ADF5355_MIN_INT_PRESCALER_89 = 75; class adf5355_impl : public adf5355_iface @@ -261,15 +262,11 @@ public: double N = prescaler_input_freq / _pfd_freq; uint16_t INT = static_cast(floor(N)); uint32_t FRAC1 = static_cast(floor((N - INT) * ADF5355_MOD1)); - double residue = ADF5355_MOD1 * (N - (INT + FRAC1 / ADF5355_MOD1)); + double residue = (N - INT) * ADF5355_MOD1 - FRAC1; double gcd = boost::math::gcd(static_cast(_pfd_freq), static_cast(freq_resolution)); - uint16_t MOD2 = static_cast(floor(_pfd_freq / gcd)); - - if (MOD2 > ADF5355_MAX_MOD2) { - MOD2 = ADF5355_MAX_MOD2; - } - uint16_t FRAC2 = ceil(residue * MOD2); + uint16_t MOD2 = static_cast(std::min(floor(_pfd_freq / gcd), static_cast(ADF5355_MAX_MOD2))); + uint16_t FRAC2 = static_cast(std::min(ceil(residue * MOD2), static_cast(ADF5355_MAX_FRAC2))); double coerced_vco_freq = _pfd_freq * ( todbl(INT) + ( -- cgit v1.2.3