From b2826402b93fdbc3a3c46a4be5f543f903f09178 Mon Sep 17 00:00:00 2001 From: Pedro Alvarez Date: Mon, 4 Dec 2017 10:54:47 +0000 Subject: [PATCH] Continuing to parse intial context setup --- srsepc/hdr/mme/s1ap_common.h | 2 +- srsepc/src/mme/s1ap.cc | 25 +++++++++---------------- 2 files changed, 10 insertions(+), 17 deletions(-) diff --git a/srsepc/hdr/mme/s1ap_common.h b/srsepc/hdr/mme/s1ap_common.h index 3c13e669e..803a66ecf 100644 --- a/srsepc/hdr/mme/s1ap_common.h +++ b/srsepc/hdr/mme/s1ap_common.h @@ -79,7 +79,7 @@ typedef struct{ uint16_t enb_id; struct sctp_sndrcvinfo enb_sri; eps_security_ctx_t security_ctxt; - erab_ctx_t erabs[MAX_ERABS_PER_UE]; + erab_ctx_t erabs_ctx[MAX_ERABS_PER_UE]; } ue_ctx_t; }//namespace #endif diff --git a/srsepc/src/mme/s1ap.cc b/srsepc/src/mme/s1ap.cc index c64977a2a..7ec26af32 100644 --- a/srsepc/src/mme/s1ap.cc +++ b/srsepc/src/mme/s1ap.cc @@ -663,15 +663,14 @@ s1ap::send_initial_context_setup_request(uint32_t mme_ue_s1ap_id, struct srslte: m_s1ap_log->error("Could not pack Initial Context Setup Request Message\n"); return false; } - //Send Reply to eNB - + //Send Reply to eNB ssize_t n_sent = sctp_send(m_s1mme,reply_buffer->msg, reply_buffer->N_bytes, &ue_ctx->enb_sri, 0); if(n_sent == -1) { m_s1ap_log->error("Failed to send Initial Context Setup Request\n"); return false; } - + m_s1ap_log->info("Sent Intial Context Setup Request\n"); m_s1ap_log->console("Sent Intial Context Setup Request\n"); @@ -708,7 +707,7 @@ s1ap::handle_initial_context_setup_response(LIBLTE_S1AP_MESSAGE_INITIALCONTEXTSE }LIBLTE_S1AP_E_RABSETUPITEMCTXTSURES_STRUCT; */ uint32_t mme_ue_s1ap_id = in_ctxt_resp->MME_UE_S1AP_ID.MME_UE_S1AP_ID; - std::map ue_ctx_it = m_acive_ues.find(mme_ue_s1ap_id); + std::map::iterator ue_ctx_it = m_active_ues.find(mme_ue_s1ap_id); if (ue_ctx_it == m_active_ues.end()) { m_s1ap_log->error("Could not find UE's context in active UE's map\n"); @@ -717,22 +716,16 @@ s1ap::handle_initial_context_setup_response(LIBLTE_S1AP_MESSAGE_INITIALCONTEXTSE for(uint32_t i; iE_RABSetupListCtxtSURes.len;i++) { uint8_t erab_id = in_ctxt_resp->E_RABSetupListCtxtSURes.buffer[i].e_RAB_ID.E_RAB_ID; + erab_ctx_t *erab_ctx = &ue_ctx_it->second->erabs_ctx[erab_id]; if (erab_ctx->active == false) { - m_s1ap_log->error("E-RAB requested was not active %d\n",); + m_s1ap_log->error("E-RAB requested was not active %d\n",erab_id); return false; } - erab_ctx_t *erab_ctx = &ue_ctx_it->second->erab_ctx[i]; - for(uint32_t i; iE_RABSetupListCtxtSURes.len;i++) - { - uint8_t erab_id = in_ctxt_resp->E_RABSetupListCtxtSURes.buffer[i].e_RAB_ID.E_RAB_ID; - std::set ue_erab_it = erabs_it->second.find(erab_id); - if(ue_erab_it == erabs_it->second.end() ) - { - m_s1ap_log->error("Could not find UE's in UE active bearers map\n"); - return false; - } - } + //Set the GTP information + memcpy(&erab_ctx->enb_fteid.ipv4, in_ctxt_resp->E_RABSetupListCtxtSURes.buffer[i].transportLayerAddress.buffer,4); + memcpy(&erab_ctx->enb_fteid.teid, in_ctxt_resp->E_RABSetupListCtxtSURes.buffer[i].gTP_TEID.buffer, 4); + } return true; }