aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMartin Braun <martin.braun@ettus.com>2021-09-23 19:15:40 +0200
committerAaron Rossetto <aaron.rossetto@ni.com>2021-09-30 11:28:32 -0700
commita0d77720dbce873baa5816f15348639ed02ea8ae (patch)
tree26d022dd3c9c9d02634d30aaca10e66cfa9fc7c7
parent96e95db5cd98101b746e0b7b473e5352d476caa5 (diff)
downloaduhd-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.cpp26
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);