aboutsummaryrefslogtreecommitdiffstats
path: root/host/examples/benchmark_rate.cpp
diff options
context:
space:
mode:
authorAndrew Lynch <andrew.lynch@ni.com>2021-11-08 17:03:46 -0600
committerAaron Rossetto <aaron.rossetto@ni.com>2022-01-10 14:57:30 -0600
commit5d80e28752d2b6f202480ce591f142f5e6f90139 (patch)
treed8d43b72ece068fd03dc50cf56dfb252dc7448dd /host/examples/benchmark_rate.cpp
parent3e5e4eb06c0ea6337464cbda0648a75bf76cca17 (diff)
downloaduhd-5d80e28752d2b6f202480ce591f142f5e6f90139.tar.gz
uhd-5d80e28752d2b6f202480ce591f142f5e6f90139.tar.bz2
uhd-5d80e28752d2b6f202480ce591f142f5e6f90139.zip
examples: support multiple streamers in benchmark_rate
Diffstat (limited to 'host/examples/benchmark_rate.cpp')
-rw-r--r--host/examples/benchmark_rate.cpp146
1 files changed, 103 insertions, 43 deletions
diff --git a/host/examples/benchmark_rate.cpp b/host/examples/benchmark_rate.cpp
index d975c4c0c..e61888bbf 100644
--- a/host/examples/benchmark_rate.cpp
+++ b/host/examples/benchmark_rate.cpp
@@ -378,6 +378,7 @@ int UHD_SAFE_MAIN(int argc, char* argv[])
("tx_delay", po::value<double>(&tx_delay)->default_value(0.25), "delay before starting TX in seconds")
("rx_delay", po::value<double>(&rx_delay)->default_value(0.05), "delay before starting RX in seconds")
("priority", po::value<std::string>(&priority)->default_value("normal"), "thread priority (normal, high)")
+ ("multi_streamer", "Create a separate streamer per channel")
;
// clang-format on
po::variables_map vm;
@@ -540,54 +541,113 @@ int UHD_SAFE_MAIN(int argc, char* argv[])
std::cout << boost::format("Setting RX spp to %u\n") % rx_spp;
usrp->set_rx_spp(rx_spp);
}
- // create a receive streamer
- uhd::stream_args_t stream_args(rx_cpu, rx_otw);
- stream_args.channels = rx_channel_nums;
- stream_args.args = uhd::device_addr_t(rx_stream_args);
- uhd::rx_streamer::sptr rx_stream = usrp->get_rx_stream(stream_args);
- auto rx_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
- benchmark_rx_rate(usrp,
- rx_cpu,
- rx_stream,
- random_nsamps,
- start_time,
- burst_timer_elapsed,
- elevate_priority,
- rx_delay);
- });
- uhd::set_thread_name(rx_thread, "bmark_rx_stream");
+ if (vm.count("multi_streamer")) {
+ for (size_t count = 0; count < rx_channel_nums.size(); count++) {
+ std::vector<size_t> this_streamer_channels{rx_channel_nums[count]};
+ // create a receive streamer
+ uhd::stream_args_t stream_args(rx_cpu, rx_otw);
+ stream_args.channels = this_streamer_channels;
+ stream_args.args = uhd::device_addr_t(rx_stream_args);
+ uhd::rx_streamer::sptr rx_stream = usrp->get_rx_stream(stream_args);
+ auto rx_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
+ benchmark_rx_rate(usrp,
+ rx_cpu,
+ rx_stream,
+ random_nsamps,
+ start_time,
+ burst_timer_elapsed,
+ elevate_priority,
+ rx_delay);
+ });
+ uhd::set_thread_name(rx_thread, "bmark_rx_strm" + std::to_string(count));
+ }
+ }
+ else {
+ // create a receive streamer
+ uhd::stream_args_t stream_args(rx_cpu, rx_otw);
+ stream_args.channels = rx_channel_nums;
+ stream_args.args = uhd::device_addr_t(rx_stream_args);
+ uhd::rx_streamer::sptr rx_stream = usrp->get_rx_stream(stream_args);
+ auto rx_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
+ benchmark_rx_rate(usrp,
+ rx_cpu,
+ rx_stream,
+ random_nsamps,
+ start_time,
+ burst_timer_elapsed,
+ elevate_priority,
+ rx_delay);
+ });
+ uhd::set_thread_name(rx_thread, "bmark_rx_stream");
+ }
}
// spawn the transmit test thread
if (vm.count("tx_rate")) {
usrp->set_tx_rate(tx_rate);
- // create a transmit streamer
- uhd::stream_args_t stream_args(tx_cpu, tx_otw);
- stream_args.channels = tx_channel_nums;
- stream_args.args = uhd::device_addr_t(tx_stream_args);
- uhd::tx_streamer::sptr tx_stream = usrp->get_tx_stream(stream_args);
- const size_t max_spp = tx_stream->get_max_num_samps();
- size_t spp = max_spp;
- if (vm.count("tx_spp")) {
- spp = std::min(spp, tx_spp);
- }
- std::cout << boost::format("Setting TX spp to %u\n") % spp;
- auto tx_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
- benchmark_tx_rate(usrp,
- tx_cpu,
- tx_stream,
- burst_timer_elapsed,
- start_time,
- spp,
- elevate_priority,
- tx_delay,
- random_nsamps);
- });
- uhd::set_thread_name(tx_thread, "bmark_tx_stream");
- auto tx_async_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
- benchmark_tx_rate_async_helper(tx_stream, start_time, burst_timer_elapsed);
- });
- uhd::set_thread_name(tx_async_thread, "bmark_tx_helper");
+
+ if (vm.count("multi_streamer")) {
+ for (size_t count = 0; count < tx_channel_nums.size(); count++) {
+ std::vector<size_t> this_streamer_channels{tx_channel_nums[count]};
+
+ // create a transmit streamer
+ uhd::stream_args_t stream_args(tx_cpu, tx_otw);
+ stream_args.channels = this_streamer_channels;
+ stream_args.args = uhd::device_addr_t(tx_stream_args);
+ uhd::tx_streamer::sptr tx_stream = usrp->get_tx_stream(stream_args);
+ const size_t max_spp = tx_stream->get_max_num_samps();
+ size_t spp = max_spp;
+ if (vm.count("tx_spp")) {
+ spp = std::min(spp, tx_spp);
+ }
+ std::cout << boost::format("Setting TX spp to %u\n") % spp;
+ auto tx_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
+ benchmark_tx_rate(usrp,
+ tx_cpu,
+ tx_stream,
+ burst_timer_elapsed,
+ start_time,
+ spp,
+ elevate_priority,
+ tx_delay,
+ random_nsamps);
+ });
+ uhd::set_thread_name(tx_thread, "bmark_tx_strm" + std::to_string(count));
+ auto tx_async_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
+ benchmark_tx_rate_async_helper(tx_stream, start_time, burst_timer_elapsed);
+ });
+ uhd::set_thread_name(tx_async_thread, "bmark_tx_hlpr" + std::to_string(count));
+ }
+ }
+ else {
+ // create a transmit streamer
+ uhd::stream_args_t stream_args(tx_cpu, tx_otw);
+ stream_args.channels = tx_channel_nums;
+ stream_args.args = uhd::device_addr_t(tx_stream_args);
+ uhd::tx_streamer::sptr tx_stream = usrp->get_tx_stream(stream_args);
+ const size_t max_spp = tx_stream->get_max_num_samps();
+ size_t spp = max_spp;
+ if (vm.count("tx_spp")) {
+ spp = std::min(spp, tx_spp);
+ }
+ std::cout << boost::format("Setting TX spp to %u\n") % spp;
+ auto tx_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
+ benchmark_tx_rate(usrp,
+ tx_cpu,
+ tx_stream,
+ burst_timer_elapsed,
+ start_time,
+ spp,
+ elevate_priority,
+ tx_delay,
+ random_nsamps);
+ });
+ uhd::set_thread_name(tx_thread, "bmark_tx_stream");
+ auto tx_async_thread = thread_group.create_thread([=, &burst_timer_elapsed]() {
+ benchmark_tx_rate_async_helper(tx_stream, start_time, burst_timer_elapsed);
+ });
+ uhd::set_thread_name(tx_async_thread, "bmark_tx_helper");
+ }
}
// sleep for the required duration (add any initial delay)