aboutsummaryrefslogtreecommitdiffstats
path: root/host/lib/usrp/multi_usrp.cpp
diff options
context:
space:
mode:
authorDerek Kozel <derek.kozel@ettus.com>2016-08-08 13:04:06 -0700
committerMartin Braun <martin.braun@ettus.com>2016-08-09 10:19:30 -0700
commit1137dc4726160edf37a29d15b3e99d37ba941be6 (patch)
tree63bb61cceb2309522b4cd861299ae21432d8a7ef /host/lib/usrp/multi_usrp.cpp
parent0584d6d3fe2b6c7bbd2fc455fed34b12d4168830 (diff)
downloaduhd-1137dc4726160edf37a29d15b3e99d37ba941be6.tar.gz
uhd-1137dc4726160edf37a29d15b3e99d37ba941be6.tar.bz2
uhd-1137dc4726160edf37a29d15b3e99d37ba941be6.zip
Coerces dsp frequency to 0 if any channel uses an external LO
Diffstat (limited to 'host/lib/usrp/multi_usrp.cpp')
-rw-r--r--host/lib/usrp/multi_usrp.cpp20
1 files changed, 19 insertions, 1 deletions
diff --git a/host/lib/usrp/multi_usrp.cpp b/host/lib/usrp/multi_usrp.cpp
index e0811e667..b5df54a65 100644
--- a/host/lib/usrp/multi_usrp.cpp
+++ b/host/lib/usrp/multi_usrp.cpp
@@ -809,10 +809,28 @@ public:
}
tune_result_t set_rx_freq(const tune_request_t &tune_request, size_t chan){
+ tune_request_t local_request = tune_request;
+
+ // If any mixer is driven by an external LO the daughterboard assumes that no CORDIC correction is
+ // necessary. Since the LO might be sourced from another daughterboard which would normally apply a
+ // cordic correction we must disable all DSP tuning to ensure identical configurations across daughterboards.
+ if (tune_request.dsp_freq_policy == tune_request.POLICY_AUTO and
+ tune_request.rf_freq_policy == tune_request.POLICY_AUTO)
+ {
+ for (size_t c = 0; c < get_rx_num_channels(); c++) {
+ UHD_VAR(get_rx_lo_source(ALL_LOS, c));
+ if (get_rx_lo_source(ALL_LOS, c) == "external") {
+ local_request.dsp_freq_policy = tune_request.POLICY_MANUAL;
+ local_request.dsp_freq = 0;
+ break;
+ }
+ }
+ }
+
tune_result_t result = tune_xx_subdev_and_dsp(RX_SIGN,
_tree->subtree(rx_dsp_root(chan)),
_tree->subtree(rx_rf_fe_root(chan)),
- tune_request);
+ local_request);
//do_tune_freq_results_message(tune_request, result, get_rx_freq(chan), "RX");
return result;
}