diff options
Diffstat (limited to 'host/lib/usrp/common/ad936x_manager.cpp')
-rw-r--r-- | host/lib/usrp/common/ad936x_manager.cpp | 118 |
1 files changed, 76 insertions, 42 deletions
diff --git a/host/lib/usrp/common/ad936x_manager.cpp b/host/lib/usrp/common/ad936x_manager.cpp index 9d07350ea..fa964c66c 100644 --- a/host/lib/usrp/common/ad936x_manager.cpp +++ b/host/lib/usrp/common/ad936x_manager.cpp @@ -8,7 +8,9 @@ #include <uhdlib/usrp/common/ad936x_manager.hpp> #include <uhd/utils/log.hpp> #include <boost/functional/hash.hpp> -#include <boost/thread/thread.hpp> +#include <boost/make_shared.hpp> +#include <chrono> +#include <thread> using namespace uhd; using namespace uhd::usrp; @@ -28,7 +30,7 @@ const bool ad936x_manager::DEFAULT_AGC_ENABLE = false; class ad936x_manager_impl : public ad936x_manager { - public: +public: /************************************************************************ * Structor ***********************************************************************/ @@ -55,7 +57,7 @@ class ad936x_manager_impl : public ad936x_manager ***********************************************************************/ void init_codec() { - for(const std::string &rx_fe: _rx_frontends) { + for (const std::string &rx_fe : _rx_frontends) { _codec_ctrl->set_gain(rx_fe, DEFAULT_GAIN); _codec_ctrl->set_bw_filter(rx_fe, DEFAULT_BANDWIDTH); _codec_ctrl->tune(rx_fe, DEFAULT_FREQ); @@ -63,7 +65,7 @@ class ad936x_manager_impl : public ad936x_manager _codec_ctrl->set_iq_balance_auto(rx_fe, DEFAULT_AUTO_IQ_BALANCE); _codec_ctrl->set_agc(rx_fe, DEFAULT_AGC_ENABLE); } - for(const std::string &tx_fe: _tx_frontends) { + for (const std::string &tx_fe : _tx_frontends) { _codec_ctrl->set_gain(tx_fe, DEFAULT_GAIN); _codec_ctrl->set_bw_filter(tx_fe, DEFAULT_BANDWIDTH); _codec_ctrl->tune(tx_fe, DEFAULT_FREQ); @@ -82,12 +84,12 @@ class ad936x_manager_impl : public ad936x_manager // worst case conditions to stress the interface. // void loopback_self_test( - boost::function<void(uint32_t)> poker_functor, - boost::function<uint64_t()> peeker_functor + std::function<void(uint32_t)> poker_functor, + std::function<uint64_t()> peeker_functor ) { // Put AD936x in loopback mode _codec_ctrl->data_port_loopback(true); - UHD_LOGGER_INFO("AD936X") << "Performing CODEC loopback test... "; + UHD_LOGGER_DEBUG("AD936X") << "Performing CODEC loopback test... "; size_t hash = size_t(time(NULL)); // Allow some time for AD936x to enter loopback mode. @@ -96,10 +98,10 @@ class ad936x_manager_impl : public ad936x_manager // when leaving the TX or RX states. That works out to ~75us at the // minimum clock rate of 5 MHz, which lines up with test results. // Sleeping 1ms is far more than enough. - boost::this_thread::sleep(boost::posix_time::milliseconds(1)); + std::this_thread::sleep_for(std::chrono::milliseconds(1)); - for (size_t i = 0; i < 100; i++) - { + constexpr size_t NUM_LOOPBACK_ITERS = 100; + for (size_t i = 0; i < NUM_LOOPBACK_ITERS; i++) { // Create test word boost::hash_combine(hash, i); const uint32_t word32 = uint32_t(hash) & 0xfff0fff0; @@ -107,20 +109,22 @@ class ad936x_manager_impl : public ad936x_manager // Write test word to codec_idle idle register (on TX side) poker_functor(word32); - // Read back values - TX is lower 32-bits and RX is upper 32-bits + // Read back values const uint64_t rb_word64 = peeker_functor(); const uint32_t rb_tx = uint32_t(rb_word64 >> 32); const uint32_t rb_rx = uint32_t(rb_word64 & 0xffffffff); // Compare TX and RX values to test word - bool test_fail = word32 != rb_tx or word32 != rb_rx; - if(test_fail) - { - UHD_LOGGER_INFO("AD936X") << "CODEC loopback test failed"; + const bool test_fail = word32 != rb_tx or word32 != rb_rx; + if (test_fail) { + UHD_LOGGER_ERROR("AD936X") + << "CODEC loopback test failed! " + << boost::format("Expected: 0x%08X Received (TX/RX): 0x%08X/0x%08X") + % word32 % rb_tx % rb_rx; throw uhd::runtime_error("CODEC loopback test failed."); } } - UHD_LOGGER_INFO("AD936X") << "CODEC loopback test passed"; + UHD_LOGGER_DEBUG("AD936X") << "CODEC loopback test passed."; // Zero out the idle data. poker_functor(0); @@ -192,28 +196,36 @@ class ad936x_manager_impl : public ad936x_manager return true; } - void populate_frontend_subtree(uhd::property_tree::sptr subtree, const std::string &key, uhd::direction_t dir) - { + void populate_frontend_subtree( + uhd::property_tree::sptr subtree, + const std::string &key, + uhd::direction_t dir + ) { subtree->create<std::string>("name").set("FE-"+key); // Sensors subtree->create<sensor_value_t>("sensors/temp") - .set_publisher(boost::bind(&ad9361_ctrl::get_temperature, _codec_ctrl)) + .set_publisher([this](){ + return this->_codec_ctrl->get_temperature(); + }) ; if (dir == RX_DIRECTION) { subtree->create<sensor_value_t>("sensors/rssi") - .set_publisher(boost::bind(&ad9361_ctrl::get_rssi, _codec_ctrl, key)) + .set_publisher([this, key](){ + return this->_codec_ctrl->get_rssi(key); + }) ; } // Gains - for(const std::string &name: ad9361_ctrl::get_gain_names(key)) - { + for (const std::string &name : ad9361_ctrl::get_gain_names(key)) { subtree->create<meta_range_t>(uhd::fs_path("gains") / name / "range") .set(ad9361_ctrl::get_gain_range(key)); subtree->create<double>(uhd::fs_path("gains") / name / "value") .set(ad936x_manager::DEFAULT_GAIN) - .set_coercer(boost::bind(&ad9361_ctrl::set_gain, _codec_ctrl, key, _1)) + .set_coercer([this, key](const double gain){ + return this->_codec_ctrl->set_gain(key, gain); + }) ; } @@ -225,19 +237,29 @@ class ad936x_manager_impl : public ad936x_manager // Analog Bandwidths subtree->create<double>("bandwidth/value") .set(ad936x_manager::DEFAULT_BANDWIDTH) - .set_coercer(boost::bind(&ad9361_ctrl::set_bw_filter, _codec_ctrl, key, _1)) + .set_coercer([this, key](const double bw){ + return this->_codec_ctrl->set_bw_filter(key, bw); + }) ; subtree->create<meta_range_t>("bandwidth/range") - .set_publisher(boost::bind(&ad9361_ctrl::get_bw_filter_range, key)) + .set_publisher([key](){ + return ad9361_ctrl::get_bw_filter_range(key); + }) ; // LO Tuning subtree->create<meta_range_t>("freq/range") - .set_publisher(boost::bind(&ad9361_ctrl::get_rf_freq_range)) + .set_publisher([](){ + return ad9361_ctrl::get_rf_freq_range(); + }) ; subtree->create<double>("freq/value") - .set_publisher(boost::bind(&ad9361_ctrl::get_freq, _codec_ctrl, key)) - .set_coercer(boost::bind(&ad9361_ctrl::tune, _codec_ctrl, key, _1)) + .set_publisher([this, key](){ + return this->_codec_ctrl->get_freq(key); + }) + .set_coercer([this, key](const double freq){ + return this->_codec_ctrl->tune(key, freq); + }) ; // Frontend corrections @@ -245,36 +267,50 @@ class ad936x_manager_impl : public ad936x_manager { subtree->create<bool>("dc_offset/enable" ) .set(ad936x_manager::DEFAULT_AUTO_DC_OFFSET) - .add_coerced_subscriber(boost::bind(&ad9361_ctrl::set_dc_offset_auto, _codec_ctrl, key, _1)) + .add_coerced_subscriber([this, key](const bool enable){ + this->_codec_ctrl->set_dc_offset_auto(key, enable); + }) ; subtree->create<bool>("iq_balance/enable" ) .set(ad936x_manager::DEFAULT_AUTO_IQ_BALANCE) - .add_coerced_subscriber(boost::bind(&ad9361_ctrl::set_iq_balance_auto, _codec_ctrl, key, _1)) + .add_coerced_subscriber([this, key](const bool enable){ + this->_codec_ctrl->set_iq_balance_auto(key, enable); + }) ; // AGC setup - const std::list<std::string> mode_strings = boost::assign::list_of("slow")("fast"); + const std::list<std::string> mode_strings{"slow", "fast"}; subtree->create<bool>("gain/agc/enable") .set(DEFAULT_AGC_ENABLE) - .add_coerced_subscriber(boost::bind((&ad9361_ctrl::set_agc), _codec_ctrl, key, _1)) + .add_coerced_subscriber([this, key](const bool enable){ + this->_codec_ctrl->set_agc(key, enable); + }) ; subtree->create<std::string>("gain/agc/mode/value") - .add_coerced_subscriber(boost::bind((&ad9361_ctrl::set_agc_mode), _codec_ctrl, key, _1)).set(mode_strings.front()) + .add_coerced_subscriber([this, key](const std::string& value){ + this->_codec_ctrl->set_agc_mode(key, value); + }) + .set(mode_strings.front()) ; - subtree->create< std::list<std::string> >("gain/agc/mode/options") + subtree->create<std::list<std::string>>("gain/agc/mode/options") .set(mode_strings) ; } // Frontend filters - for(const std::string &filter_name: _codec_ctrl->get_filter_names(key)) { - subtree->create<filter_info_base::sptr>(uhd::fs_path("filters") / filter_name / "value" ) - .set_publisher(boost::bind(&ad9361_ctrl::get_filter, _codec_ctrl, key, filter_name)) - .add_coerced_subscriber(boost::bind(&ad9361_ctrl::set_filter, _codec_ctrl, key, filter_name, _1)); + for (const auto &filter_name : _codec_ctrl->get_filter_names(key)) { + subtree->create<filter_info_base::sptr>(uhd::fs_path("filters") / filter_name / "value") + .set_publisher([this, key, filter_name](){ + return this->_codec_ctrl->get_filter(key, filter_name); + }) + .add_coerced_subscriber([this, key, filter_name](filter_info_base::sptr filter_info){ + this->_codec_ctrl->set_filter(key, filter_name, filter_info); + }) + ; } } - private: +private: //! Store a pointer to an actual AD936x control object ad9361_ctrl::sptr _codec_ctrl; @@ -291,8 +327,6 @@ ad936x_manager::sptr ad936x_manager::make( const ad9361_ctrl::sptr &codec_ctrl, const size_t n_frontends ) { - return sptr( - new ad936x_manager_impl(codec_ctrl, n_frontends) - ); + return boost::make_shared<ad936x_manager_impl>(codec_ctrl, n_frontends); } |