update ded_info_nas_list handling

master
Francisco Paisana 5 years ago committed by Francisco Paisana
parent 2e4e22dc68
commit 09cafaa4bb

@ -78,8 +78,8 @@ private:
sched_interface::ue_cfg_t* sched_ue_cfg; sched_interface::ue_cfg_t* sched_ue_cfg;
srslte::byte_buffer_pool* pool = nullptr; srslte::byte_buffer_pool* pool = nullptr;
std::map<uint8_t, srslte::unique_byte_buffer_t> erab_info_list; std::map<uint8_t, std::vector<uint8_t> > erab_info_list;
std::map<uint8_t, erab_t> erabs; std::map<uint8_t, erab_t> erabs;
// last cfg // last cfg
asn1::rrc::srb_to_add_mod_list_l last_srbs; asn1::rrc::srb_to_add_mod_list_l last_srbs;

@ -93,14 +93,10 @@ int bearer_handler::setup_erab(uint8_t
return SRSLTE_ERROR; return SRSLTE_ERROR;
} }
if (nas_pdu != nullptr) { if (nas_pdu != nullptr and nas_pdu->size() > 0) {
erab_info_list[erab_id] = allocate_unique_buffer(*pool); erab_info_list[erab_id].assign(nas_pdu->data(), nas_pdu->data() + nas_pdu->size());
memcpy(erab_info_list[erab_id]->msg, nas_pdu->data(), nas_pdu->size()); log_h->info_hex(
erab_info_list[erab_id]->N_bytes = nas_pdu->size(); &erab_info_list[erab_id][0], erab_info_list[erab_id].size(), "setup_erab nas_pdu -> erab_info rnti 0x%x", rnti);
log_h->info_hex(erab_info_list[erab_id]->msg,
erab_info_list[erab_id]->N_bytes,
"setup_erab nas_pdu -> erab_info rnti 0x%x",
rnti);
} }
// Set DRBtoAddMod // Set DRBtoAddMod
@ -262,11 +258,10 @@ void bearer_handler::fill_pending_nas_info(asn1::rrc::rrc_conn_recfg_r8_ies_s* m
uint8_t erab_id = drb.drb_id + 4; uint8_t erab_id = drb.drb_id + 4;
auto it = erab_info_list.find(erab_id); auto it = erab_info_list.find(erab_id);
if (it != erab_info_list.end()) { if (it != erab_info_list.end()) {
const srslte::unique_byte_buffer_t& erab_info = it->second; const std::vector<uint8_t>& erab_info = it->second;
log_h->info_hex( log_h->info_hex(&erab_info[0], erab_info.size(), "connection_reconf erab_info -> nas_info rnti 0x%x\n", rnti);
erab_info->msg, erab_info->N_bytes, "connection_reconf erab_info -> nas_info rnti 0x%x\n", rnti); msg->ded_info_nas_list[idx].resize(erab_info.size());
msg->ded_info_nas_list[idx].resize(erab_info->N_bytes); memcpy(msg->ded_info_nas_list[idx].data(), &erab_info[0], erab_info.size());
memcpy(msg->ded_info_nas_list[idx].data(), erab_info->msg, erab_info->N_bytes);
erab_info_list.erase(it); erab_info_list.erase(it);
} else { } else {
log_h->debug("Not adding NAS message to connection reconfiguration. E-RAB id %d\n", erab_id); log_h->debug("Not adding NAS message to connection reconfiguration. E-RAB id %d\n", erab_id);

Loading…
Cancel
Save