From 52f1c15cfc99fda3dfd1d249d37b5a99b06eac95 Mon Sep 17 00:00:00 2001 From: Martin Braun Date: Thu, 26 Mar 2020 12:01:04 -0700 Subject: multi_usrp: Fix ALL_CHAN and ALL_MBOARDS API calls for Gen-3 devices Most of the API calls that default an arg to ALL_CHANS or ALL_MBOARDS were in fact broken. This adds a macro to efficiently mux out API calls that take such wildcard arguments so we don't have to repeat the same loop all over the place, even for those API calls that already correctly implemented wildcards (for consistency). --- host/lib/usrp/multi_usrp_rfnoc.cpp | 169 ++++++++++++++----------------------- 1 file changed, 64 insertions(+), 105 deletions(-) (limited to 'host/lib') diff --git a/host/lib/usrp/multi_usrp_rfnoc.cpp b/host/lib/usrp/multi_usrp_rfnoc.cpp index 9a3169e38..11d5f28d1 100644 --- a/host/lib/usrp/multi_usrp_rfnoc.cpp +++ b/host/lib/usrp/multi_usrp_rfnoc.cpp @@ -31,6 +31,26 @@ using namespace uhd; using namespace uhd::usrp; using namespace uhd::rfnoc; +//! Fan out (mux) an API call that is for all channels or all motherboards +#define MUX_API_CALL(max_index, api_call, mux_var, mux_cond, ...) \ + if (mux_var == mux_cond) { \ + for (size_t __index = 0; __index < max_index; ++__index) { \ + api_call(__VA_ARGS__, __index); \ + } \ + return; \ + } + +//! Fan out (mux) an RX-specific API call that is for all channels +#define MUX_RX_API_CALL(api_call, ...) \ + MUX_API_CALL(get_rx_num_channels(), api_call, chan, ALL_CHANS, __VA_ARGS__) +//! Fan out (mux) an TX-specific API call that is for all channels +#define MUX_TX_API_CALL(api_call, ...) \ + MUX_API_CALL(get_tx_num_channels(), api_call, chan, ALL_CHANS, __VA_ARGS__) +//! Fan out (mux) a motherboard-specific API call that is for all boards +#define MUX_MB_API_CALL(api_call, ...) \ + MUX_API_CALL(get_num_mboards(), api_call, mboard, ALL_MBOARDS, __VA_ARGS__) + + namespace { constexpr char DEFAULT_CPU_FORMAT[] = "fc32"; constexpr char DEFAULT_OTW_FORMAT[] = "sc16"; @@ -526,7 +546,7 @@ public: /******************************************************************* * Mboard methods ******************************************************************/ - void set_master_clock_rate(double rate, size_t mboard = ALL_MBOARDS) + void set_master_clock_rate(double rate, size_t mboard) { for (auto& chain : _rx_chans) { auto radio = chain.second.radio; @@ -636,25 +656,15 @@ public: return get_mbc(mboard)->get_timekeeper(0)->get_time_last_pps(); } - void set_time_now(const time_spec_t& time_spec, size_t mboard = ALL_MBOARDS) + void set_time_now(const time_spec_t& time_spec, size_t mboard) { - if (mboard == ALL_MBOARDS) { - for (size_t i = 0; i < get_num_mboards(); ++i) { - set_time_now(time_spec, i); - } - return; - } + MUX_MB_API_CALL(set_time_now, time_spec); get_mbc(mboard)->get_timekeeper(0)->set_time_now(time_spec); } - void set_time_next_pps(const time_spec_t& time_spec, size_t mboard = ALL_MBOARDS) + void set_time_next_pps(const time_spec_t& time_spec, size_t mboard) { - if (mboard == ALL_MBOARDS) { - for (size_t i = 0; i < get_num_mboards(); ++i) { - set_time_next_pps(time_spec, i); - } - return; - } + MUX_MB_API_CALL(set_time_next_pps, time_spec); get_mbc(mboard)->get_timekeeper(0)->set_time_next_pps(time_spec); } @@ -704,14 +714,9 @@ public: return true; } - void set_command_time(const uhd::time_spec_t& time_spec, size_t mboard = ALL_MBOARDS) + void set_command_time(const uhd::time_spec_t& time_spec, size_t mboard) { - if (mboard == ALL_MBOARDS) { - for (size_t i = 0; i < get_num_mboards(); ++i) { - set_command_time(time_spec, i); - } - return; - } + MUX_MB_API_CALL(set_command_time, time_spec); // Set command time on all the blocks that are connected for (auto& chain : _rx_chans) { @@ -728,7 +733,7 @@ public: } } - void clear_command_time(size_t mboard = ALL_MBOARDS) + void clear_command_time(size_t mboard) { if (mboard == ALL_MBOARDS) { for (size_t i = 0; i < get_num_mboards(); ++i) { @@ -768,14 +773,9 @@ public: } } - void set_time_source(const std::string& source, const size_t mboard = ALL_MBOARDS) + void set_time_source(const std::string& source, const size_t mboard) { - if (mboard == ALL_MBOARDS) { - for (size_t i = 0; i < get_num_mboards(); ++i) { - set_time_source(source, i); - } - return; - } + MUX_MB_API_CALL(set_time_source, source); get_mbc(mboard)->set_time_source(source); } @@ -789,14 +789,9 @@ public: return get_mbc(mboard)->get_time_sources(); } - void set_clock_source(const std::string& source, const size_t mboard = ALL_MBOARDS) + void set_clock_source(const std::string& source, const size_t mboard) { - if (mboard == ALL_MBOARDS) { - for (size_t i = 0; i < get_num_mboards(); ++i) { - set_clock_source(source, i); - } - return; - } + MUX_MB_API_CALL(set_clock_source, source); get_mbc(mboard)->set_clock_source(source); } @@ -812,26 +807,15 @@ public: void set_sync_source(const std::string& clock_source, const std::string& time_source, - const size_t mboard = ALL_MBOARDS) + const size_t mboard) { - if (mboard == ALL_MBOARDS) { - for (size_t i = 0; i < get_num_mboards(); ++i) { - set_sync_source(clock_source, time_source, i); - } - return; - } + MUX_MB_API_CALL(set_sync_source, clock_source, time_source); get_mbc(mboard)->set_sync_source(clock_source, time_source); } - void set_sync_source( - const device_addr_t& sync_source, const size_t mboard = ALL_MBOARDS) + void set_sync_source(const device_addr_t& sync_source, const size_t mboard) { - if (mboard == ALL_MBOARDS) { - for (size_t i = 0; i < get_num_mboards(); ++i) { - set_sync_source(sync_source, i); - } - return; - } + MUX_MB_API_CALL(set_sync_source, sync_source); get_mbc(mboard)->set_sync_source(sync_source); } @@ -845,13 +829,15 @@ public: return get_mbc(mboard)->get_sync_sources(); } - void set_clock_source_out(const bool enb, const size_t mboard = ALL_MBOARDS) + void set_clock_source_out(const bool enb, const size_t mboard) { + MUX_MB_API_CALL(set_clock_source_out, enb); get_mbc(mboard)->set_clock_source_out(enb); } - void set_time_source_out(const bool enb, const size_t mboard = ALL_MBOARDS) + void set_time_source_out(const bool enb, const size_t mboard) { + MUX_MB_API_CALL(set_time_source_out, enb); get_mbc(mboard)->set_time_source_out(enb); } @@ -982,7 +968,7 @@ public: } void set_rx_subdev_spec( - const uhd::usrp::subdev_spec_t& spec, size_t mboard = ALL_MBOARDS) + const uhd::usrp::subdev_spec_t& spec, size_t mboard) { // First, generate a vector of the RX channels that we need to register auto new_rx_chans = [this, spec, mboard]() { @@ -1048,15 +1034,10 @@ public: return rx_chain.radio->get_fe_name(rx_chain.block_chan, uhd::RX_DIRECTION); } - void set_rx_rate(double rate, size_t chan = ALL_CHANS) + void set_rx_rate(double rate, size_t chan) { std::lock_guard l(_graph_mutex); - if (chan == ALL_CHANS) { - for (size_t chan = 0; chan < _rx_chans.size(); ++chan) { - set_rx_rate(rate, chan); - } - return; - } + MUX_RX_API_CALL(set_rx_rate, rate); const double actual_rate = [&]() { auto rx_chain = _get_rx_chan(chan); if (rx_chain.ddc) { @@ -1077,12 +1058,7 @@ public: void set_rx_spp(const size_t spp, const size_t chan = ALL_CHANS) { std::lock_guard l(_graph_mutex); - if (chan == ALL_CHANS) { - for (size_t chan = 0; chan < _rx_chans.size(); ++chan) { - set_rx_spp(spp, chan); - } - return; - } + MUX_RX_API_CALL(set_rx_spp, spp); auto rx_chain = _get_rx_chan(chan); rx_chain.radio->set_property( "spp", narrow_cast(spp), rx_chain.block_chan); @@ -1112,6 +1088,7 @@ public: tune_result_t set_rx_freq(const tune_request_t& tune_request, size_t chan) { std::lock_guard l(_graph_mutex); + // TODO: Add external LO warning auto rx_chain = _get_rx_chan(chan); @@ -1436,28 +1413,18 @@ public: return rx_chain.radio->get_rx_sensor_names(rx_chain.block_chan); } - void set_rx_dc_offset(const bool enb, size_t chan = ALL_CHANS) + void set_rx_dc_offset(const bool enb, size_t chan) { - if (chan != ALL_CHANS) { - auto rx_chain = _get_rx_chan(chan); - rx_chain.radio->set_rx_dc_offset(enb, rx_chain.block_chan); - return; - } - for (size_t ch = 0; ch < get_rx_num_channels(); ++ch) { - set_rx_dc_offset(enb, ch); - } + MUX_RX_API_CALL(set_rx_dc_offset, enb); + const auto rx_chain = _get_rx_chan(chan); + rx_chain.radio->set_rx_dc_offset(enb, rx_chain.block_chan); } - void set_rx_dc_offset(const std::complex& offset, size_t chan = ALL_CHANS) + void set_rx_dc_offset(const std::complex& offset, size_t chan) { - if (chan != ALL_CHANS) { - auto rx_chain = _get_rx_chan(chan); - rx_chain.radio->set_rx_dc_offset(offset, rx_chain.block_chan); - return; - } - for (size_t ch = 0; ch < get_rx_num_channels(); ++ch) { - set_rx_dc_offset(offset, ch); - } + MUX_RX_API_CALL(set_rx_dc_offset, offset); + const auto rx_chain = _get_rx_chan(chan); + rx_chain.radio->set_rx_dc_offset(offset, rx_chain.block_chan); } meta_range_t get_rx_dc_offset_range(size_t chan) @@ -1479,16 +1446,11 @@ public: } void set_rx_iq_balance( - const std::complex& correction, size_t chan = ALL_CHANS) + const std::complex& correction, size_t chan) { - if (chan != ALL_CHANS) { - auto rx_chain = _get_rx_chan(chan); - rx_chain.radio->set_rx_iq_balance(correction, rx_chain.block_chan); - return; - } - for (size_t ch = 0; ch < get_rx_num_channels(); ++ch) { - set_rx_iq_balance(correction, ch); - } + MUX_RX_API_CALL(set_rx_iq_balance, correction); + const auto rx_chain = _get_rx_chan(chan); + rx_chain.radio->set_rx_iq_balance(correction, rx_chain.block_chan); } /******************************************************************* @@ -1591,7 +1553,7 @@ public: } void set_tx_subdev_spec( - const uhd::usrp::subdev_spec_t& spec, size_t mboard = ALL_MBOARDS) + const uhd::usrp::subdev_spec_t& spec, size_t mboard) { /* TODO: Refactor with get_rx_subdev_spec- the algorithms are the same, just the * types are different @@ -1660,15 +1622,10 @@ public: return tx_chain.radio->get_fe_name(tx_chain.block_chan, uhd::TX_DIRECTION); } - void set_tx_rate(double rate, size_t chan = ALL_CHANS) + void set_tx_rate(double rate, size_t chan) { std::lock_guard l(_graph_mutex); - if (chan == ALL_CHANS) { - for (size_t chan = 0; chan < _tx_chans.size(); ++chan) { - set_tx_rate(rate, chan); - } - return; - } + MUX_TX_API_CALL(set_tx_rate, rate); const double actual_rate = [&]() { auto tx_chain = _get_tx_chan(chan); if (tx_chain.duc) { @@ -1899,7 +1856,8 @@ public: void set_tx_dc_offset(const std::complex& offset, size_t chan) { - auto tx_chain = _get_tx_chan(chan); + MUX_TX_API_CALL(set_tx_dc_offset, offset); + const auto tx_chain = _get_tx_chan(chan); tx_chain.radio->set_tx_dc_offset(offset, tx_chain.block_chan); } @@ -1911,7 +1869,8 @@ public: void set_tx_iq_balance(const std::complex& correction, size_t chan) { - auto tx_chain = _get_tx_chan(chan); + MUX_TX_API_CALL(set_tx_iq_balance, correction); + const auto tx_chain = _get_tx_chan(chan); tx_chain.radio->set_tx_iq_balance(correction, tx_chain.block_chan); } -- cgit v1.2.3