fix req_bytes methods to account for new method to calculate conres scheduling.

master
Francisco Paisana 5 years ago committed by Francisco Paisana
parent d716d8bf7e
commit 66a38f53f5

@ -472,6 +472,7 @@ int sched_ue::generate_format1(uint32_t pid,
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_state = ra_state_t::conres_sent; conres_state = ra_state_t::conres_sent;
rem_tbs -= sched_utils::conres_ce_size + 1;
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);
} }
@ -494,9 +495,11 @@ int sched_ue::generate_format1(uint32_t pid,
// Allocate DL Harq, if there was at least one successful allocation // Allocate DL Harq, if there was at least one successful allocation
if (rem_tbs != tbs) { if (rem_tbs != tbs) {
h->new_tx(user_mask, 0, tti_tx_dl, mcs, tbs, data->dci.location.ncce); h->new_tx(user_mask, 0, tti_tx_dl, mcs, tbs, data->dci.location.ncce);
Debug("SCHED: Alloc format1 new mcs=%d, tbs=%d, nof_prb=%d, req_bytes=%d\n", mcs, tbs, nof_prb, req_bytes);
} else {
Warning("SCHED: Failed to allocate DL harq pid=%d\n", h->get_id());
} }
Debug("SCHED: Alloc format1 new mcs=%d, tbs=%d, nof_prb=%d, req_bytes=%d\n", mcs, tbs, nof_prb, req_bytes);
} else { } else {
h->new_retx(user_mask, 0, tti_tx_dl, &mcs, &tbs, data->dci.location.ncce); h->new_retx(user_mask, 0, tti_tx_dl, &mcs, &tbs, data->dci.location.ncce);
Debug("SCHED: Alloc format1 previous mcs=%d, tbs=%d\n", mcs, tbs); Debug("SCHED: Alloc format1 previous mcs=%d, tbs=%d\n", mcs, tbs);
@ -905,12 +908,12 @@ std::pair<uint32_t, uint32_t> sched_ue::get_requested_dl_bytes(uint32_t ue_cc_id
if (is_dci_format1 and (lch[0].buf_tx > 0 or lch[0].buf_retx > 0)) { if (is_dci_format1 and (lch[0].buf_tx > 0 or lch[0].buf_retx > 0)) {
srb0_data = compute_sdu_total_bytes(0, lch[0].buf_retx); srb0_data = compute_sdu_total_bytes(0, lch[0].buf_retx);
srb0_data += compute_sdu_total_bytes(0, lch[0].buf_tx); srb0_data += compute_sdu_total_bytes(0, lch[0].buf_tx);
if (is_conres_ce_pending()) {
sum_ce_data = sched_utils::conres_ce_size + ce_subheader_size;
}
} }
// Add pending CEs // Add pending CEs
if (is_dci_format1 and ue_cc_idx == 0) { if (is_dci_format1 and ue_cc_idx == 0) {
if (is_conres_ce_pending()) {
sum_ce_data = sched_utils::conres_ce_size + ce_subheader_size;
}
for (const auto& ce : pending_ces) { for (const auto& ce : pending_ces) {
sum_ce_data += ce.get_req_bytes(cfg); sum_ce_data += ce.get_req_bytes(cfg);
} }
@ -925,12 +928,11 @@ std::pair<uint32_t, uint32_t> sched_ue::get_requested_dl_bytes(uint32_t ue_cc_id
max_data = srb0_data + sum_ce_data + rb_data; max_data = srb0_data + sum_ce_data + rb_data;
/* Set Minimum boundary */ /* Set Minimum boundary */
if (srb0_data > 0) {
min_data = srb0_data; min_data = srb0_data;
if (is_conres_ce_pending()) { if (is_conres_ce_pending()) {
min_data += sched_utils::conres_ce_size + ce_subheader_size; min_data += sched_utils::conres_ce_size + ce_subheader_size;
} }
} else { if (min_data == 0) {
if (sum_ce_data > 0) { if (sum_ce_data > 0) {
min_data = pending_ces.front().get_req_bytes(cfg); min_data = pending_ces.front().get_req_bytes(cfg);
} else if (rb_data > 0) { } else if (rb_data > 0) {

@ -64,7 +64,6 @@ using srslte::tti_point;
*******************************************************/ *******************************************************/
uint32_t const seed = std::chrono::system_clock::now().time_since_epoch().count(); uint32_t const seed = std::chrono::system_clock::now().time_since_epoch().count();
// uint32_t const seed = 2452071795;
// uint32_t const seed = 1581009287; // prb==25 // uint32_t const seed = 1581009287; // prb==25
bool check_old_pids = false; bool check_old_pids = false;

Loading…
Cancel
Save