diff options
| author | mattprost <matt.prost@ni.com> | 2020-07-28 13:29:38 -0500 | 
|---|---|---|
| committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2020-08-11 16:07:16 -0500 | 
| commit | fc3f91e0cfb77e295673ac04d310ded65863c119 (patch) | |
| tree | 83aec8d8f2d62bbb69a8c52873b085d11704e00a /host/lib/include/uhdlib | |
| parent | de8b6fcd7137834defbb52242bc4cdec8adb167e (diff) | |
| download | uhd-fc3f91e0cfb77e295673ac04d310ded65863c119.tar.gz uhd-fc3f91e0cfb77e295673ac04d310ded65863c119.tar.bz2 uhd-fc3f91e0cfb77e295673ac04d310ded65863c119.zip | |
twinrx: update synthesizer register values for improved rf performance
Updated Register values for ADF5356:
R2) Expand Frac2 to a 28-bit value for ADF5356
R6) Use negative bleed current for improved spurious performance
R7) Set Fractional-N Lock Detect Precision to 12.0 ns because of bleed
currents
R8) Use magic number for reserved bits
R9) Fix VCO Band Division calculation for ADF5356
RD) Expand Frac2 to a 28-bit value for ADF5356
Signed-off-by: mattprost <matt.prost@ni.com>
Diffstat (limited to 'host/lib/include/uhdlib')
| -rw-r--r-- | host/lib/include/uhdlib/usrp/common/adf535x.hpp | 39 | 
1 files changed, 28 insertions, 11 deletions
| diff --git a/host/lib/include/uhdlib/usrp/common/adf535x.hpp b/host/lib/include/uhdlib/usrp/common/adf535x.hpp index e8f4a9309..03efecc36 100644 --- a/host/lib/include/uhdlib/usrp/common/adf535x.hpp +++ b/host/lib/include/uhdlib/usrp/common/adf535x.hpp @@ -96,8 +96,10 @@ const double ADF535X_MIN_OUT_FREQ = (3.4e9 / 64);  const double ADF535X_PHASE_RESYNC_TIME = 400e-6;  const uint32_t ADF535X_MOD1      = 16777216; -const uint32_t ADF535X_MAX_MOD2  = 16383; -const uint32_t ADF535X_MAX_FRAC2 = 16383; +const uint32_t ADF5355_MAX_MOD2  = 16383; +const uint32_t ADF5355_MAX_FRAC2 = 16383; +const uint32_t ADF5356_MAX_MOD2  = 268435455; +const uint32_t ADF5356_MAX_FRAC2 = 268435455;  // const uint16_t ADF535X_MIN_INT_PRESCALER_89 = 75;  } // namespace @@ -205,7 +207,7 @@ public:          //-----------------------------------------------------------          // Set VCO band divider -        _regs.vco_band_div = static_cast<uint8_t>(ceil(_pfd_freq / 2.4e6)); +        _regs.vco_band_div = _set_vco_band_div(_pfd_freq);          //-----------------------------------------------------------          // Set ADC delay (code from ADI driver) @@ -342,6 +344,7 @@ public:      }  protected: +    uint8_t _set_vco_band_div(double);      double _set_frequency(double, double, bool);      uhd::meta_range_t _get_charge_pump_current_range();      void _commit(); @@ -361,6 +364,12 @@ private: // Members  // ADF5355 Functions  template <> +inline uint8_t adf535x_impl<adf5355_regs_t>::_set_vco_band_div(double pfd_freq) +{ +    return static_cast<uint8_t>(ceil(pfd_freq / 2.4e6)); +} + +template <>  inline double adf535x_impl<adf5355_regs_t>::_set_frequency(      double target_freq, double freq_resolution, bool flush)  { @@ -420,9 +429,9 @@ inline double adf535x_impl<adf5355_regs_t>::_set_frequency(      const double gcd = double(          uhd::math::gcd(static_cast<int>(_pfd_freq), static_cast<int>(freq_resolution)));      const auto MOD2 = static_cast<uint16_t>( -        std::min(floor(_pfd_freq / gcd), static_cast<double>(ADF535X_MAX_MOD2))); +        std::min(floor(_pfd_freq / gcd), static_cast<double>(ADF5355_MAX_MOD2)));      const auto FRAC2 = static_cast<uint16_t>( -        std::min(ceil(residue * MOD2), static_cast<double>(ADF535X_MAX_FRAC2))); +        std::min(ceil(residue * MOD2), static_cast<double>(ADF5355_MAX_FRAC2)));      const double coerced_vco_freq =          _pfd_freq * (_fb_after_divider ? rf_divider : 1) @@ -492,6 +501,12 @@ inline void adf535x_impl<adf5355_regs_t>::_commit()  // ADF5356 Functions  template <> +inline uint8_t adf535x_impl<adf5356_regs_t>::_set_vco_band_div(double pfd_freq) +{ +    return static_cast<uint8_t>(ceil(pfd_freq / 1.6e6)); +} + +template <>  inline double adf535x_impl<adf5356_regs_t>::_set_frequency(      double target_freq, double freq_resolution, bool flush)  { @@ -550,10 +565,10 @@ inline double adf535x_impl<adf5356_regs_t>::_set_frequency(      const double gcd = double(          uhd::math::gcd(static_cast<int>(_pfd_freq), static_cast<int>(freq_resolution))); -    const auto MOD2 = static_cast<uint16_t>( -        std::min(floor(_pfd_freq / gcd), static_cast<double>(ADF535X_MAX_MOD2))); -    const auto FRAC2 = static_cast<uint16_t>( -        std::min(round(residue * MOD2), static_cast<double>(ADF535X_MAX_FRAC2))); +    const auto MOD2 = static_cast<uint32_t>( +        std::min(floor(_pfd_freq / gcd), static_cast<double>(ADF5356_MAX_MOD2))); +    const auto FRAC2 = static_cast<uint32_t>( +        std::min(round(residue * MOD2), static_cast<double>(ADF5356_MAX_FRAC2)));      const double coerced_vco_freq =          _pfd_freq * (_fb_after_divider ? rf_divider : 1) @@ -575,8 +590,10 @@ inline double adf535x_impl<adf5356_regs_t>::_set_frequency(      /* Update registers */      _regs.int_16_bit   = INT;      _regs.frac1_24_bit = FRAC1; -    _regs.frac2_msb    = FRAC2; -    _regs.mod2_msb     = MOD2; +    _regs.frac2_lsb    = narrow_cast<uint16_t>(FRAC2 & 0x3FFF); +    _regs.mod2_lsb     = narrow_cast<uint16_t>(MOD2 & 0x3FFF); +    _regs.frac2_msb    = narrow_cast<uint16_t>(FRAC2 >> 14); +    _regs.mod2_msb     = narrow_cast<uint16_t>(MOD2 >> 14);      _regs.phase_24_bit = 0;      if (flush) | 
