detect and handle repeated ERAB IDs in S1AP ERAB Modify Request message

master
Francisco 4 years ago committed by Francisco Paisana
parent eeddbe69ce
commit bc16c46ffc

@ -384,8 +384,6 @@ void rrc::release_erabs(uint32_t rnti,
const asn1::unbounded_octstring<true>* nas_pdu = const asn1::unbounded_octstring<true>* nas_pdu =
msg.protocol_ies.nas_pdu_present ? &msg.protocol_ies.nas_pdu.value : nullptr; msg.protocol_ies.nas_pdu_present ? &msg.protocol_ies.nas_pdu.value : nullptr;
user_it->second->send_connection_reconf(nullptr, false, nas_pdu); user_it->second->send_connection_reconf(nullptr, false, nas_pdu);
return;
} }
void rrc::modify_erabs(uint16_t rnti, void rrc::modify_erabs(uint16_t rnti,
@ -401,16 +399,26 @@ void rrc::modify_erabs(uint16_t rnti,
return; return;
} }
// Iterate over bearers const auto& erab_mod_list = msg.protocol_ies.erab_to_be_modified_list_bearer_mod_req.value;
for (uint32_t i = 0; i < msg.protocol_ies.erab_to_be_modified_list_bearer_mod_req.value.size(); i++) {
const asn1::s1ap::erab_to_be_modified_item_bearer_mod_req_s& erab_to_mod =
msg.protocol_ies.erab_to_be_modified_list_bearer_mod_req.value[i]
.value.erab_to_be_modified_item_bearer_mod_req();
uint32_t erab_id = erab_to_mod.erab_id; for (const auto* it = erab_mod_list.begin(); it != erab_mod_list.end(); ++it) {
asn1::s1ap::erab_level_qos_params_s qos_params = erab_to_mod.erab_level_qos_params; const auto& erab_to_mod = it->value.erab_to_be_modified_item_bearer_mod_req();
bool ret = modify_ue_erab(rnti, erab_id, qos_params, &erab_to_mod.nas_pdu); for (const auto* it2 = it + 1; it2 != erab_mod_list.end(); ++it2) {
// Detect repeated E-RAB IDs
if (it2->value.erab_to_be_modified_item_bearer_mod_req().erab_id == erab_to_mod.erab_id) {
erabs_failed_to_modify->push_back(it->id);
continue;
}
}
if (std::find(erabs_failed_to_modify->begin(), erabs_failed_to_modify->end(), erab_to_mod.erab_id) !=
erabs_failed_to_modify->end()) {
// Already added to the list of E-RABs that modification as failed
continue;
}
// Attempt to modify E-RAB
bool ret = modify_ue_erab(rnti, erab_to_mod.erab_id, erab_to_mod.erab_level_qos_params, &erab_to_mod.nas_pdu);
if (ret) { if (ret) {
erabs_modified->push_back(erab_to_mod.erab_id); erabs_modified->push_back(erab_to_mod.erab_id);
} else { } else {
@ -418,7 +426,9 @@ void rrc::modify_erabs(uint16_t rnti,
} }
} }
return; // Sort output vectors by ERAB ID
std::sort(erabs_modified->begin(), erabs_modified->end());
std::sort(erabs_failed_to_modify->begin(), erabs_failed_to_modify->end());
} }
bool rrc::modify_ue_erab(uint16_t rnti, bool rrc::modify_ue_erab(uint16_t rnti,

Loading…
Cancel
Save