The scheduler now accounts for the possible presence of BSRs in the size of UL grants

master
Francisco Paisana 4 years ago
parent f185272367
commit 12c147d75a

@ -984,17 +984,24 @@ uint32_t sched_ue::get_pending_ul_old_data(uint32_t cc_idx)
uint32_t sched_ue::get_pending_ul_new_data(uint32_t tti, int this_ue_cc_idx) uint32_t sched_ue::get_pending_ul_new_data(uint32_t tti, int this_ue_cc_idx)
{ {
static constexpr uint32_t lbsr_size = 4, sbsr_size = 2;
// Note: If there are no active bearers, scheduling requests are also ignored. // Note: If there are no active bearers, scheduling requests are also ignored.
uint32_t pending_data = 0; uint32_t pending_data = 0;
bool ul_bearers_found = false; uint32_t active_lcgs = 0, pending_lcgs = 0;
for (int i = 0; i < sched_interface::MAX_LC_GROUP; i++) { for (int i = 0; i < sched_interface::MAX_LC_GROUP; i++) {
if (lch_handler.is_bearer_ul(i)) { if (lch_handler.is_bearer_ul(i)) {
pending_data += lch_handler.get_bsr(i); int bsr = lch_handler.get_bsr(i);
ul_bearers_found = true; pending_data += bsr;
active_lcgs++;
pending_lcgs += (bsr > 0) ? 1 : 0;
} }
} }
if (pending_data == 0) { if (pending_data > 0) {
if (is_sr_triggered() and ul_bearers_found and this_ue_cc_idx >= 0) { // BSR is expected
pending_data += (pending_lcgs <= 1) ? sbsr_size : lbsr_size;
} else {
if (is_sr_triggered() and active_lcgs > 0 and this_ue_cc_idx >= 0) {
// Check if this_cc_idx is the carrier with highest CQI // Check if this_cc_idx is the carrier with highest CQI
uint32_t max_cqi = 0, max_cc_idx = 0; uint32_t max_cqi = 0, max_cc_idx = 0;
for (uint32_t cc_idx = 0; cc_idx < carriers.size(); ++cc_idx) { for (uint32_t cc_idx = 0; cc_idx < carriers.size(); ++cc_idx) {

Loading…
Cancel
Save