aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorMark Meserve <mark.meserve@ni.com>2019-05-23 17:36:18 -0500
committerMartin Braun <martin.braun@ettus.com>2019-06-12 16:22:04 -0700
commit57d6ed2a0a3c45fcd6854dcdac6377be3f336830 (patch)
tree1d715f823033ba2bdfcb5f5b89c524dd9a17063c
parentff80b058240a5d9ebf6e92a38089a015265c69fe (diff)
downloaduhd-57d6ed2a0a3c45fcd6854dcdac6377be3f336830.tar.gz
uhd-57d6ed2a0a3c45fcd6854dcdac6377be3f336830.tar.bz2
uhd-57d6ed2a0a3c45fcd6854dcdac6377be3f336830.zip
ubx: add temperature compensation mode
- This mode defaults to "disabled" (no change from current behavior) - Enabling this mode fixes some instances where the MAX287x would fail to lock when in integer-n mode - Enabling this mode increases the maximum lock time to up to 100ms
-rw-r--r--host/lib/usrp/dboard/db_ubx.cpp41
1 files changed, 41 insertions, 0 deletions
diff --git a/host/lib/usrp/dboard/db_ubx.cpp b/host/lib/usrp/dboard/db_ubx.cpp
index 2ab5abaad..305a69c52 100644
--- a/host/lib/usrp/dboard/db_ubx.cpp
+++ b/host/lib/usrp/dboard/db_ubx.cpp
@@ -161,6 +161,7 @@ static const std::vector<std::string> ubx_tx_antennas{"TX/RX", "CAL"};
static const std::vector<std::string> ubx_rx_antennas{"TX/RX", "RX2", "CAL"};
static const std::vector<std::string> ubx_power_modes{"performance", "powersave"};
static const std::vector<std::string> ubx_xcvr_modes{"FDX", "TX", "TX/RX", "RX"};
+static const std::vector<std::string> ubx_temp_comp_modes{"enabled", "disabled"};
// clang-format off
static const ubx_gpio_field_info_t ubx_proto_gpio_info[] = {
@@ -445,6 +446,13 @@ public:
get_rx_subtree()->create<std::string>("xcvr_mode/value")
.add_coerced_subscriber(boost::bind(&ubx_xcvr::set_xcvr_mode, this, _1))
.set("FDX");
+ get_rx_subtree()->create<std::vector<std::string> >("temp_comp_mode/options")
+ .set(ubx_temp_comp_modes);
+ get_rx_subtree()
+ ->create<std::string>("temp_comp_mode/value")
+ .add_coerced_subscriber(
+ [this](std::string mode) { this->set_temp_comp_mode(mode); })
+ .set("disabled");
get_tx_subtree()->create<std::vector<std::string> >("power_mode/options")
.set(ubx_power_modes);
get_tx_subtree()->create<std::string>("power_mode/value")
@@ -455,6 +463,21 @@ public:
get_tx_subtree()->create<std::string>("xcvr_mode/value")
.add_coerced_subscriber(boost::bind(&uhd::property<std::string>::set, &get_rx_subtree()->access<std::string>("xcvr_mode/value"), _1))
.set_publisher(boost::bind(&uhd::property<std::string>::get, &get_rx_subtree()->access<std::string>("xcvr_mode/value")));
+ get_tx_subtree()->create<std::vector<std::string> >("temp_comp_mode/options")
+ .set(ubx_temp_comp_modes);
+ get_tx_subtree()
+ ->create<std::string>("temp_comp_mode/value")
+ .add_coerced_subscriber([this](std::string mode) {
+ this->get_rx_subtree()
+ ->access<std::string>("temp_comp_mode/value")
+ .set(mode);
+ })
+ .set_publisher([this]() {
+ return this->get_rx_subtree()
+ ->access<std::string>("temp_comp_mode/value")
+ .get();
+ });
+
////////////////////////////////////////////////////////////////////
// Register TX properties
@@ -1279,6 +1302,24 @@ private:
_rx_sync_delay = value;
}
+ void set_temp_comp_mode(std::string mode)
+ {
+ const bool enabled = [mode]() {
+ if (mode == "enabled") {
+ return true;
+ } else if (mode == "disabled") {
+ return false;
+ } else {
+ throw uhd::value_error("invalid temperature_compensation_mode");
+ }
+ }();
+
+ boost::mutex::scoped_lock lock(_mutex);
+ for (const auto& lo : {_txlo1, _txlo2, _rxlo1, _rxlo2}) {
+ lo->set_auto_retune(enabled);
+ }
+ }
+
/***********************************************************************
* Variables
**********************************************************************/