From 1c79742231c5cc3609e35bda34c8d9b9e7440f50 Mon Sep 17 00:00:00 2001 From: Ciro Nishiguchi Date: Tue, 6 Aug 2019 14:44:51 -0500 Subject: utils: remove thread priority elevation Remove UHD call to elevate thread priority to realtime from utils, and add warning in documentation of set_thread_priority function. Setting all threads to the same realtime priority can cause the threads to not share access to the network interface fairly, which adversely affects operation of the worker threads in UHD. --- host/include/uhd/utils/thread.hpp | 6 ++++-- host/tests/packet_handler_benchmark.cpp | 2 -- host/utils/query_gpsdo_sensors.cpp | 2 -- host/utils/uhd_cal_rx_iq_balance.cpp | 2 -- host/utils/uhd_cal_tx_dc_offset.cpp | 2 -- host/utils/uhd_cal_tx_iq_balance.cpp | 2 -- 6 files changed, 4 insertions(+), 12 deletions(-) (limited to 'host') diff --git a/host/include/uhd/utils/thread.hpp b/host/include/uhd/utils/thread.hpp index aeb27e467..9f71161d0 100644 --- a/host/include/uhd/utils/thread.hpp +++ b/host/include/uhd/utils/thread.hpp @@ -20,8 +20,10 @@ static const float default_thread_priority = float(0.5); /*! * Set the scheduling priority on the current thread. * - * A new thread or calling process should make this call - * with the defaults this to enable realtime scheduling. + * To enable realtime scheduling on a new thread, call this function with + * the default values. Warning: realtime scheduling can cause UHD worker + * threads to not share resources such as network interfaces fairly, + * potentially causing it to malfunction. * * A priority of zero corresponds to normal priority. * Positive priority values are higher than normal. diff --git a/host/tests/packet_handler_benchmark.cpp b/host/tests/packet_handler_benchmark.cpp index 21e1430ae..ec7eff517 100644 --- a/host/tests/packet_handler_benchmark.cpp +++ b/host/tests/packet_handler_benchmark.cpp @@ -319,8 +319,6 @@ int UHD_SAFE_MAIN(int argc, char* argv[]) return EXIT_FAILURE; } - uhd::set_thread_priority_safe(); - const char* formats[] = {"sc16", "fc32", "fc64"}; constexpr size_t rx_spp = 2000; constexpr size_t tx_spp = 1000; diff --git a/host/utils/query_gpsdo_sensors.cpp b/host/utils/query_gpsdo_sensors.cpp index ecc0048a7..99fbd1d03 100644 --- a/host/utils/query_gpsdo_sensors.cpp +++ b/host/utils/query_gpsdo_sensors.cpp @@ -82,8 +82,6 @@ int query_clock_sensors(const std::string& args) int UHD_SAFE_MAIN(int argc, char* argv[]) { - uhd::set_thread_priority_safe(); - std::string args; // Set up program options diff --git a/host/utils/uhd_cal_rx_iq_balance.cpp b/host/utils/uhd_cal_rx_iq_balance.cpp index c68c96173..1d8bdf6ee 100644 --- a/host/utils/uhd_cal_rx_iq_balance.cpp +++ b/host/utils/uhd_cal_rx_iq_balance.cpp @@ -32,8 +32,6 @@ static void tx_thread(uhd::usrp::multi_usrp::sptr usrp, uhd::tx_streamer::sptr tx_stream, const double tx_wave_ampl) { - uhd::set_thread_priority_safe(); - // set max TX gain usrp->set_tx_gain(usrp->get_tx_gain_range().stop()); diff --git a/host/utils/uhd_cal_tx_dc_offset.cpp b/host/utils/uhd_cal_tx_dc_offset.cpp index f47b5e913..4ae305696 100644 --- a/host/utils/uhd_cal_tx_dc_offset.cpp +++ b/host/utils/uhd_cal_tx_dc_offset.cpp @@ -31,8 +31,6 @@ static void tx_thread(uhd::usrp::multi_usrp::sptr usrp, const double tx_wave_freq, const double tx_wave_ampl) { - uhd::set_thread_priority_safe(); - // set max TX gain usrp->set_tx_gain(usrp->get_tx_gain_range().stop()); diff --git a/host/utils/uhd_cal_tx_iq_balance.cpp b/host/utils/uhd_cal_tx_iq_balance.cpp index 2e7229fd3..233f23862 100644 --- a/host/utils/uhd_cal_tx_iq_balance.cpp +++ b/host/utils/uhd_cal_tx_iq_balance.cpp @@ -28,8 +28,6 @@ static void tx_thread(uhd::usrp::multi_usrp::sptr usrp, const double tx_wave_freq, const double tx_wave_ampl) { - uhd::set_thread_priority_safe(); - // set max TX gain usrp->set_tx_gain(usrp->get_tx_gain_range().stop()); -- cgit v1.2.3