Commit e31d87ee authored by francescomani's avatar francescomani

trigger RA also in case of no valid pucch resource configured for pending SR

parent 408cebc1
...@@ -2512,11 +2512,10 @@ int8_t nr_ue_get_SR(NR_UE_MAC_INST_t *mac, frame_t frame, slot_t slot, NR_Schedu ...@@ -2512,11 +2512,10 @@ int8_t nr_ue_get_SR(NR_UE_MAC_INST_t *mac, frame_t frame, slot_t slot, NR_Schedu
sr_info->maxTransmissions); sr_info->maxTransmissions);
// initiate a Random Access procedure (see clause 5.1) on the SpCell and cancel all pending SRs. // initiate a Random Access procedure (see clause 5.1) on the SpCell and cancel all pending SRs.
schedule_RA_after_SR_failure(mac);
sr_info->pending = false; sr_info->pending = false;
sr_info->counter = 0; sr_info->counter = 0;
nr_timer_stop(&sr_info->prohibitTimer); nr_timer_stop(&sr_info->prohibitTimer);
schedule_RA_after_SR_failure(mac);
return -1; return -1;
} }
......
...@@ -1122,6 +1122,19 @@ void nr_ue_dl_scheduler(NR_UE_MAC_INST_t *mac, nr_downlink_indication_t *dl_info ...@@ -1122,6 +1122,19 @@ void nr_ue_dl_scheduler(NR_UE_MAC_INST_t *mac, nr_downlink_indication_t *dl_info
LOG_E(NR_MAC, "Internal error, no scheduled_response function\n"); LOG_E(NR_MAC, "Internal error, no scheduled_response function\n");
} }
static bool check_pucchres_for_pending_SR(NR_PUCCH_Config_t *pucch_Config, int target_sr_id)
{
for (int id = 0; id < pucch_Config->schedulingRequestResourceToAddModList->list.count; id++) {
NR_SchedulingRequestResourceConfig_t *sr_Config = pucch_Config->schedulingRequestResourceToAddModList->list.array[id];
if (sr_Config->schedulingRequestID == target_sr_id) {
if (sr_Config->resource) {
return true;
}
}
}
return false;
}
static void nr_update_sr(NR_UE_MAC_INST_t *mac) static void nr_update_sr(NR_UE_MAC_INST_t *mac)
{ {
NR_UE_SCHEDULING_INFO *sched_info = &mac->scheduling_info; NR_UE_SCHEDULING_INFO *sched_info = &mac->scheduling_info;
...@@ -1164,17 +1177,27 @@ static void nr_update_sr(NR_UE_MAC_INST_t *mac) ...@@ -1164,17 +1177,27 @@ static void nr_update_sr(NR_UE_MAC_INST_t *mac)
// if the UL-SCH resources available for a new transmission do not meet the LCP mapping restrictions // if the UL-SCH resources available for a new transmission do not meet the LCP mapping restrictions
// TODO not implemented // TODO not implemented
// trigger SR
if (lc_info->sr_id < 0 || lc_info->sr_id >= NR_MAX_SR_ID) if (lc_info->sr_id < 0 || lc_info->sr_id >= NR_MAX_SR_ID)
LOG_E(NR_MAC, "No SR corresponding to this LCID\n"); // TODO not sure what to do here LOG_E(NR_MAC, "No SR corresponding to this LCID\n"); // TODO not sure what to do here
else { else {
nr_sr_info_t *sr = &sched_info->sr_info[lc_info->sr_id]; nr_sr_info_t *sr = &sched_info->sr_info[lc_info->sr_id];
if (!sr->pending) { if (!sr->pending) {
LOG_D(NR_MAC, "Triggering SR for ID %d\n", lc_info->sr_id); NR_UE_UL_BWP_t *current_UL_BWP = mac->current_UL_BWP;
sr->pending = true; NR_PUCCH_Config_t *pucch_Config = current_UL_BWP ? current_UL_BWP->pucch_Config : NULL;
sr->counter = 0; if (check_pucchres_for_pending_SR(pucch_Config, lc_info->sr_id)) {
// TODO initiate a Random Access procedure on the SpCell and cancel the pending SR // trigger SR
// if the MAC entity has no valid PUCCH resource configured for the pending SR LOG_D(NR_MAC, "Triggering SR for ID %d\n", lc_info->sr_id);
sr->pending = true;
sr->counter = 0;
}
else {
// initiate a Random Access procedure on the SpCell and cancel the pending SR
// if the MAC entity has no valid PUCCH resource configured for the pending SR
sr->pending = false;
sr->counter = 0;
nr_timer_stop(&sr->prohibitTimer);
schedule_RA_after_SR_failure(mac);
}
} }
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment