rf_uhd_imp: fix race in RF metrics

master
Andre Puschmann 4 years ago
parent 132f2aa605
commit ff5fe5df14

@ -90,6 +90,7 @@ private:
std::vector<srsran_rf_info_t> rf_info = {}; std::vector<srsran_rf_info_t> rf_info = {};
std::vector<int32_t> rx_offset_n = {}; std::vector<int32_t> rx_offset_n = {};
rf_metrics_t rf_metrics = {}; rf_metrics_t rf_metrics = {};
std::mutex metrics_mutex;
srslog::basic_logger& logger = srslog::fetch_basic_logger("RF", false); srslog::basic_logger& logger = srslog::fetch_basic_logger("RF", false);
phy_interface_radio* phy = nullptr; phy_interface_radio* phy = nullptr;
cf_t* zeros = nullptr; cf_t* zeros = nullptr;

@ -174,13 +174,13 @@ int srsran_rf_open_multi(srsran_rf_t* h, char* args, uint32_t nof_channels)
int srsran_rf_close(srsran_rf_t* rf) int srsran_rf_close(srsran_rf_t* rf)
{ {
// Stop gain thread // Stop gain thread
if (rf->thread_gain_run) {
pthread_mutex_lock(&rf->mutex); pthread_mutex_lock(&rf->mutex);
if (rf->thread_gain_run) {
rf->thread_gain_run = false; rf->thread_gain_run = false;
}
pthread_mutex_unlock(&rf->mutex); pthread_mutex_unlock(&rf->mutex);
pthread_cond_signal(&rf->cond); pthread_cond_signal(&rf->cond);
pthread_join(rf->thread_gain, NULL); pthread_join(rf->thread_gain, NULL);
}
return ((rf_dev_t*)rf->dev)->srsran_rf_close(rf->handler); return ((rf_dev_t*)rf->dev)->srsran_rf_close(rf->handler);
} }

@ -194,6 +194,7 @@ static std::array<cf_t, 64 * 1024> dummy_mem = {}; // For receiving
static void log_overflow(rf_uhd_handler_t* h) static void log_overflow(rf_uhd_handler_t* h)
{ {
std::unique_lock<std::mutex> lock(h->tx_mutex);
if (h->tx_state == RF_UHD_IMP_TX_STATE_BURST) { if (h->tx_state == RF_UHD_IMP_TX_STATE_BURST) {
h->tx_state = RF_UHD_IMP_TX_STATE_END_OF_BURST; h->tx_state = RF_UHD_IMP_TX_STATE_END_OF_BURST;
} }
@ -208,6 +209,7 @@ static void log_overflow(rf_uhd_handler_t* h)
static void log_late(rf_uhd_handler_t* h, bool is_rx) static void log_late(rf_uhd_handler_t* h, bool is_rx)
{ {
std::unique_lock<std::mutex> lock(h->tx_mutex);
if (h->tx_state == RF_UHD_IMP_TX_STATE_BURST) { if (h->tx_state == RF_UHD_IMP_TX_STATE_BURST) {
h->tx_state = RF_UHD_IMP_TX_STATE_END_OF_BURST; h->tx_state = RF_UHD_IMP_TX_STATE_END_OF_BURST;
} }

@ -979,6 +979,7 @@ srsran_rf_info_t* radio::get_info()
bool radio::get_metrics(rf_metrics_t* metrics) bool radio::get_metrics(rf_metrics_t* metrics)
{ {
std::lock_guard<std::mutex> lock(metrics_mutex);
*metrics = rf_metrics; *metrics = rf_metrics;
rf_metrics = {}; rf_metrics = {};
return true; return true;
@ -990,8 +991,11 @@ void radio::handle_rf_msg(srsran_rf_error_t error)
return; return;
} }
if (error.type == srsran_rf_error_t::SRSRAN_RF_ERROR_OVERFLOW) { if (error.type == srsran_rf_error_t::SRSRAN_RF_ERROR_OVERFLOW) {
{
std::lock_guard<std::mutex> lock(metrics_mutex);
rf_metrics.rf_o++; rf_metrics.rf_o++;
rf_metrics.rf_error = true; rf_metrics.rf_error = true;
}
logger.info("Overflow"); logger.info("Overflow");
// inform PHY about overflow // inform PHY about overflow
@ -999,13 +1003,15 @@ void radio::handle_rf_msg(srsran_rf_error_t error)
phy->radio_overflow(); phy->radio_overflow();
} }
} else if (error.type == srsran_rf_error_t::SRSRAN_RF_ERROR_UNDERFLOW) { } else if (error.type == srsran_rf_error_t::SRSRAN_RF_ERROR_UNDERFLOW) {
logger.info("Underflow");
std::lock_guard<std::mutex> lock(metrics_mutex);
rf_metrics.rf_u++; rf_metrics.rf_u++;
rf_metrics.rf_error = true; rf_metrics.rf_error = true;
logger.info("Underflow");
} else if (error.type == srsran_rf_error_t::SRSRAN_RF_ERROR_LATE) { } else if (error.type == srsran_rf_error_t::SRSRAN_RF_ERROR_LATE) {
logger.info("Late (detected in %s)", error.opt ? "rx call" : "asynchronous thread");
std::lock_guard<std::mutex> lock(metrics_mutex);
rf_metrics.rf_l++; rf_metrics.rf_l++;
rf_metrics.rf_error = true; rf_metrics.rf_error = true;
logger.info("Late (detected in %s)", error.opt ? "rx call" : "asynchronous thread");
} else if (error.type == srsran_rf_error_t::SRSRAN_RF_ERROR_RX) { } else if (error.type == srsran_rf_error_t::SRSRAN_RF_ERROR_RX) {
logger.error("Fatal radio error occured."); logger.error("Fatal radio error occured.");
phy->radio_failure(); phy->radio_failure();

Loading…
Cancel
Save