diff options
author | Martin Braun <martin.braun@ettus.com> | 2019-11-05 10:10:33 -0800 |
---|---|---|
committer | Martin Braun <martin.braun@ettus.com> | 2019-11-26 12:21:33 -0800 |
commit | 2d110b1deda68351fdfbf6a8b7cc0c62897d57bc (patch) | |
tree | 46ba06a37a207faab5a9d7eb102d585a7e26084e /host/lib/usrp/multi_usrp_rfnoc.cpp | |
parent | b7488af14e6bf23eb52b815d30c3f37836834387 (diff) | |
download | uhd-2d110b1deda68351fdfbf6a8b7cc0c62897d57bc.tar.gz uhd-2d110b1deda68351fdfbf6a8b7cc0c62897d57bc.tar.bz2 uhd-2d110b1deda68351fdfbf6a8b7cc0c62897d57bc.zip |
rfnoc_graph: Modify find_blocks() to sort return value
With this patch, the elements of of the return value of find_blocks()
are sorted lexicographically (specifically, using
uhd::rfnoc::block_id_it::operator<()).
The underlying block_container class stores the blocks in an unordered
set, so the return value for find_blocks() was always sorted randomly.
multi_usrp_rfnoc had to sort the return values every time find_blocks()
was used to get a useful return value.
Because find_blocks() had no contract for the order of returned blocks,
this change simply sorts the return value before returning it.
multi_usrp_rfnoc is modified to remove all the sorts that are now
superfluous.
A good way to see the change is to run uhd_usrp_probe, which will now
contain content like this:
| _____________________________________________________
| /
| | RFNoC blocks on this device:
| |
| | * 0/DDC#0
| | * 0/DDC#1
| | * 0/DUC#0
| | * 0/DUC#1
| | * 0/DmaFIFO#0
| | * 0/Radio#0
| | * 0/Radio#1
Assuming the blocks don't change, the order of this list will always be
the same following this patch. Note that the order is unrelated to the
order on the control crossbar, which it never was.
Diffstat (limited to 'host/lib/usrp/multi_usrp_rfnoc.cpp')
-rw-r--r-- | host/lib/usrp/multi_usrp_rfnoc.cpp | 37 |
1 files changed, 2 insertions, 35 deletions
diff --git a/host/lib/usrp/multi_usrp_rfnoc.cpp b/host/lib/usrp/multi_usrp_rfnoc.cpp index 5242da965..99c07dc8c 100644 --- a/host/lib/usrp/multi_usrp_rfnoc.cpp +++ b/host/lib/usrp/multi_usrp_rfnoc.cpp @@ -96,20 +96,9 @@ public: multi_usrp_rfnoc(rfnoc_graph::sptr graph, const device_addr_t& addr) : _args(addr), _graph(graph), _tree(_graph->get_tree()) { - // Discover all of the radios on our devices and create a mapping between radio - // chains and channel numbers + // Discover all of the radios on our devices and create a mapping between + // radio chains and channel numbers. The result is sorted. auto radio_blk_ids = _graph->find_blocks("Radio"); - // find_blocks doesn't sort, so we need to - std::sort(radio_blk_ids.begin(), - radio_blk_ids.end(), - [](uhd::rfnoc::block_id_t i, uhd::rfnoc::block_id_t j) -> bool { - if (i.get_device_no() != j.get_device_no()) { - return i.get_device_no() < j.get_device_no(); - } else { - return i.get_block_count() < j.get_block_count(); - } - }); - // If we don't find any radios, we don't have a multi_usrp object if (radio_blk_ids.empty()) { throw uhd::runtime_error( @@ -895,17 +884,6 @@ public: // Discover all of the radios on our devices and create a mapping between radio // chains and channel numbers auto radio_blk_ids = _graph->find_blocks(std::to_string(mboard) + "/Radio"); - // find_blocks doesn't sort, so we need to - std::sort(radio_blk_ids.begin(), - radio_blk_ids.end(), - [](uhd::rfnoc::block_id_t i, uhd::rfnoc::block_id_t j) -> bool { - if (i.get_device_no() != j.get_device_no()) { - return i.get_device_no() < j.get_device_no(); - } else { - return i.get_block_count() < j.get_block_count(); - } - }); - // If we don't find any radios, we don't have a multi_usrp object if (radio_blk_ids.empty()) { throw uhd::runtime_error( @@ -1515,17 +1493,6 @@ public: // Discover all of the radios on our devices and create a mapping between radio // chains and channel numbers auto radio_blk_ids = _graph->find_blocks(std::to_string(mboard) + "/Radio"); - // find_blocks doesn't sort, so we need to - std::sort(radio_blk_ids.begin(), - radio_blk_ids.end(), - [](uhd::rfnoc::block_id_t i, uhd::rfnoc::block_id_t j) -> bool { - if (i.get_device_no() != j.get_device_no()) { - return i.get_device_no() < j.get_device_no(); - } else { - return i.get_block_count() < j.get_block_count(); - } - }); - // If we don't find any radios, we don't have a multi_usrp object if (radio_blk_ids.empty()) { throw uhd::runtime_error( |