diff options
author | Martin Braun <martin.braun@ettus.com> | 2021-09-23 19:15:40 +0200 |
---|---|---|
committer | Aaron Rossetto <aaron.rossetto@ni.com> | 2021-09-30 11:28:32 -0700 |
commit | a0d77720dbce873baa5816f15348639ed02ea8ae (patch) | |
tree | 26d022dd3c9c9d02634d30aaca10e66cfa9fc7c7 | |
parent | 96e95db5cd98101b746e0b7b473e5352d476caa5 (diff) | |
download | uhd-a0d77720dbce873baa5816f15348639ed02ea8ae.tar.gz uhd-a0d77720dbce873baa5816f15348639ed02ea8ae.tar.bz2 uhd-a0d77720dbce873baa5816f15348639ed02ea8ae.zip |
ad9361: Add comment re overclocking
As GitHub user marcosino points out, we're running the AD9361 in
overclocked mode. This is because the driver was written with no longer
valid recommendations.
We add a comment and some debug messages to clarify this. Should there
be RF impairments (signal integrity or other) because of overclocking,
users would be able to check DEBUG log statements to correlate with
overclocked configurations.
-rw-r--r-- | host/lib/usrp/common/ad9361_driver/ad9361_device.cpp | 26 |
1 files changed, 23 insertions, 3 deletions
diff --git a/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp b/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp index 5574022b6..6d687f80e 100644 --- a/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp +++ b/host/lib/usrp/common/ad9361_driver/ad9361_device.cpp @@ -1242,7 +1242,11 @@ double ad9361_device_t::_tune_bbvco(const double rate) * (double)modulus); UHD_LOG_TRACE("AD936X", boost::format("[ad9361_device_t::_tune_bbvco] nint=%d nfrac=%d") % nint % nfrac); - double actual_vcorate = fref * ((double)nint + ((double)nfrac / (double)modulus)); + const double actual_vcorate = + fref * ((double)nint + ((double)nfrac / (double)modulus)); + UHD_LOG_TRACE("AD936X", + boost::format("[ad9361_device_t::_tune_bbvco] actual vcorate=%.10f") + % actual_vcorate); /* Scale CP current according to VCO rate */ const double icp_baseline = 150e-6; @@ -1507,8 +1511,14 @@ double ad9361_device_t::_setup_rates(const double rate) const double adcclk = _tune_bbvco(rate * divfactor); double dacclk = adcclk; - /* The DAC clock must be <= 336e6, and is either the ADC clock or 1/2 the - * ADC clock.*/ + // We keep the DAC clock <= 336 MHz, either the ADC clock or 1/2 the ADC + // clock. + // Note that current recommendations from ADI are 640 MHz for the ADC and + // 320 MHz for the DAC. We are thus overclocking the AD9361, since we are + // using these no longer valid recommendations, but they seem to work and we + // consider the risk of changing these higher than the benefit. We will add + // a log statement, though, so we can track back suboptimal RF performance + // to overclocked settings. if (adcclk > 336e6) { /* Make the DAC clock = ADC/2 */ _regs.bbpll = _regs.bbpll | 0x08; @@ -1516,6 +1526,16 @@ double ad9361_device_t::_setup_rates(const double rate) } else { _regs.bbpll = _regs.bbpll & 0xF7; } + if (dacclk > 320e6) { + UHD_LOG_DEBUG("AD936X", + "[ad9361_device_t::_setup_rates] DAC rate is overclocked! dacclk=" + << (dacclk / 1e6) << " MHz."); + } + if (dacclk > 640e6) { + UHD_LOG_DEBUG("AD936X", + "[ad9361_device_t::_setup_rates] ADC rate is overclocked! adcclk=" + << (adcclk / 1e6) << " MHz."); + } /* Set the dividers / interpolators in AD9361. */ _io_iface->poke8(0x002, _regs.txfilt); |