From 4819dae2363f10a1ef67a880c036e5a34f9b6c70 Mon Sep 17 00:00:00 2001 From: ismagom Date: Wed, 10 Jun 2015 02:44:29 +0200 Subject: [PATCH] Set DL HARQ new transmissionevery time a TB is correctly decoded --- .../ue/mac/include/srsapps/ue/mac/dl_harq.h | 1 - srsapps/ue/mac/src/dl_harq.cc | 25 ++++++++----------- srsapps/ue/mac/src/ul_harq.cc | 4 +-- 3 files changed, 13 insertions(+), 17 deletions(-) diff --git a/srsapps/ue/mac/include/srsapps/ue/mac/dl_harq.h b/srsapps/ue/mac/include/srsapps/ue/mac/dl_harq.h index f95d3dcbe..85bc77a62 100644 --- a/srsapps/ue/mac/include/srsapps/ue/mac/dl_harq.h +++ b/srsapps/ue/mac/include/srsapps/ue/mac/dl_harq.h @@ -82,7 +82,6 @@ private: dl_sched_grant pending_ack_grant; ul_buffer *pending_ul_buffer; bool is_first_tx; - bool is_first_decoded; bool pending_ack; srslte::log *log_h; diff --git a/srsapps/ue/mac/src/dl_harq.cc b/srsapps/ue/mac/src/dl_harq.cc index 49e70823c..2460de4ce 100644 --- a/srsapps/ue/mac/src/dl_harq.cc +++ b/srsapps/ue/mac/src/dl_harq.cc @@ -103,7 +103,6 @@ void dl_harq_entity::send_pending_ack_contention_resolution() dl_harq_entity::dl_harq_process::dl_harq_process() : cur_grant(0),pending_ack_grant(0) { is_first_tx = true; - is_first_decoded = true; is_initiated = false; ack = false; bzero(&cur_grant, sizeof(srslte::ue::dl_sched_grant)); @@ -114,7 +113,6 @@ dl_harq_entity::dl_harq_process::dl_harq_process() : cur_grant(0),pending_ack_gr void dl_harq_entity::dl_harq_process::reset() { ack = false; is_first_tx = true; - is_first_decoded = true; bzero(&cur_grant, sizeof(srslte::ue::dl_sched_grant)); if (is_initiated) { srslte_softbuffer_rx_reset(&softbuffer); @@ -144,17 +142,16 @@ void dl_harq_entity::dl_harq_process::receive_data(uint32_t tti, srslte::ue::dl_ Debug("Delivering PDU=%d bytes to Dissassemble and Demux unit (BCCH)\n", cur_grant.get_tbs()/8); harq_entity->demux_unit->push_pdu_bcch(payload, cur_grant.get_tbs()); } else { - if (is_first_decoded) { - if (cur_grant.is_temp_rnti()) { - Debug("Delivering PDU=%d bytes to Dissassemble and Demux unit (Temporal C-RNTI)\n", - cur_grant.get_tbs()/8); - harq_entity->demux_unit->push_pdu_temp_crnti(payload, cur_grant.get_tbs()); - } else { - Debug("Delivering PDU=%d bytes to Dissassemble and Demux unit\n", cur_grant.get_tbs()/8); - harq_entity->demux_unit->push_pdu(payload, cur_grant.get_tbs()); - } + if (cur_grant.is_temp_rnti()) { + Debug("Delivering PDU=%d bytes to Dissassemble and Demux unit (Temporal C-RNTI)\n", + cur_grant.get_tbs()/8); + harq_entity->demux_unit->push_pdu_temp_crnti(payload, cur_grant.get_tbs()); + } else { + Debug("Delivering PDU=%d bytes to Dissassemble and Demux unit\n", cur_grant.get_tbs()/8); + harq_entity->demux_unit->push_pdu(payload, cur_grant.get_tbs()); } ack = true; + is_first_tx = true; } } else { // RX NOK @@ -191,9 +188,8 @@ void dl_harq_entity::dl_harq_process::receive_data(uint32_t tti, srslte::ue::dl_ void dl_harq_entity::dl_harq_process::set_harq_info(srslte::ue::dl_sched_grant* new_grant) { bool is_new_transmission = false; - if (new_grant->get_ndi() == 1 || is_first_tx || (pid == HARQ_BCCH_PID && new_grant->get_rv() == 0)) { + if (new_grant->get_ndi() == true || is_first_tx || (pid == HARQ_BCCH_PID && new_grant->get_rv() == 0)) { is_new_transmission = true; - is_first_decoded = true; Debug("Set HARQ Info for new transmission\n"); } else { is_new_transmission = false; @@ -203,7 +199,8 @@ void dl_harq_entity::dl_harq_process::set_harq_info(srslte::ue::dl_sched_grant* if (is_first_tx) { Info("DL PID %d: first TX RV=%d, NDI=%d\n", pid, new_grant->get_rv(), new_grant->get_ndi()); } else { - Info("DL PID %d: %s RV=%d, NDI=%d, LastNDI=%d\n", pid, is_new_transmission?"new TX":"reTX", new_grant->get_rv(), new_grant->get_ndi(), cur_grant.get_ndi()); + Info("DL PID %d: %s RV=%d, NDI=%d, LastNDI=%d\n", pid, is_new_transmission?"new TX":"reTX", new_grant->get_rv(), + new_grant->get_ndi(), cur_grant.get_ndi()); } if (is_first_tx) { diff --git a/srsapps/ue/mac/src/ul_harq.cc b/srsapps/ue/mac/src/ul_harq.cc index 8132e84ab..4ec3418d0 100644 --- a/srsapps/ue/mac/src/ul_harq.cc +++ b/srsapps/ue/mac/src/ul_harq.cc @@ -93,8 +93,8 @@ void ul_harq_entity::run_tti(uint32_t tti, ul_sched_grant *grant, phy *phy_h) } if (grant) { - if ((grant->is_temp_rnti() && grant->get_ndi() != proc[pid].get_ndi()) || - (grant->is_crnti() && !proc[pid].has_grant()) || + if ((!grant->is_temp_rnti() && grant->get_ndi() == true) || + (grant->is_crnti() && !proc[pid].has_grant()) || grant->is_from_rar()) { // New transmission