fixed issue regarding repetition of ConRes tx

master
Francisco Paisana 5 years ago
parent e94e0a8641
commit eeb47f8fa4

@ -264,6 +264,9 @@ private:
uint16_t rnti = 0; uint16_t rnti = 0;
uint32_t max_msg3retx = 0; uint32_t max_msg3retx = 0;
/* User State */
bool conres_ce_pending = true;
uint32_t nof_ta_cmd = 0; uint32_t nof_ta_cmd = 0;
int next_tpc_pusch = 0; int next_tpc_pusch = 0;

@ -114,6 +114,7 @@ void sched_ue::reset()
buf_ul = 0; buf_ul = 0;
phy_config_dedicated_enabled = false; phy_config_dedicated_enabled = false;
cqi_request_tti = 0; cqi_request_tti = 0;
conres_ce_pending = true;
for (auto& c : carriers) { for (auto& c : carriers) {
c.reset(); c.reset();
} }
@ -442,8 +443,8 @@ int sched_ue::generate_format1(dl_harq_proc* h,
if (need_conres_ce) { if (need_conres_ce) {
data->pdu[0][data->nof_pdu_elems[0]].lcid = srslte::sch_subh::CON_RES_ID; data->pdu[0][data->nof_pdu_elems[0]].lcid = srslte::sch_subh::CON_RES_ID;
data->nof_pdu_elems[0]++; data->nof_pdu_elems[0]++;
conres_ce_pending = false;
Info("SCHED: Added MAC Contention Resolution CE for rnti=0x%x\n", rnti); Info("SCHED: Added MAC Contention Resolution CE for rnti=0x%x\n", rnti);
} else { } else {
// Add TA CE // Add TA CE
// FIXME: Can't put it in Msg4 because current srsUE doesn't read it // FIXME: Can't put it in Msg4 because current srsUE doesn't read it
@ -766,7 +767,7 @@ bool sched_ue::needs_cqi_unlocked(uint32_t tti, uint32_t cc_idx, bool will_be_se
bool sched_ue::is_conres_ce_pending() const bool sched_ue::is_conres_ce_pending() const
{ {
return bearer_is_dl(&lch[0]) and (lch[0].buf_retx > 0 or lch[0].buf_tx > 0); return conres_ce_pending and bearer_is_dl(&lch[0]) and (lch[0].buf_retx > 0 or lch[0].buf_tx > 0);
} }
uint32_t sched_ue::get_pending_dl_new_data() uint32_t sched_ue::get_pending_dl_new_data()

@ -180,7 +180,8 @@ struct sched_tester : public srsenb::sched {
srsenb::sched_interface::dl_sched_res_t sched_result_dl; srsenb::sched_interface::dl_sched_res_t sched_result_dl;
}; };
struct ue_info { struct ue_info {
int prach_tti = -1, rar_tti = -1, msg3_tti = -1; int prach_tti = -1, rar_tti = -1, msg3_tti = -1, msg4_tti = -1;
bool drb_cfg_flag = false;
srsenb::sched_interface::ue_bearer_cfg_t bearer_cfg; srsenb::sched_interface::ue_bearer_cfg_t bearer_cfg;
srsenb::sched_interface::ue_cfg_t user_cfg; srsenb::sched_interface::ue_cfg_t user_cfg;
uint32_t dl_data = 0; uint32_t dl_data = 0;
@ -305,15 +306,29 @@ int sched_tester::process_tti_args()
// push UL SRs and DL packets // push UL SRs and DL packets
for (auto& e : sim_args.tti_events[tti_data.tti_rx].users) { for (auto& e : sim_args.tti_events[tti_data.tti_rx].users) {
if (e.second.sr_data > 0) { if (e.second.sr_data > 0 and tester_ues[e.first].drb_cfg_flag) {
uint32_t tot_ul_data = ue_db[e.first].get_pending_ul_new_data(tti_data.tti_tx_ul) + e.second.sr_data; uint32_t tot_ul_data = ue_db[e.first].get_pending_ul_new_data(tti_data.tti_tx_ul) + e.second.sr_data;
uint32_t lcid = 0; uint32_t lcid = 0;
ul_bsr(e.first, lcid, tot_ul_data, true); ul_bsr(e.first, lcid, tot_ul_data, true);
} }
if (e.second.dl_data > 0) { if (e.second.dl_data > 0 and tester_ues[e.first].msg3_tti >= 0 and
uint32_t lcid = 0; tester_ues[e.first].msg3_tti < (int)tti_data.tti_rx) {
// If Msg4 not yet sent, allocate data in SRB0 buffer
uint32_t lcid = (tester_ues[e.first].msg4_tti >= 0) ? 2 : 0;
uint32_t pending_dl_new_data = ue_db[e.first].get_pending_dl_new_data();
if (lcid == 2 and not tester_ues[e.first].drb_cfg_flag) {
// If RRCSetup finished
if (pending_dl_new_data == 0) {
// setup lcid==2 bearer
tester_ues[e.first].drb_cfg_flag = true;
bearer_ue_cfg(e.first, 2, &tester_ues[e.first].bearer_cfg);
} else {
// Let SRB0 get emptied
continue;
}
}
// FIXME: Does it need TTI for checking pending data? // FIXME: Does it need TTI for checking pending data?
uint32_t tot_dl_data = ue_db[e.first].get_pending_dl_new_data() + e.second.dl_data; uint32_t tot_dl_data = pending_dl_new_data + e.second.dl_data;
dl_rlc_buffer_state(e.first, lcid, tot_dl_data, 0); dl_rlc_buffer_state(e.first, lcid, tot_dl_data, 0);
} }
} }
@ -415,13 +430,12 @@ int sched_tester::test_ra()
// Check whether RA has completed correctly // Check whether RA has completed correctly
int prach_tti = userinfo.prach_tti; int prach_tti = userinfo.prach_tti;
if (userinfo.msg3_tti > prach_tti) { // Msg3 already scheduled // if (userinfo.msg4_tti > prach_tti) { // Msg4 already scheduled
continue; // continue;
} // }
bool rar_not_sent = prach_tti >= userinfo.rar_tti;
uint32_t window[2] = {(uint32_t)prach_tti + 3, prach_tti + 3 + cfg.prach_rar_window}; uint32_t window[2] = {(uint32_t)prach_tti + 3, prach_tti + 3 + cfg.prach_rar_window};
if (rar_not_sent) { if (prach_tti >= userinfo.rar_tti) { // RAR not yet sent
CONDERROR(tti_data.tti_tx_dl > window[1], "[TESTER] There was no RAR scheduled within the RAR Window\n"); CONDERROR(tti_data.tti_tx_dl > window[1], "[TESTER] There was no RAR scheduled within the RAR Window\n");
if (tti_data.tti_tx_dl >= window[0]) { if (tti_data.tti_tx_dl >= window[0]) {
for (uint32_t i = 0; i < tti_data.sched_result_dl.nof_rar_elems; ++i) { for (uint32_t i = 0; i < tti_data.sched_result_dl.nof_rar_elems; ++i) {
@ -432,7 +446,7 @@ int sched_tester::test_ra()
} }
} }
} }
} else { // RAR completed, check for Msg3 } else if (userinfo.msg3_tti < prach_tti) { // Msg3 not yet sent
uint32_t msg3_tti = (uint32_t)(userinfo.rar_tti + FDD_HARQ_DELAY_MS + MSG3_DELAY_MS) % 10240; uint32_t msg3_tti = (uint32_t)(userinfo.rar_tti + FDD_HARQ_DELAY_MS + MSG3_DELAY_MS) % 10240;
if (msg3_tti == tti_data.tti_tx_ul) { if (msg3_tti == tti_data.tti_tx_ul) {
for (uint32_t i = 0; i < tti_data.sched_result_ul.nof_dci_elems; ++i) { for (uint32_t i = 0; i < tti_data.sched_result_ul.nof_dci_elems; ++i) {
@ -450,6 +464,23 @@ int sched_tester::test_ra()
TESTERROR("[TESTER] No UL msg3 allocation was made\n"); TESTERROR("[TESTER] No UL msg3 allocation was made\n");
} }
} }
// Find any Msg4 allocation
for (uint32_t i = 0; i < tti_data.sched_result_dl.nof_data_elems; ++i) {
auto& ue_data = tti_data.sched_result_dl.data[i];
if (ue_data.dci.rnti != rnti) {
continue;
}
for (uint32_t j = 0; j < tti_data.sched_result_dl.data[i].nof_pdu_elems[0]; ++j) {
if (ue_data.pdu[0][j].lcid == srslte::sch_subh::CON_RES_ID) {
// ConRes found
CONDERROR(ue_data.dci.format != SRSLTE_DCI_FORMAT1, "ConRes must be format1\n");
CONDERROR(userinfo.msg3_tti > (int)tti_data.tti_rx, "Transmitting ConRes without receiving Msg3\n");
CONDERROR(userinfo.msg4_tti >= 0, "ConRes CE cannot be retransmitted for the same rnti\n");
userinfo.msg4_tti = tti_data.tti_tx_dl;
}
}
}
} }
for (uint32_t i = 0; i < tti_data.sched_result_ul.nof_dci_elems; ++i) { for (uint32_t i = 0; i < tti_data.sched_result_ul.nof_dci_elems; ++i) {
msg3_count -= tti_data.sched_result_ul.pusch[i].needs_pdcch ? 0 : 1; msg3_count -= tti_data.sched_result_ul.pusch[i].needs_pdcch ? 0 : 1;

Loading…
Cancel
Save