From 6a5807ecab1c8580b2b187da441017735189fd53 Mon Sep 17 00:00:00 2001 From: michael-west Date: Tue, 12 Jan 2021 11:21:49 -0800 Subject: TwinRX: Spur cleanup - Reduce FRAC2 and MOD2 values on ADF5356 - Add write to register 10 and delay during retune on ADF5356 - Make negative bleed conditional on integer or fractional N mode for ADF5356 - Tune unused LOs out of band to remove interference Signed-off-by: michael-west --- host/lib/usrp/dboard/twinrx/twinrx_ctrl.cpp | 10 ++++++---- 1 file changed, 6 insertions(+), 4 deletions(-) (limited to 'host/lib/usrp/dboard/twinrx/twinrx_ctrl.cpp') diff --git a/host/lib/usrp/dboard/twinrx/twinrx_ctrl.cpp b/host/lib/usrp/dboard/twinrx/twinrx_ctrl.cpp index 3686f4348..315861cd9 100644 --- a/host/lib/usrp/dboard/twinrx/twinrx_ctrl.cpp +++ b/host/lib/usrp/dboard/twinrx/twinrx_ctrl.cpp @@ -121,7 +121,7 @@ public: [this](uint32_t microseconds) { _db_iface->sleep(boost::chrono::microseconds(microseconds)); }); - _lo1_iface[i]->set_pfd_freq(TWINRX_REV_C_PFD_FREQ); + _lo1_pfd_freq = TWINRX_REV_C_PFD_FREQ; } else { _lo1_iface[i] = adf535x_iface::make_adf5355( [this](const std::vector& regs) { @@ -130,13 +130,14 @@ public: [this](uint32_t microseconds) { _db_iface->sleep(boost::chrono::microseconds(microseconds)); }); - _lo1_iface[i]->set_pfd_freq(TWINRX_REV_AB_PFD_FREQ); + _lo1_pfd_freq = TWINRX_REV_AB_PFD_FREQ; } + _lo1_iface[i]->set_pfd_freq(_lo1_pfd_freq); _lo1_iface[i]->set_output_power(adf535x_iface::OUTPUT_POWER_5DBM); _lo1_iface[i]->set_reference_freq( _db_iface->get_clock_rate(dboard_iface::UNIT_TX)); _lo1_iface[i]->set_muxout_mode(adf535x_iface::MUXOUT_DLD); - _lo1_iface[i]->set_frequency(3e9, 1.0e3); + _lo1_iface[i]->set_frequency(3e9, _lo1_pfd_freq / 2); // LO2 _lo2_iface[i] = @@ -561,7 +562,7 @@ public: double set_lo1_synth_freq(channel_t ch, double freq, bool commit = true) { boost::lock_guard lock(_mutex); - static const double RESOLUTION = 1e3; + static const double RESOLUTION = _lo1_pfd_freq / 2; double coerced_freq = 0.0; if (ch == CH1 or ch == BOTH) { @@ -852,6 +853,7 @@ private: // Members twinrx_gpio::sptr _gpio_iface; twinrx_cpld_regmap::sptr _cpld_regs; spi_config_t _spi_config; + double _lo1_pfd_freq; adf535x_iface::sptr _lo1_iface[NUM_CHANS]; adf435x_iface::sptr _lo2_iface[NUM_CHANS]; lo_source_t _lo1_src[NUM_CHANS]; -- cgit v1.2.3