Fix several data races in LTE and NR harq classes.

master
faluco 3 years ago committed by Andre Puschmann
parent 991013ca2c
commit 6c4548c243

@ -99,6 +99,7 @@ private:
ue_rnti* rntis = nullptr;
srsran::ul_harq_cfg_t harq_cfg = {};
std::mutex config_mutex;
std::atomic<float> average_retx{0};
std::atomic<uint64_t> nof_pkts{0};

@ -96,6 +96,7 @@ private:
srslog::basic_logger& logger;
uint16_t last_temporal_crnti = SRSRAN_INVALID_RNTI;
dl_harq_metrics_t metrics = {};
std::mutex metrics_mutex;
uint8_t cc_idx = 0;
pthread_rwlock_t rwlock;
};

@ -103,6 +103,7 @@ private:
srsran::ul_harq_cfg_t harq_cfg = {};
ul_harq_metrics_t metrics = {};
std::mutex metrics_mutex;
};
typedef std::unique_ptr<ul_harq_entity_nr> ul_harq_entity_nr_ptr;

@ -57,6 +57,7 @@ void ul_harq_entity::reset_ndi()
void ul_harq_entity::set_config(srsran::ul_harq_cfg_t& harq_cfg_)
{
std::lock_guard<std::mutex> lock(config_mutex);
harq_cfg = harq_cfg_;
}
@ -174,11 +175,14 @@ void ul_harq_entity::ul_harq_process::new_grant_ul(mac_interface_phy_lte::mac_gr
// Get maximum retransmissions
uint32_t max_retx;
{
std::lock_guard<std::mutex> lock(harq_entity->config_mutex);
if (grant.rnti == harq_entity->rntis->get_temp_rnti()) {
max_retx = harq_entity->harq_cfg.max_harq_msg3_tx;
} else {
max_retx = harq_entity->harq_cfg.max_harq_tx;
}
}
// Check maximum retransmissions, do not consider last retx ACK
if (current_tx_nb >= max_retx && !grant.hi_value) {

@ -126,6 +126,7 @@ void dl_harq_entity_nr::reset()
dl_harq_entity_nr::dl_harq_metrics_t dl_harq_entity_nr::get_metrics()
{
std::lock_guard<std::mutex> lock(metrics_mutex);
dl_harq_metrics_t tmp = metrics;
metrics = {};
return tmp;
@ -230,9 +231,11 @@ void dl_harq_entity_nr::dl_harq_process_nr::tb_decoded(const mac_nr_grant_dl_t&
}
}
std::lock_guard<std::mutex> lock(harq_entity->metrics_mutex);
harq_entity->metrics.rx_ok++;
harq_entity->metrics.rx_brate += grant.tbs * 8;
} else {
std::lock_guard<std::mutex> lock(harq_entity->metrics_mutex);
harq_entity->metrics.rx_ko++;
}

@ -106,6 +106,7 @@ int ul_harq_entity_nr::get_current_tbs(uint32_t pid)
ul_harq_entity_nr::ul_harq_metrics_t ul_harq_entity_nr::get_metrics()
{
std::lock_guard<std::mutex> lock(metrics_mutex);
ul_harq_entity_nr::ul_harq_metrics_t tmp = metrics;
metrics = {};
return tmp;
@ -240,6 +241,7 @@ void ul_harq_entity_nr::ul_harq_process_nr::generate_new_tx(const mac_interface_
generate_tx(action);
std::lock_guard<std::mutex> lock(harq_entity->metrics_mutex);
harq_entity->metrics.tx_ok++;
}
@ -255,6 +257,7 @@ void ul_harq_entity_nr::ul_harq_process_nr::generate_retx(const mac_interface_ph
generate_tx(action);
// increment Tx error count
std::lock_guard<std::mutex> lock(harq_entity->metrics_mutex);
harq_entity->metrics.tx_ko++;
}
@ -262,7 +265,11 @@ void ul_harq_entity_nr::ul_harq_process_nr::generate_retx(const mac_interface_ph
void ul_harq_entity_nr::ul_harq_process_nr::generate_tx(mac_interface_phy_nr::tb_action_ul_t* action)
{
nof_retx++;
{
std::lock_guard<std::mutex> lock(harq_entity->metrics_mutex);
harq_entity->metrics.tx_brate += current_grant.tbs * 8;
}
action->tb.rv = current_grant.rv;
action->tb.enabled = true;

Loading…
Cancel
Save