diff options
Diffstat (limited to 'host/lib/rfnoc')
-rw-r--r-- | host/lib/rfnoc/radio_ctrl_impl.cpp | 127 | ||||
-rw-r--r-- | host/lib/rfnoc/radio_ctrl_impl.hpp | 3 |
2 files changed, 74 insertions, 56 deletions
diff --git a/host/lib/rfnoc/radio_ctrl_impl.cpp b/host/lib/rfnoc/radio_ctrl_impl.cpp index 827443ffd..c91147def 100644 --- a/host/lib/rfnoc/radio_ctrl_impl.cpp +++ b/host/lib/rfnoc/radio_ctrl_impl.cpp @@ -6,13 +6,13 @@ #include "wb_iface_adapter.hpp" #include <boost/format.hpp> -#include <boost/bind.hpp> #include <uhd/convert.hpp> #include <uhd/utils/log.hpp> #include <uhd/types/ranges.hpp> #include <uhd/types/direction.hpp> #include "radio_ctrl_impl.hpp" #include "../../transport/super_recv_packet_handler.hpp" +#include <tuple> using namespace uhd; using namespace uhd::rfnoc; @@ -46,33 +46,25 @@ radio_ctrl_impl::radio_ctrl_impl() : _register_loopback_self_test(i); _perifs[i].ctrl = boost::make_shared<wb_iface_adapter>( // poke32 functor - boost::bind( - static_cast< void (block_ctrl_base::*)(const uint32_t, const uint32_t, const size_t) >(&block_ctrl_base::sr_write), - this, _1, _2, i - ), + [this, i](const uint32_t addr, const uint32_t data){ + this->sr_write(addr, data, i); + }, // peek32 functor - boost::bind( - static_cast< uint32_t (block_ctrl_base::*)(const uint32_t, const size_t) >(&block_ctrl_base::user_reg_read32), - this, - _1, i - ), + [this, i](const uint32_t addr){ + return this->user_reg_read32(addr, i); + }, // peek64 functor - boost::bind( - static_cast< uint64_t (block_ctrl_base::*)(const uint32_t, const size_t) >(&block_ctrl_base::user_reg_read64), - this, - _1, i - ), + [this, i](const uint32_t addr){ + return this->user_reg_read64(addr, i); + }, // get_time functor - boost::bind( - static_cast< time_spec_t (block_ctrl_base::*)(const size_t) >(&block_ctrl_base::get_command_time), - this, i - ), + [this, i](){ + return this->get_command_time(i); + }, // set_time functor - boost::bind( - static_cast< void (block_ctrl_base::*)(const time_spec_t&, const size_t) >(&block_ctrl_base::set_command_time), - this, - _1, i - ) + [this, i](const time_spec_t& time_spec){ + this->set_command_time(time_spec, i); + } ); // FIXME there's currently no way to set the underflow policy @@ -81,7 +73,11 @@ radio_ctrl_impl::radio_ctrl_impl() : time_core_3000::readback_bases_type time64_rb_bases; time64_rb_bases.rb_now = regs::RB_TIME_NOW; time64_rb_bases.rb_pps = regs::RB_TIME_PPS; - _time64 = time_core_3000::make(_perifs[i].ctrl, regs::sr_addr(regs::TIME), time64_rb_bases); + _time64 = time_core_3000::make( + _perifs[i].ctrl, + regs::sr_addr(regs::TIME), + time64_rb_bases + ); this->set_time_now(0.0); } @@ -94,32 +90,40 @@ radio_ctrl_impl::radio_ctrl_impl() : //////////////////////////////////////////////////////////////////// if (not _tree->exists(fs_path("time") / "now")) { _tree->create<time_spec_t>(fs_path("time") / "now") - .set_publisher(boost::bind(&radio_ctrl_impl::get_time_now, this)) + .set_publisher([this](){ return this->get_time_now(); }) ; } if (not _tree->exists(fs_path("time") / "pps")) { _tree->create<time_spec_t>(fs_path("time") / "pps") - .set_publisher(boost::bind(&radio_ctrl_impl::get_time_last_pps, this)) + .set_publisher([this](){ return this->get_time_last_pps(); }) ; } if (not _tree->exists(fs_path("time") / "cmd")) { _tree->create<time_spec_t>(fs_path("time") / "cmd"); } _tree->access<time_spec_t>(fs_path("time") / "now") - .add_coerced_subscriber(boost::bind(&radio_ctrl_impl::set_time_now, this, _1)) + .add_coerced_subscriber([this](const time_spec_t& time_spec){ + this->set_time_now(time_spec); + }) ; _tree->access<time_spec_t>(fs_path("time") / "pps") - .add_coerced_subscriber(boost::bind(&radio_ctrl_impl::set_time_next_pps, this, _1)) + .add_coerced_subscriber([this](const time_spec_t& time_spec){ + this->set_time_next_pps(time_spec); + }) ; for (size_t i = 0; i < _get_num_radios(); i++) { _tree->access<time_spec_t>("time/cmd") - .add_coerced_subscriber(boost::bind(&block_ctrl_base::set_command_tick_rate, this, boost::ref(_tick_rate), i)) - .add_coerced_subscriber(boost::bind(&block_ctrl_base::set_command_time, this, _1, i)) + .add_coerced_subscriber([this, i](const time_spec_t& time_spec){ + this->set_command_tick_rate(this->_tick_rate, i); + this->set_command_time(time_spec, i); + }) ; } // spp gets created in the XML file _tree->access<int>(get_arg_path("spp") / "value") - .add_coerced_subscriber(boost::bind(&radio_ctrl_impl::_update_spp, this, _1)) + .add_coerced_subscriber([this](const int spp){ + this->_update_spp(spp); + }) .update() ; } @@ -134,7 +138,10 @@ void radio_ctrl_impl::_register_loopback_self_test(size_t chan) uint32_t result = user_reg_read32(regs::RB_TEST, chan); if (result != uint32_t(hash)) { UHD_LOGGER_ERROR("RFNOC RADIO") << "Register loopback test failed"; - UHD_LOGGER_ERROR("RFNOC RADIO") << boost::format("expected: %x result: %x") % uint32_t(hash) % result ; + UHD_LOGGER_ERROR("RFNOC RADIO") + << boost::format("expected: %x result: %x") + % uint32_t(hash) % result + ; return; // exit on any failure } } @@ -146,7 +153,7 @@ void radio_ctrl_impl::_register_loopback_self_test(size_t chan) ***************************************************************************/ double radio_ctrl_impl::set_rate(double rate) { - boost::mutex::scoped_lock lock(_mutex); + std::lock_guard<std::mutex> lock(_mutex); _tick_rate = rate; _time64->set_tick_rate(_tick_rate); _time64->self_test(); @@ -364,41 +371,51 @@ double radio_ctrl_impl::get_tx_lo_freq( * RX Streamer-related methods (from source_block_ctrl_base) **********************************************************************/ //! Pass stream commands to the radio -void radio_ctrl_impl::issue_stream_cmd(const uhd::stream_cmd_t &stream_cmd, const size_t chan) -{ - boost::mutex::scoped_lock lock(_mutex); - UHD_RFNOC_BLOCK_TRACE() << "radio_ctrl_impl::issue_stream_cmd() " << chan << " " << char(stream_cmd.stream_mode) ; +void radio_ctrl_impl::issue_stream_cmd( + const uhd::stream_cmd_t &stream_cmd, + const size_t chan +) { + std::lock_guard<std::mutex> lock(_mutex); + UHD_RFNOC_BLOCK_TRACE() + << "radio_ctrl_impl::issue_stream_cmd() " << chan + << " " << char(stream_cmd.stream_mode) ; if (not _is_streamer_active(uhd::RX_DIRECTION, chan)) { - UHD_RFNOC_BLOCK_TRACE() << "radio_ctrl_impl::issue_stream_cmd() called on inactive channel. Skipping." ; + UHD_RFNOC_BLOCK_TRACE() + << "radio_ctrl_impl::issue_stream_cmd() called on inactive " + "channel. Skipping."; return; } UHD_ASSERT_THROW(stream_cmd.num_samps <= 0x0fffffff); - _continuous_streaming[chan] = (stream_cmd.stream_mode == stream_cmd_t::STREAM_MODE_START_CONTINUOUS); + _continuous_streaming[chan] = + (stream_cmd.stream_mode == stream_cmd_t::STREAM_MODE_START_CONTINUOUS); //setup the mode to instruction flags - typedef boost::tuple<bool, bool, bool, bool> inst_t; - static const uhd::dict<stream_cmd_t::stream_mode_t, inst_t> mode_to_inst = boost::assign::map_list_of + typedef std::tuple<bool, bool, bool, bool> inst_t; + static const std::map<stream_cmd_t::stream_mode_t, inst_t> mode_to_inst{ //reload, chain, samps, stop - (stream_cmd_t::STREAM_MODE_START_CONTINUOUS, inst_t(true, true, false, false)) - (stream_cmd_t::STREAM_MODE_STOP_CONTINUOUS, inst_t(false, false, false, true)) - (stream_cmd_t::STREAM_MODE_NUM_SAMPS_AND_DONE, inst_t(false, false, true, false)) - (stream_cmd_t::STREAM_MODE_NUM_SAMPS_AND_MORE, inst_t(false, true, true, false)) + {stream_cmd_t::STREAM_MODE_START_CONTINUOUS, inst_t(true, true, false, false)}, + {stream_cmd_t::STREAM_MODE_STOP_CONTINUOUS, inst_t(false, false, false, true)}, + {stream_cmd_t::STREAM_MODE_NUM_SAMPS_AND_DONE, inst_t(false, false, true, false)}, + {stream_cmd_t::STREAM_MODE_NUM_SAMPS_AND_MORE, inst_t(false, true, true, false)} + } ; //setup the instruction flag values bool inst_reload, inst_chain, inst_samps, inst_stop; - boost::tie(inst_reload, inst_chain, inst_samps, inst_stop) = mode_to_inst[stream_cmd.stream_mode]; + std::tie(inst_reload, inst_chain, inst_samps, inst_stop) = + mode_to_inst.at(stream_cmd.stream_mode); //calculate the word from flags and length - uint32_t cmd_word = 0; - cmd_word |= uint32_t((stream_cmd.stream_now)? 1 : 0) << 31; - cmd_word |= uint32_t((inst_chain)? 1 : 0) << 30; - cmd_word |= uint32_t((inst_reload)? 1 : 0) << 29; - cmd_word |= uint32_t((inst_stop)? 1 : 0) << 28; - cmd_word |= (inst_samps)? stream_cmd.num_samps : ((inst_stop)? 0 : 1); + const uint32_t cmd_word = 0 + | uint32_t((stream_cmd.stream_now)? 1 : 0) << 31 + | uint32_t((inst_chain)? 1 : 0) << 30 + | uint32_t((inst_reload)? 1 : 0) << 29 + | uint32_t((inst_stop)? 1 : 0) << 28 + | (inst_samps) ? stream_cmd.num_samps : ((inst_stop)? 0 : 1); //issue the stream command - const uint64_t ticks = (stream_cmd.stream_now)? 0 : stream_cmd.time_spec.to_ticks(get_rate()); + const uint64_t ticks = + (stream_cmd.stream_now)? 0 : stream_cmd.time_spec.to_ticks(get_rate()); sr_write(regs::RX_CTRL_CMD, cmd_word, chan); sr_write(regs::RX_CTRL_TIME_HI, uint32_t(ticks >> 32), chan); sr_write(regs::RX_CTRL_TIME_LO, uint32_t(ticks >> 0), chan); //latches the command @@ -459,7 +476,7 @@ void radio_ctrl_impl::set_tx_streamer(bool active, const size_t port) // TODO move to nocscript void radio_ctrl_impl::_update_spp(int spp) { - boost::mutex::scoped_lock lock(_mutex); + std::lock_guard<std::mutex> lock(_mutex); UHD_RFNOC_BLOCK_TRACE() << "radio_ctrl_impl::_update_spp(): Requested spp: " << spp ; if (spp == 0) { spp = DEFAULT_PACKET_SIZE / BYTES_PER_SAMPLE; diff --git a/host/lib/rfnoc/radio_ctrl_impl.hpp b/host/lib/rfnoc/radio_ctrl_impl.hpp index 85ae860d4..953807407 100644 --- a/host/lib/rfnoc/radio_ctrl_impl.hpp +++ b/host/lib/rfnoc/radio_ctrl_impl.hpp @@ -14,6 +14,7 @@ #include <uhd/rfnoc/radio_ctrl.hpp> #include <uhd/types/direction.hpp> #include <boost/thread.hpp> +#include <mutex> //! Shorthand for radio block constructor #define UHD_RFNOC_RADIO_BLOCK_CONSTRUCTOR_DECL(CLASS_NAME) \ @@ -209,7 +210,7 @@ protected: // TODO see what's protected and what's private //! There is always only one time core per radio time_core_3000::sptr _time64; - boost::mutex _mutex; + std::mutex _mutex; private: /************************************************************************ |