From fb09ba8e7a6638a553f2e39ddb25380d472a7328 Mon Sep 17 00:00:00 2001 From: Lionel Gauthier <lionel.gauthier@eurecom.fr> Date: Fri, 10 Apr 2015 12:21:25 +0000 Subject: [PATCH] OK for start of MME_GW and HSS on same host git-svn-id: http://svn.eurecom.fr/openair4G/trunk@7110 818b1a75-f10b-46b9-bf7c-635c3b92a50f --- openair-cn/GTPV1-U/GTPUAH/xt_GTPUAH.c | 4 + openair-cn/GTPV1-U/gtpv1u_eNB.c | 99 +++++---- openair-cn/GTPV1-U/gtpv1u_eNB_defs.h | 17 +- openair-cn/GTPV1-U/gtpv1u_task.c | 7 +- .../GTPV1-U/nw-gtpv1u/src/NwGtpv1uMsg.c | 1 + openair-cn/MME_APP/mme_app_authentication.c | 144 ++----------- openair-cn/MME_APP/mme_app_context.c | 27 ++- openair-cn/MME_APP/mme_app_ue_context.h | 5 - .../NAS/EURECOM-NAS/src/api/mme/mme_api.c | 6 +- .../NAS/EURECOM-NAS/src/api/mme/mme_api.h | 4 +- .../EURECOM-NAS/src/api/network/nas_message.c | 33 ++- .../EURECOM-NAS/src/api/network/nas_message.h | 2 +- .../EURECOM-NAS/src/api/user/at_response.c | 2 +- openair-cn/NAS/EURECOM-NAS/src/emm/Attach.c | 43 ++-- .../NAS/EURECOM-NAS/src/emm/Authentication.c | 10 +- openair-cn/NAS/EURECOM-NAS/src/emm/Detach.c | 4 +- .../NAS/EURECOM-NAS/src/emm/EmmCommon.c | 32 +-- .../NAS/EURECOM-NAS/src/emm/EmmStatusHdl.c | 2 +- .../NAS/EURECOM-NAS/src/emm/Identification.c | 4 +- .../NAS/EURECOM-NAS/src/emm/LowerLayer.c | 4 +- .../EURECOM-NAS/src/emm/SecurityModeControl.c | 8 +- .../EURECOM-NAS/src/emm/TrackingAreaUpdate.c | 2 +- openair-cn/NAS/EURECOM-NAS/src/emm/emmData.h | 6 +- .../NAS/EURECOM-NAS/src/emm/emm_data_ctx.c | 2 +- openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.c | 8 +- openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.h | 4 +- .../NAS/EURECOM-NAS/src/emm/msg/emm_msg.c | 14 +- .../NAS/EURECOM-NAS/src/emm/sap/emm_as.c | 26 +-- .../NAS/EURECOM-NAS/src/emm/sap/emm_cn.c | 2 +- .../NAS/EURECOM-NAS/src/emm/sap/emm_cn.h | 2 +- .../NAS/EURECOM-NAS/src/emm/sap/emm_cnDef.h | 6 +- .../NAS/EURECOM-NAS/src/emm/sap/emm_fsm.c | 14 +- .../NAS/EURECOM-NAS/src/emm/sap/emm_fsm.h | 2 +- .../NAS/EURECOM-NAS/src/emm/sap/emm_recv.c | 21 +- .../NAS/EURECOM-NAS/src/emm/sap/emm_sap.c | 2 +- .../NAS/EURECOM-NAS/src/emm/sap/emm_sap.h | 4 +- .../NAS/EURECOM-NAS/src/esm/PdnConnectivity.c | 2 +- openair-cn/NAS/EURECOM-NAS/src/esm/esmData.h | 12 +- openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr.c | 6 +- .../NAS/EURECOM-NAS/src/esm/esm_ebr_context.c | 4 +- openair-cn/NAS/EURECOM-NAS/src/esm/esm_main.c | 2 +- .../NAS/EURECOM-NAS/src/esm/msg/esm_msg.c | 14 +- .../EURECOM-NAS/src/ies/UeNetworkCapability.c | 3 + .../src/ies/UeSecurityCapability.c | 26 ++- openair-cn/NAS/EURECOM-NAS/src/nas_network.c | 4 +- openair-cn/NAS/EURECOM-NAS/src/nas_network.h | 4 +- openair-cn/NAS/EURECOM-NAS/src/nas_proc.c | 4 +- openair-cn/NAS/EURECOM-NAS/src/nas_proc.h | 6 +- openair-cn/NAS/EURECOM-NAS/src/util/nas_log.c | 2 +- openair-cn/NAS/EURECOM-NAS/src/util/nas_log.h | 4 +- .../NAS/EURECOM-NAS/src/util/nas_timer.c | 2 +- .../NAS/EURECOM-NAS/src/util/nas_timer.h | 2 +- openair-cn/NAS/EURECOM-NAS/tools/network.h | 5 +- openair-cn/NAS/EURECOM-NAS/tools/ue_data.c | 55 ++--- openair-cn/NAS/EURECOM-NAS/tools/usim_data.c | 189 +++++++++--------- openair-cn/NAS/Makefile.UE | 2 +- openair-cn/NAS/Makefile.am | 2 +- openair-cn/NAS/nas_itti_messaging.c | 10 +- openair-cn/NAS/nas_itti_messaging.h | 6 +- openair-cn/OAI_EPC/oai_epc.c | 2 + openair-cn/S1AP/s1ap_eNB.c | 17 ++ .../s1ap_eNB_context_management_procedures.c | 32 +++ openair-cn/S1AP/s1ap_eNB_defs.h | 2 +- openair-cn/S1AP/s1ap_eNB_nas_procedures.c | 109 +++++++++- openair-cn/S1AP/s1ap_eNB_ue_context.h | 2 +- openair-cn/S1AP/s1ap_mme.c | 22 +- openair-cn/S1AP/s1ap_mme.h | 12 +- openair-cn/S1AP/s1ap_mme_handlers.c | 25 ++- openair-cn/S1AP/s1ap_mme_nas_procedures.c | 7 +- openair-cn/S1AP/s1ap_mme_retransmission.c | 2 +- openair-cn/S1AP/s1ap_mme_retransmission.h | 2 +- ...r-1.2.0.patch => freediameter-1.2.0.patch} | 2 +- openair-cn/S6A/s6a_defs.h | 1 + openair-cn/S6A/s6a_dict.c | 3 + openair-cn/S6A/s6a_task.c | 15 +- openair-cn/SGW-LITE/sgw_lite_task.c | 9 + openair-cn/UDP/udp_eNB_task.c | 2 +- openair-cn/UTILS/CONF/enb_default.conf | 12 -- openair-cn/UTILS/CONF/enb_orcus.conf | 12 -- openair-cn/UTILS/CONF/enb_yang.conf | 12 -- openair-cn/UTILS/CONF/epc_caviar.conf | 73 ------- openair-cn/UTILS/CONF/epc_nord.conf | 73 ------- openair-cn/UTILS/CONF/epc_orcus.conf | 73 ------- openair-cn/UTILS/CONF/epc_sud.conf | 73 ------- openair-cn/UTILS/CONF/epc_tapenade.conf | 73 ------- openair-cn/UTILS/CONF/epc_yang.conf | 73 ------- openair-cn/UTILS/CONF/mme_default.conf | 73 ------- openair-cn/UTILS/CONF/mme_yang.conf | 73 ------- openair-cn/UTILS/CONF/s6a.conf.in | 97 --------- 89 files changed, 667 insertions(+), 1255 deletions(-) rename openair-cn/S6A/freediameter/{freeDiameter-1.2.0.patch => freediameter-1.2.0.patch} (99%) delete mode 100755 openair-cn/UTILS/CONF/enb_default.conf delete mode 100644 openair-cn/UTILS/CONF/enb_orcus.conf delete mode 100755 openair-cn/UTILS/CONF/enb_yang.conf delete mode 100644 openair-cn/UTILS/CONF/epc_caviar.conf delete mode 100644 openair-cn/UTILS/CONF/epc_nord.conf delete mode 100644 openair-cn/UTILS/CONF/epc_orcus.conf delete mode 100644 openair-cn/UTILS/CONF/epc_sud.conf delete mode 100644 openair-cn/UTILS/CONF/epc_tapenade.conf delete mode 100755 openair-cn/UTILS/CONF/epc_yang.conf delete mode 100644 openair-cn/UTILS/CONF/mme_default.conf delete mode 100755 openair-cn/UTILS/CONF/mme_yang.conf delete mode 100644 openair-cn/UTILS/CONF/s6a.conf.in diff --git a/openair-cn/GTPV1-U/GTPUAH/xt_GTPUAH.c b/openair-cn/GTPV1-U/GTPUAH/xt_GTPUAH.c index db57e2e8d..f2daac86d 100755 --- a/openair-cn/GTPV1-U/GTPUAH/xt_GTPUAH.c +++ b/openair-cn/GTPV1-U/GTPUAH/xt_GTPUAH.c @@ -349,6 +349,10 @@ _gtpuah_tg4_add(struct sk_buff *old_skb_pP, const struct xt_action_param *par_pP } } }; + /*pr_info("GTPUAH: PACKET -> NF_HOOK NF_INET_POST_ROUTING/%s encapsulated src: %u.%u.%u.%u dst: %u.%u.%u.%u\n", + gtpuah_tg_reg[0].table, + NIPADDR(old_iph_p->saddr), + NIPADDR(old_iph_p->daddr));*/ rt = ip_route_output_key(&init_net, &fl.u.ip4); diff --git a/openair-cn/GTPV1-U/gtpv1u_eNB.c b/openair-cn/GTPV1-U/gtpv1u_eNB.c index 0549521c7..362ce22b9 100644 --- a/openair-cn/GTPV1-U/gtpv1u_eNB.c +++ b/openair-cn/GTPV1-U/gtpv1u_eNB.c @@ -68,6 +68,7 @@ extern boolean_t pdcp_data_req( unsigned char *const sdu_buffer_pP, const pdcp_transmission_mode_t modeP); +extern unsigned char NB_eNB_INST; static int gtpv1u_eNB_send_init_udp( @@ -132,19 +133,23 @@ gtpv1u_initial_req( int gtpv1u_new_data_req( - uint8_t enb_idP, - uint8_t ue_idP, + uint8_t enb_module_idP, + rnti_t ue_rntiP, uint8_t rab_idP, uint8_t *buffer_pP, uint32_t buf_lenP, - uint32_t buf_offsetP); + uint32_t buf_offsetP +); static int gtpv1u_create_s1u_tunnel( - gtpv1u_enb_create_tunnel_req_t *create_tunnel_req_pP); + const instance_t instanceP, + const gtpv1u_enb_create_tunnel_req_t * const create_tunnel_req_pP); static int -gtpv1u_delete_s1u_tunnel(gtpv1u_enb_delete_tunnel_req_t *req_pP); +gtpv1u_delete_s1u_tunnel( + const instance_t instanceP, + const gtpv1u_enb_delete_tunnel_req_t * const req_pP); static int gtpv1u_eNB_init(void); @@ -322,17 +327,14 @@ NwGtpv1uRcT gtpv1u_eNB_process_stack_req( #endif #warning "LG eps bearer mapping to DRB id to do (offset -4)" - ctxt.enb_module_id = gtpv1u_teid_data_p->enb_id; - ctxt.ue_module_id = gtpv1u_teid_data_p->ue_id; - ctxt.frame = 0; - ctxt.enb_flag = ENB_FLAG_YES; + PROTOCOL_CTXT_SET_BY_MODULE_ID(&ctxt, gtpv1u_teid_data_p->enb_id, ENB_FLAG_YES, gtpv1u_teid_data_p->ue_id, 0, 0); result = pdcp_data_req( &ctxt, SRB_FLAG_NO, (gtpv1u_teid_data_p->eps_bearer_id) ? gtpv1u_teid_data_p->eps_bearer_id - 4: 5-4, 0, // mui - FALSE, // confirm + SDU_CONFIRM_NO, // confirm buffer_len, buffer, PDCP_TRANSMISSION_MODE_DATA); @@ -551,8 +553,8 @@ gtpv1u_initial_req( //----------------------------------------------------------------------------- int gtpv1u_new_data_req( - uint8_t enb_idP, - uint8_t ue_idP, + uint8_t enb_module_idP, + rnti_t ue_rntiP, uint8_t rab_idP, uint8_t *buffer_pP, uint32_t buf_lenP, @@ -569,18 +571,18 @@ gtpv1u_new_data_req( gtpv1u_data_t *gtpv1u_data_p = NULL; memset(&ue, 0, sizeof(struct gtpv1u_ue_data_s)); - ue.ue_id = ue_idP; + ue.ue_id = ue_rntiP; - AssertFatal(enb_idP >=0, "Bad parameter enb module id %u\n", enb_idP); + AssertFatal(enb_module_idP >=0, "Bad parameter enb module id %u\n", enb_module_idP); AssertFatal((rab_idP - GTPV1U_BEARER_OFFSET)< GTPV1U_MAX_BEARERS_ID, "Bad parameter rab id %u\n", rab_idP); AssertFatal((rab_idP - GTPV1U_BEARER_OFFSET) >= 0 , "Bad parameter rab id %u\n", rab_idP); gtpv1u_data_p = >pv1u_data_g; /* Check that UE context is present in ue map. */ - hash_rc = hashtable_get(gtpv1u_data_p->ue_mapping, (uint64_t)ue_idP, (void**)&ue_inst_p); + hash_rc = hashtable_get(gtpv1u_data_p->ue_mapping, (uint64_t)ue_rntiP, (void**)&ue_inst_p); if (hash_rc == HASH_TABLE_KEY_NOT_EXISTS ) { - LOG_E(GTPU, "[UE %d] Trying to send data on non-existing UE context\n", ue_idP); + LOG_E(GTPU, "[UE %d] Trying to send data on non-existing UE context\n", ue_rntiP); return -1; } @@ -643,7 +645,8 @@ gtpv1u_new_data_req( //----------------------------------------------------------------------------- static int gtpv1u_create_s1u_tunnel( - gtpv1u_enb_create_tunnel_req_t *create_tunnel_req_pP) + const instance_t instanceP, + const gtpv1u_enb_create_tunnel_req_t * const create_tunnel_req_pP) { /* Create a new nw-gtpv1-u stack req using API */ NwGtpv1uUlpApiT stack_req; @@ -662,15 +665,15 @@ gtpv1u_create_s1u_tunnel( int addrs_length_in_bytes= 0; message_p = itti_alloc_new_message(TASK_GTPV1_U, GTPV1U_ENB_CREATE_TUNNEL_RESP); - GTPV1U_ENB_CREATE_TUNNEL_RESP(message_p).ue_index = create_tunnel_req_pP->ue_index; + GTPV1U_ENB_CREATE_TUNNEL_RESP(message_p).rnti = create_tunnel_req_pP->rnti; GTPV1U_ENB_CREATE_TUNNEL_RESP(message_p).status = 0; GTPV1U_ENB_CREATE_TUNNEL_RESP(message_p).num_tunnels = 0; for (i = 0; i < create_tunnel_req_pP->num_tunnels; i++) { ip_offset = 0; eps_bearer_id = create_tunnel_req_pP->eps_bearer_id[i]; - LOG_D(GTPU, "Rx GTPV1U_ENB_CREATE_TUNNEL_REQ ue_index %u eps bearer id %u\n", - create_tunnel_req_pP->ue_index, eps_bearer_id); + LOG_D(GTPU, "Rx GTPV1U_ENB_CREATE_TUNNEL_REQ ue rnti %x eps bearer id %u\n", + create_tunnel_req_pP->rnti, eps_bearer_id); memset(&stack_req, 0, sizeof(NwGtpv1uUlpApiT)); stack_req.apiType = NW_GTPV1U_ULP_API_CREATE_TUNNEL_ENDPOINT; @@ -689,17 +692,17 @@ gtpv1u_create_s1u_tunnel( //----------------------- // PDCP->GTPV1U mapping //----------------------- - hash_rc = hashtable_get(gtpv1u_data_g.ue_mapping, create_tunnel_req_pP->ue_index, (void **)>pv1u_ue_data_p); + hash_rc = hashtable_get(gtpv1u_data_g.ue_mapping, create_tunnel_req_pP->rnti, (void **)>pv1u_ue_data_p); if ((hash_rc == HASH_TABLE_KEY_NOT_EXISTS) || (hash_rc == HASH_TABLE_OK)) { if (hash_rc == HASH_TABLE_KEY_NOT_EXISTS) { gtpv1u_ue_data_p = calloc (1, sizeof(gtpv1u_ue_data_t)); - hash_rc = hashtable_insert(gtpv1u_data_g.ue_mapping, create_tunnel_req_pP->ue_index, gtpv1u_ue_data_p); + hash_rc = hashtable_insert(gtpv1u_data_g.ue_mapping, create_tunnel_req_pP->rnti, gtpv1u_ue_data_p); AssertFatal(hash_rc == HASH_TABLE_OK, "Error inserting ue_mapping in GTPV1U hashtable"); } - gtpv1u_ue_data_p->ue_id = create_tunnel_req_pP->ue_index; + gtpv1u_ue_data_p->ue_id = create_tunnel_req_pP->rnti; gtpv1u_ue_data_p->instance_id = 0; // TO DO memcpy(>PV1U_ENB_CREATE_TUNNEL_RESP(message_p).enb_addr.buffer, >pv1u_data_g.enb_ip_address_for_S1u_S12_S4_up, @@ -748,7 +751,7 @@ gtpv1u_create_s1u_tunnel( if (hash_rc == HASH_TABLE_KEY_NOT_EXISTS) { gtpv1u_teid_data_p = calloc (1, sizeof(gtpv1u_teid_data_t)); gtpv1u_teid_data_p->enb_id = 0; // TO DO - gtpv1u_teid_data_p->ue_id = create_tunnel_req_pP->ue_index; + gtpv1u_teid_data_p->ue_id = create_tunnel_req_pP->rnti; gtpv1u_teid_data_p->eps_bearer_id = eps_bearer_id; hash_rc = hashtable_insert(gtpv1u_data_g.teid_mapping, s1u_teid, gtpv1u_teid_data_p); AssertFatal(hash_rc == HASH_TABLE_OK, "Error inserting teid mapping in GTPV1U hashtable"); @@ -758,16 +761,18 @@ gtpv1u_create_s1u_tunnel( } } - LOG_D(GTPU, "Tx GTPV1U_ENB_CREATE_TUNNEL_RESP ue_index %u status %d\n", - create_tunnel_req_pP->ue_index, + LOG_D(GTPU, "Tx GTPV1U_ENB_CREATE_TUNNEL_RESP ue rnti %x status %d\n", + create_tunnel_req_pP->rnti, GTPV1U_ENB_CREATE_TUNNEL_RESP(message_p).status); - return itti_send_msg_to_task(TASK_RRC_ENB, INSTANCE_DEFAULT, message_p); + return itti_send_msg_to_task(TASK_RRC_ENB, instanceP, message_p); } //----------------------------------------------------------------------------- -static int gtpv1u_delete_s1u_tunnel(gtpv1u_enb_delete_tunnel_req_t *req_pP) +static int gtpv1u_delete_s1u_tunnel( + const instance_t instanceP, + const gtpv1u_enb_delete_tunnel_req_t * const req_pP) { NwGtpv1uUlpApiT stack_req; NwGtpv1uRcT rc = NW_GTPV1U_FAILURE; @@ -779,18 +784,18 @@ static int gtpv1u_delete_s1u_tunnel(gtpv1u_enb_delete_tunnel_req_t *req_pP) message_p = itti_alloc_new_message(TASK_GTPV1_U, GTPV1U_ENB_DELETE_TUNNEL_RESP); - GTPV1U_ENB_DELETE_TUNNEL_RESP(message_p).ue_index = req_pP->ue_index; + GTPV1U_ENB_DELETE_TUNNEL_RESP(message_p).rnti = req_pP->rnti; GTPV1U_ENB_DELETE_TUNNEL_RESP(message_p).status = 0; - hash_rc = hashtable_get(gtpv1u_data_g.ue_mapping, req_pP->ue_index, (void**)>pv1u_ue_data_p); + hash_rc = hashtable_get(gtpv1u_data_g.ue_mapping, req_pP->rnti, (void**)>pv1u_ue_data_p); if (hash_rc == HASH_TABLE_OK) { for (erab_index = 0; erab_index < req_pP->num_erab; erab_index++) { teid_eNB = gtpv1u_ue_data_p->bearers[req_pP->eps_bearer_id[erab_index] - GTPV1U_BEARER_OFFSET].teid_eNB; - LOG_D(GTPU, "Rx GTPV1U_ENB_DELETE_TUNNEL user index %u eNB S1U teid %u eps bearer id %u\n", - req_pP->ue_index, teid_eNB, req_pP->eps_bearer_id[erab_index]); + LOG_D(GTPU, "Rx GTPV1U_ENB_DELETE_TUNNEL user rnti %x eNB S1U teid %u eps bearer id %u\n", + req_pP->rnti, teid_eNB, req_pP->eps_bearer_id[erab_index]); { memset(&stack_req, 0, sizeof(NwGtpv1uUlpApiT)); @@ -821,8 +826,8 @@ static int gtpv1u_delete_s1u_tunnel(gtpv1u_enb_delete_tunnel_req_t *req_pP) gtpv1u_ue_data_p->num_bearers -= 1; if (gtpv1u_ue_data_p->num_bearers == 0) { - hash_rc = hashtable_remove(gtpv1u_data_g.ue_mapping, req_pP->ue_index); - LOG_D(GTPU, "Removed user index %u,no more bearers configured\n", req_pP->ue_index); + hash_rc = hashtable_remove(gtpv1u_data_g.ue_mapping, req_pP->rnti); + LOG_D(GTPU, "Removed user rnti %x,no more bearers configured\n", req_pP->rnti); } //----------------------- @@ -831,17 +836,17 @@ static int gtpv1u_delete_s1u_tunnel(gtpv1u_enb_delete_tunnel_req_t *req_pP) hash_rc = hashtable_remove(gtpv1u_data_g.teid_mapping, teid_eNB); if (hash_rc != HASH_TABLE_OK) { - LOG_D(GTPU, "Removed user index %u , enb S1U teid %u not found\n", req_pP->ue_index, teid_eNB); + LOG_D(GTPU, "Removed user rnti %x , enb S1U teid %u not found\n", req_pP->rnti, teid_eNB); } } }// else silently do nothing - LOG_D(GTPU, "Tx GTPV1U_ENB_DELETE_TUNNEL_RESP user index %u eNB S1U teid %u status %u\n", - GTPV1U_ENB_DELETE_TUNNEL_RESP(message_p).ue_index, + LOG_D(GTPU, "Tx GTPV1U_ENB_DELETE_TUNNEL_RESP user rnti %x eNB S1U teid %u status %u\n", + GTPV1U_ENB_DELETE_TUNNEL_RESP(message_p).rnti, GTPV1U_ENB_DELETE_TUNNEL_RESP(message_p).enb_S1u_teid, GTPV1U_ENB_DELETE_TUNNEL_RESP(message_p).status); - return itti_send_msg_to_task(TASK_RRC_ENB, INSTANCE_DEFAULT, message_p); + return itti_send_msg_to_task(TASK_RRC_ENB, instanceP, message_p); } //----------------------------------------------------------------------------- @@ -947,7 +952,10 @@ static int gtpv1u_eNB_init(void) //----------------------------------------------------------------------------- void *gtpv1u_eNB_task(void *args) { - int rc = 0; + int rc = 0; + instance_t instance; + const char *msg_name_p; + rc = gtpv1u_eNB_init(); AssertFatal(rc == 0, "gtpv1u_eNB_init Failed"); itti_mark_task_ready(TASK_GTPV1_U); @@ -962,14 +970,17 @@ void *gtpv1u_eNB_task(void *args) vcd_signal_dumper_dump_function_by_name(VCD_SIGNAL_DUMPER_FUNCTIONS_GTPV1U_ENB_TASK, VCD_FUNCTION_IN); DevAssert(received_message_p != NULL); + instance = ITTI_MSG_INSTANCE(received_message_p); + msg_name_p = ITTI_MSG_NAME(received_message_p); + switch (ITTI_MSG_ID(received_message_p)) { case GTPV1U_ENB_CREATE_TUNNEL_REQ: { - gtpv1u_create_s1u_tunnel(&received_message_p->ittiMsg.Gtpv1uCreateTunnelReq); + gtpv1u_create_s1u_tunnel(instance, &received_message_p->ittiMsg.Gtpv1uCreateTunnelReq); } break; case GTPV1U_ENB_DELETE_TUNNEL_REQ: { - gtpv1u_delete_s1u_tunnel(&received_message_p->ittiMsg.Gtpv1uDeleteTunnelReq); + gtpv1u_delete_s1u_tunnel(instance, &received_message_p->ittiMsg.Gtpv1uDeleteTunnelReq); } break; @@ -989,7 +1000,7 @@ void *gtpv1u_eNB_task(void *args) // DATA TO BE SENT TO UDP case GTPV1U_ENB_TUNNEL_DATA_REQ: { gtpv1u_enb_tunnel_data_req_t *data_req_p = NULL; - NwGtpv1uUlpApiT stack_req; + NwGtpv1uUlpApiT stack_req; NwGtpv1uRcT rc = NW_GTPV1U_FAILURE; hashtable_rc_t hash_rc = HASH_TABLE_KEY_NOT_EXISTS; gtpv1u_ue_data_t *gtpv1u_ue_data_p = NULL; @@ -1005,10 +1016,10 @@ void *gtpv1u_eNB_task(void *args) #endif memset(&stack_req, 0, sizeof(NwGtpv1uUlpApiT)); - hash_rc = hashtable_get(gtpv1u_data_g.ue_mapping, (uint64_t)data_req_p->ue_index, (void**)>pv1u_ue_data_p); + hash_rc = hashtable_get(gtpv1u_data_g.ue_mapping, (uint64_t)data_req_p->rnti, (void**)>pv1u_ue_data_p); if (hash_rc == HASH_TABLE_KEY_NOT_EXISTS) { - LOG_E(GTPU, "nwGtpv1uProcessUlpReq failed: while getting ue_index %u in hashtable ue_mapping\n", data_req_p->ue_index); + LOG_E(GTPU, "nwGtpv1uProcessUlpReq failed: while getting ue rnti %x in hashtable ue_mapping\n", data_req_p->rnti); } else { if ((data_req_p->rab_id >= GTPV1U_BEARER_OFFSET) && (data_req_p->rab_id <= max_val_DRB_Identity)) { enb_s1u_teid = gtpv1u_ue_data_p->bearers[data_req_p->rab_id - GTPV1U_BEARER_OFFSET].teid_eNB; diff --git a/openair-cn/GTPV1-U/gtpv1u_eNB_defs.h b/openair-cn/GTPV1-U/gtpv1u_eNB_defs.h index 81dc1b3dc..454f4effc 100644 --- a/openair-cn/GTPV1-U/gtpv1u_eNB_defs.h +++ b/openair-cn/GTPV1-U/gtpv1u_eNB_defs.h @@ -58,7 +58,7 @@ typedef enum { typedef struct gtpv1u_teid_data_s { /* UE identifier for oaisim stack */ module_id_t enb_id; - module_id_t ue_id; + rnti_t ue_id; ebi_t eps_bearer_id; } gtpv1u_teid_data_t; @@ -76,7 +76,7 @@ typedef struct gtpv1u_bearer_s { typedef struct gtpv1u_ue_data_s { /* UE identifier for oaisim stack */ - module_id_t ue_id; + rnti_t ue_id; /* Unique identifier used between PDCP and GTP-U to distinguish UEs */ uint32_t instance_id; @@ -121,12 +121,13 @@ typedef struct gtpv1u_data_s { int gtpv1u_new_data_req( - uint8_t enb_id, - uint8_t ue_id, - uint8_t rab_id, - uint8_t *buffer, - uint32_t buf_len, - uint32_t buf_offset); + uint8_t enb_module_idP, + rnti_t ue_rntiP, + uint8_t rab_idP, + uint8_t *buffer_pP, + uint32_t buf_lenP, + uint32_t buf_offsetP +); int gtpv1u_initial_req( diff --git a/openair-cn/GTPV1-U/gtpv1u_task.c b/openair-cn/GTPV1-U/gtpv1u_task.c index 898206582..6acdeaa94 100644 --- a/openair-cn/GTPV1-U/gtpv1u_task.c +++ b/openair-cn/GTPV1-U/gtpv1u_task.c @@ -54,7 +54,9 @@ //static NwGtpv1uStackHandleT gtpv1u_stack = 0; static gtpv1u_data_t gtpv1u_sgw_data; +#if !defined(ENABLE_USE_GTPU_IN_KERNEL) static int gtpv1u_send_init_udp(uint16_t port_number); +#endif static int gtpv1u_create_s1u_tunnel(Gtpv1uCreateTunnelReq *create_tunnel_reqP); static int gtpv1u_delete_s1u_tunnel(Teid_t context_teidP, Teid_t S1U_teidP); static int gtpv1u_update_s1u_tunnel(Gtpv1uUpdateTunnelReq *reqP); @@ -147,6 +149,7 @@ void gtpu_print_hex_octets(unsigned char* dataP, unsigned long sizeP) } +#if !defined(ENABLE_USE_GTPU_IN_KERNEL) static int gtpv1u_send_init_udp(uint16_t port_number) { // Create and alloc new message @@ -168,6 +171,7 @@ static int gtpv1u_send_init_udp(uint16_t port_number) return itti_send_msg_to_task(TASK_UDP, INSTANCE_DEFAULT, message_p); } +#endif NwGtpv1uRcT gtpv1u_log_request(NwGtpv1uLogMgrHandleT hLogMgr, NwU32T logLevel, @@ -179,6 +183,7 @@ NwGtpv1uRcT gtpv1u_log_request(NwGtpv1uLogMgrHandleT hLogMgr, return NW_GTPV1U_OK; } +#if !defined(ENABLE_USE_GTPU_IN_KERNEL) NwGtpv1uRcT gtpv1u_send_udp_msg( NwGtpv1uUdpHandleT udpHandle, NwU8T *buffer, @@ -203,7 +208,7 @@ NwGtpv1uRcT gtpv1u_send_udp_msg( return itti_send_msg_to_task(TASK_UDP, INSTANCE_DEFAULT, message_p); } - +#endif /* Callback called when a gtpv1u message arrived on UDP interface */ NwGtpv1uRcT gtpv1u_process_stack_req( NwGtpv1uUlpHandleT hUlp, diff --git a/openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1uMsg.c b/openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1uMsg.c index a42da2517..ce3a8ae1b 100644 --- a/openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1uMsg.c +++ b/openair-cn/GTPV1-U/nw-gtpv1u/src/NwGtpv1uMsg.c @@ -128,6 +128,7 @@ nwGtpv1uGpduMsgNew( NW_IN NwGtpv1uStackHandleT hGtpuStackHandle, { NwGtpv1uStackT *pStack = (NwGtpv1uStackT *) hGtpuStackHandle; NwGtpv1uMsgT *pMsg; + //NwU32T header_len = 0; NwU32T msgExtraLen = 0; if(gpGtpv1uMsgPool) { diff --git a/openair-cn/MME_APP/mme_app_authentication.c b/openair-cn/MME_APP/mme_app_authentication.c index 45f9d341b..80e39658b 100644 --- a/openair-cn/MME_APP/mme_app_authentication.c +++ b/openair-cn/MME_APP/mme_app_authentication.c @@ -45,19 +45,20 @@ #include "assertions.h" static -int mme_app_request_authentication_info(const mme_app_imsi_t imsi, +int mme_app_request_authentication_info(const char *imsi, const uint8_t nb_of_vectors, const plmn_t *plmn, const uint8_t *auts); static -int mme_app_request_authentication_info(const mme_app_imsi_t imsi, +int mme_app_request_authentication_info(const char *imsi, const uint8_t nb_of_vectors, const plmn_t *plmn, const uint8_t *auts) { s6a_auth_info_req_t *auth_info_req = NULL; MessageDef *message_p = NULL; + int imsi_length = strlen(imsi); DevAssert(plmn != NULL); @@ -66,7 +67,9 @@ int mme_app_request_authentication_info(const mme_app_imsi_t imsi, auth_info_req = &message_p->ittiMsg.s6a_auth_info_req; memset(auth_info_req, 0, sizeof(*auth_info_req)); - auth_info_req->imsi_length = MME_APP_IMSI_TO_STRING(imsi, auth_info_req->imsi); + strncpy(auth_info_req->imsi, imsi, imsi_length); + auth_info_req->imsi_length = imsi_length; + //MME_APP_IMSI_TO_STRING(imsi, auth_info_req->imsi); memcpy(&auth_info_req->visited_plmn, plmn, sizeof(plmn_t)); MME_APP_DEBUG("%s visited_plmn MCC %X%X%X MNC %X%X%X\n", @@ -214,122 +217,7 @@ mme_app_handle_authentication_info_answer( return 0; } -#if defined(DISABLE_USE_NAS) -int mme_app_handle_attach_req(nas_attach_req_t *attach_req_p) -{ - /* An attach request has been received from NAS layer. - * If the UE authentication vectors for the UE are known within MME then the - * authentication procedure should be triggered only if the request is an - * initial attach, otherwise an update location should be sent to the HSS - * and default bearer should be established for the provided APN. - * In case of initial attach procedure, the default APN retrieved from the - * HSS will be used to establish the default bearer within EPC. - * The default APN is the one that matches the context-identifier - */ - struct ue_context_s *ue_context; - uint64_t imsi = 0; - - DevAssert(attach_req_p != NULL); - - MME_APP_STRING_TO_IMSI((char *)attach_req_p->imsi, &imsi); - - MME_APP_DEBUG("Handling imsi %"IMSI_FORMAT"\n", imsi); - - ue_context = mme_ue_context_exists_imsi(&mme_app_desc.mme_ue_contexts, imsi); - - if (ue_context == NULL) { - /* The MME doesn't know this IMSI. - * Insert the UE to the list of known equipements and - * Retrieve the authentication vector from HSS. - */ - MME_APP_DEBUG("UE context doesn't exist -> create one\n"); - - if ((ue_context = mme_create_new_ue_context()) == NULL) { - /* Error during ue context malloc */ - /* TODO */ - DevMessage("mme_create_new_ue_context"); - return -1; - } - ue_context->imsi = imsi; - - ue_context->eNB_ue_s1ap_id = attach_req_p->transparent.eNB_ue_s1ap_id; - ue_context->mme_ue_s1ap_id = attach_req_p->transparent.mme_ue_s1ap_id; - ue_context->ue_id = attach_req_p->transparent.mme_ue_s1ap_id; - - // STAILQ_INIT(&ue_context->vector_list); - DevAssert(mme_insert_ue_context(&mme_app_desc.mme_ue_contexts, ue_context) == 0); - goto request_auth; - } else { - /* MME knows this IMSI, check if UE is authenticated and authentication - * vectors are known. - */ - MME_APP_DEBUG("UE context already exists, use it\n"); - - /* Update mme ue s1ap id */ - ue_context->mme_ue_s1ap_id = attach_req_p->transparent.mme_ue_s1ap_id; - - if ((ue_context->imsi_auth == IMSI_AUTHENTICATED) && - (attach_req_p->initial != INITIAL_REQUEST)) { - /* We have to send an update location request to the HSS */ - MME_APP_DEBUG("UE is authenticated\n"); - } else { - MME_APP_DEBUG("UE is not authenticated\n"); - - /* UE is not authenticated or an initial request */ - // if (STAILQ_EMPTY(&ue_context->vector_list)) - if (ue_context->nb_of_vectors == 0) -request_auth: { - /* We have no vector for this UE, send an authentication request - * to the HSS. - */ - AssertFatal(0, "Hardcoded MCC/MNC"); - plmn_t plmn = { - .MCCdigit2 = 0, - .MCCdigit1 = 8, - .MCCdigit3 = 2, - .MNCdigit1 = 0, - .MNCdigit2 = 4, - .MNCdigit3 = 3, - }; - - memcpy(&ue_context->e_utran_cgi, &attach_req_p->transparent.e_utran_cgi, - sizeof(cgi_t)); - - /* Acquire the current time */ - time(&ue_context->cell_age); - - /* Some random values for GUTI */ - ue_context->guti.m_tmsi = 0x24568956; - ue_context->guti.gummei.MMEcode = 0x01; - ue_context->guti.gummei.MMEgid = 0x5691; - - memcpy(&ue_context->guti.gummei.plmn, &plmn, sizeof(plmn_t)); - MME_APP_DEBUG("and we have no auth. vector for it, request" - " authentication information\n"); - // mme_app_dump_ue_contexts(); - mme_app_request_authentication_info(imsi, 1, &plmn, NULL); - } else { - nas_auth_req_t *nas_auth_req_p; - MessageDef *message_p; - /* We have a vector... USE it */ - MME_APP_DEBUG("but we have an auth. vector for it, request" - " authentication from NAS\n"); - message_p = itti_alloc_new_message(TASK_MME_APP, NAS_AUTHENTICATION_PARAM_FAIL); - - nas_auth_req_p = &message_p->ittiMsg.nas_auth_req; - - MME_APP_IMSI_TO_STRING(imsi, nas_auth_req_p->imsi); - nas_auth_req_p->failure = NAS_FAILURE_OK; - - return itti_send_msg_to_task(TASK_NAS_MME, INSTANCE_DEFAULT, message_p); - } - } - } - - return 0; -} -#else void mme_app_handle_nas_auth_param_req( const nas_auth_param_req_t * const nas_auth_param_req_pP) @@ -354,13 +242,14 @@ mme_app_handle_nas_auth_param_req( visited_plmn_from_req.MCCdigit2 = nas_auth_param_req_pP->imsi[1]; visited_plmn_from_req.MCCdigit3 = nas_auth_param_req_pP->imsi[2]; - mnc_length = find_mnc_length(nas_auth_param_req_pP->imsi[0], - nas_auth_param_req_pP->imsi[1], - nas_auth_param_req_pP->imsi[2], - nas_auth_param_req_pP->imsi[3], - nas_auth_param_req_pP->imsi[4], - nas_auth_param_req_pP->imsi[5] - ); + mnc_length = find_mnc_length( + nas_auth_param_req_pP->imsi[0], + nas_auth_param_req_pP->imsi[1], + nas_auth_param_req_pP->imsi[2], + nas_auth_param_req_pP->imsi[3], + nas_auth_param_req_pP->imsi[4], + nas_auth_param_req_pP->imsi[5] + ); if (mnc_length == 2) { visited_plmn_from_req.MNCdigit1 = nas_auth_param_req_pP->imsi[3]; @@ -439,11 +328,10 @@ mme_app_handle_nas_auth_param_req( memcpy(&ue_context->guti.gummei.plmn, visited_plmn, sizeof(plmn_t)); MME_APP_DEBUG("and we have no auth. vector for it, request" " authentication information\n"); - mme_app_request_authentication_info(imsi, 1, visited_plmn, NULL); + mme_app_request_authentication_info(nas_auth_param_req_pP->imsi, 1, visited_plmn, NULL); } else { memcpy(&ue_context->guti.gummei.plmn, visited_plmn, sizeof(plmn_t)); - mme_app_request_authentication_info(imsi, 1, visited_plmn, nas_auth_param_req_pP->auts); + mme_app_request_authentication_info(nas_auth_param_req_pP->imsi, 1, visited_plmn, nas_auth_param_req_pP->auts); } } -#endif diff --git a/openair-cn/MME_APP/mme_app_context.c b/openair-cn/MME_APP/mme_app_context.c index 42610aebf..64c5893ae 100644 --- a/openair-cn/MME_APP/mme_app_context.c +++ b/openair-cn/MME_APP/mme_app_context.c @@ -50,8 +50,8 @@ #include "mme_app_ue_context.h" #include "mme_app_defs.h" -static inline int ue_context_compare_identifiers(struct ue_context_s *p1, - struct ue_context_s *p2); +int ue_context_compare_identifiers(struct ue_context_s *p1, + struct ue_context_s *p2); RB_PROTOTYPE(ue_context_map, ue_context_s, rb_entry, ue_context_compare_identifiers); @@ -59,7 +59,7 @@ RB_PROTOTYPE(ue_context_map, ue_context_s, rb_entry, RB_GENERATE(ue_context_map, ue_context_s, rb_entry, ue_context_compare_identifiers); -static inline int ue_context_compare_identifiers( +extern inline int ue_context_compare_identifiers( struct ue_context_s *p1, struct ue_context_s *p2) { MME_APP_DEBUG(" ue_context_compare_identifiers IMSI %"SCNu64"\n", p1->imsi); @@ -68,6 +68,8 @@ static inline int ue_context_compare_identifiers( MME_APP_DEBUG(" ue_context_compare_identifiers ue_id %08x\n" , p1->ue_id); if (p1->imsi > 0) { + MME_APP_DEBUG(" with IMSI %"SCNu64"\n", p2->imsi); + /* if IMSI provided */ if (p1->imsi > p2->imsi) { return 1; @@ -77,6 +79,8 @@ static inline int ue_context_compare_identifiers( return -1; } } else if (p1->mme_s11_teid > 0) { + MME_APP_DEBUG(" with mme_s11_teid %08x\n", p2->mme_s11_teid); + /* if s11 teid provided */ if (p1->mme_s11_teid > p2->mme_s11_teid) { return 1; @@ -86,7 +90,7 @@ static inline int ue_context_compare_identifiers( return -1; } } else if (p1->mme_ue_s1ap_id > 0) { - MME_APP_DEBUG(" with mme_ue_s1ap_id %d\n" , p2->mme_ue_s1ap_id); + MME_APP_DEBUG(" with mme_ue_s1ap_id %08x\n", p2->mme_ue_s1ap_id); /* if s1ap ue id provided */ if (p1->mme_ue_s1ap_id > p2->mme_ue_s1ap_id) { @@ -97,6 +101,8 @@ static inline int ue_context_compare_identifiers( return -1; } } else if (p1->ue_id > 0) { + MME_APP_DEBUG(" with ue_id %08x\n", p2->ue_id); + /* if nas ue_id provided */ if (p1->ue_id > p2->ue_id) { return 1; @@ -152,7 +158,7 @@ ue_context_t *mme_create_new_ue_context(void) return new_p; } -inline + struct ue_context_s *mme_ue_context_exists_imsi(mme_ue_context_t *mme_ue_context, mme_app_imsi_t imsi) { @@ -166,7 +172,7 @@ struct ue_context_s *mme_ue_context_exists_imsi(mme_ue_context_t *mme_ue_context &reference); } -inline + struct ue_context_s *mme_ue_context_exists_s11_teid(mme_ue_context_t *mme_ue_context, uint32_t teid) { @@ -180,7 +186,8 @@ struct ue_context_s *mme_ue_context_exists_s11_teid(mme_ue_context_t *mme_ue_con &reference); } -inline + + ue_context_t *mme_ue_context_exists_mme_ue_s1ap_id( mme_ue_context_t *mme_ue_context, uint32_t mme_ue_s1ap_id) @@ -195,7 +202,8 @@ ue_context_t *mme_ue_context_exists_mme_ue_s1ap_id( &reference); } -inline + + ue_context_t *mme_ue_context_exists_nas_ue_id( mme_ue_context_t *mme_ue_context, uint32_t nas_ue_id) @@ -211,7 +219,8 @@ ue_context_t *mme_ue_context_exists_nas_ue_id( } -inline + + ue_context_t *mme_ue_context_exists_guti(mme_ue_context_t *mme_ue_context, GUTI_t guti) { diff --git a/openair-cn/MME_APP/mme_app_ue_context.h b/openair-cn/MME_APP/mme_app_ue_context.h index 594b7e082..682c196b3 100644 --- a/openair-cn/MME_APP/mme_app_ue_context.h +++ b/openair-cn/MME_APP/mme_app_ue_context.h @@ -200,7 +200,6 @@ typedef struct { * \param imsi Imsi to find in UE map * @returns an UE context matching the IMSI or NULL if the context doesn't exists **/ -inline ue_context_t *mme_ue_context_exists_imsi(mme_ue_context_t *mme_ue_context, mme_app_imsi_t imsi); @@ -208,7 +207,6 @@ ue_context_t *mme_ue_context_exists_imsi(mme_ue_context_t *mme_ue_context, * \param teid The tunnel endpoint identifier used between MME and S-GW * @returns an UE context matching the teid or NULL if the context doesn't exists **/ -inline ue_context_t *mme_ue_context_exists_s11_teid(mme_ue_context_t *mme_ue_context, uint32_t teid); @@ -216,7 +214,6 @@ ue_context_t *mme_ue_context_exists_s11_teid(mme_ue_context_t *mme_ue_context, * \param mme_ue_s1ap_id The UE id identifier used in S1AP MME (and NAS) * @returns an UE context matching the mme_ue_s1ap_id or NULL if the context doesn't exists **/ -inline ue_context_t *mme_ue_context_exists_mme_ue_s1ap_id(mme_ue_context_t *mme_ue_context, uint32_t mme_ue_s1ap_id); @@ -224,7 +221,6 @@ ue_context_t *mme_ue_context_exists_mme_ue_s1ap_id(mme_ue_context_t *mme_ue_cont * \param nas_ue_id The UE id identifier used in S1AP MME and NAS * @returns an UE context matching the nas_ue_id or NULL if the context doesn't exists **/ -inline ue_context_t *mme_ue_context_exists_nas_ue_id(mme_ue_context_t *mme_ue_context, uint32_t nas_ue_id); @@ -232,7 +228,6 @@ ue_context_t *mme_ue_context_exists_nas_ue_id(mme_ue_context_t *mme_ue_context, * \param guti The GUTI used by the UE * @returns an UE context matching the guti or NULL if the context doesn't exists **/ -inline ue_context_t *mme_ue_context_exists_guti(mme_ue_context_t *mme_ue_context, GUTI_t guti); diff --git a/openair-cn/NAS/EURECOM-NAS/src/api/mme/mme_api.c b/openair-cn/NAS/EURECOM-NAS/src/api/mme/mme_api.c index 524fad6f9..dd0ff9c2f 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/api/mme/mme_api.c +++ b/openair-cn/NAS/EURECOM-NAS/src/api/mme/mme_api.c @@ -251,14 +251,14 @@ static int _mme_api_pdn_id = 0; ** Others: None ** ** ** ***************************************************************************/ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) int mme_api_get_emm_config(mme_api_emm_config_t *config, mme_config_t *mme_config_p) #else int mme_api_get_emm_config(mme_api_emm_config_t *config) #endif { -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) int i; #endif LOG_FUNC_IN; @@ -285,7 +285,7 @@ int mme_api_get_emm_config(mme_api_emm_config_t *config) config->gummei.MMEgid = mme_config_p->gummei.mme_gid[0]; config->gummei.MMEcode = mme_config_p->gummei.mmec[0]; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) /* SR: this config param comes from MME global config */ if (mme_config_p->emergency_attach_supported != 0) { diff --git a/openair-cn/NAS/EURECOM-NAS/src/api/mme/mme_api.h b/openair-cn/NAS/EURECOM-NAS/src/api/mme/mme_api.h index b3661da25..dc3a603fc 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/api/mme/mme_api.h +++ b/openair-cn/NAS/EURECOM-NAS/src/api/mme/mme_api.h @@ -47,7 +47,7 @@ Description Implements the API used by the NAS layer running in the MME #define __MME_API_H__ #ifdef NAS_MME -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) # include "mme_config.h" # endif #include "commonDef.h" @@ -127,7 +127,7 @@ typedef struct mme_api_tft_s { /****************** E X P O R T E D F U N C T I O N S ******************/ /****************************************************************************/ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) int mme_api_get_emm_config(mme_api_emm_config_t *config, mme_config_t *mme_config_p); #else diff --git a/openair-cn/NAS/EURECOM-NAS/src/api/network/nas_message.c b/openair-cn/NAS/EURECOM-NAS/src/api/network/nas_message.c index 6eb304727..22fc6dbe1 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/api/network/nas_message.c +++ b/openair-cn/NAS/EURECOM-NAS/src/api/network/nas_message.c @@ -54,7 +54,7 @@ Description Defines the layer 3 messages supported by the NAS sublayer #include <stdlib.h> // malloc, free #include <string.h> // memcpy -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) # include "nas_itti_messaging.h" #endif #include "secu_defs.h" @@ -313,7 +313,6 @@ int nas_message_decrypt( #endif emm_security_context); - /* Check NAS message integrity */ if (mac != header->message_authentication_code) { LOG_TRACE(DEBUG, @@ -425,6 +424,24 @@ int nas_message_decode( emm_security_context ); +#define NAS_CODE_TO_BE_MODIFIED 1 +#ifdef NAS_CODE_TO_BE_MODIFIED + + // According to 3GPP TS 24.301 version 10.15.0 Release 10, 4.4.4.3 Integrity checking of NAS signalling messages in the MME + if ((!emm_security_context) && (mac == 0) && (msg->header.message_authentication_code != 0)) { + // force mac to be the same, but we should check for message types. + // TODO Reverse order of processing in NAS code: decode message type then check MAC + LOG_TRACE(DEBUG, + "Forced computed MAC to be the MSG MAC %04x", + msg->header.message_authentication_code); + mac = msg->header.message_authentication_code; + LOG_TRACE(DEBUG, + "Forced computed MAC to be the same as MAC in message %04x", + msg->header.message_authentication_code); + } + +#endif + /* Check NAS message integrity */ if (mac != msg->header.message_authentication_code) { LOG_TRACE(DEBUG, @@ -434,7 +451,7 @@ int nas_message_decode( LOG_FUNC_RETURN (TLV_DECODE_MAC_MISMATCH); } -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) /* Log message header */ #endif @@ -566,7 +583,7 @@ int nas_message_encode( } } -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) /* Log message header */ #endif } else { @@ -970,7 +987,9 @@ static int _nas_message_decrypt( "No decryption of message length %u according to security header type 0x%02x", length, security_header_type); memcpy(dest, src, length); - LOG_FUNC_RETURN (length); + DECODE_U8(dest, *(UInt8_t*)(&header), size); + LOG_FUNC_RETURN (header.protocol_discriminator); + //LOG_FUNC_RETURN (length); break; case SECURITY_HEADER_TYPE_INTEGRITY_PROTECTED_CYPHERED: @@ -1268,7 +1287,7 @@ static UInt32_t _nas_message_get_mac( if (!emm_security_context) { LOG_TRACE(DEBUG, "No security context set for integrity protection algorithm"); -#if defined(EPC_BUILD) || defined(UE_BUILD) +#if defined(NAS_BUILT_IN_EPC) || defined(NAS_BUILT_IN_UE) LOG_FUNC_RETURN (0); #else LOG_FUNC_RETURN (0xabababab); @@ -1398,7 +1417,7 @@ static UInt32_t _nas_message_get_mac( (direction == SECU_DIRECTION_UPLINK) ? emm_security_context->ul_count.seq_num:emm_security_context->dl_count.seq_num ); -#if defined(EPC_BUILD) || defined(UE_BUILD) +#if defined(NAS_BUILT_IN_EPC) || defined(NAS_BUILT_IN_UE) LOG_FUNC_RETURN (0); #else LOG_FUNC_RETURN (0xabababab); diff --git a/openair-cn/NAS/EURECOM-NAS/src/api/network/nas_message.h b/openair-cn/NAS/EURECOM-NAS/src/api/network/nas_message.h index 08b579ad2..d7d09f114 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/api/network/nas_message.h +++ b/openair-cn/NAS/EURECOM-NAS/src/api/network/nas_message.h @@ -49,7 +49,7 @@ Description Defines the layer 3 messages supported by the NAS sublayer #include "commonDef.h" #include "emm_msg.h" -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) #include "emmData.h" #endif #include "esm_msg.h" diff --git a/openair-cn/NAS/EURECOM-NAS/src/api/user/at_response.c b/openair-cn/NAS/EURECOM-NAS/src/api/user/at_response.c index 905eb274f..7d067d1cf 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/api/user/at_response.c +++ b/openair-cn/NAS/EURECOM-NAS/src/api/user/at_response.c @@ -1084,7 +1084,7 @@ static int _at_response_encode_cgpaddr(char* buffer, const at_response_t* data) if (cgpaddr->PDP_addr_2[i] != NULL) { /* IPv6 Link-local address prefixe */ offset += sprintf(buffer+offset, - ",%u.%u.%u.%u.%u.%u.%u.%u", + ",%hhu.%hhu.%hhu.%hhu.%hhu.%hhu.%hhu.%hhu", 0xfe, 0x80, 0, 0, 0, 0, 0, 0); /* IPv6 Link-local address */ offset += sprintf(buffer+offset, diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/Attach.c b/openair-cn/NAS/EURECOM-NAS/src/emm/Attach.c index a481fcc91..cea194584 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/Attach.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/Attach.c @@ -76,7 +76,7 @@ Description Defines the attach related EMM procedure executed by the #ifdef NAS_MME #include "mme_api.h" #include "mme_config.h" -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) # include "nas_itti_messaging.h" # endif #endif @@ -1075,13 +1075,18 @@ int emm_proc_attach_set_detach(void) ** Others: _emm_data ** ** ** ***************************************************************************/ -int emm_proc_attach_request(unsigned int ueid, emm_proc_attach_type_t type, - int native_ksi, int ksi, int native_guti, - GUTI_t *guti, imsi_t *imsi, imei_t *imei, - tai_t *tai, - int eea, int eia, int ucs2, int uea, int uia, int gea, - int umts_present, int gprs_present, - const OctetString *esm_msg) +int emm_proc_attach_request( + unsigned int ueid, + emm_proc_attach_type_t type, + int native_ksi, int ksi, + int native_guti, + GUTI_t *guti, + imsi_t *imsi, + imei_t *imei, + tai_t *tai, + int eea, int eia, int ucs2, int uea, int uia, int gea, + int umts_present, int gprs_present, + const OctetString *esm_msg) { LOG_FUNC_IN; @@ -1098,7 +1103,7 @@ int emm_proc_attach_request(unsigned int ueid, emm_proc_attach_type_t type, ue_ctx.is_dynamic = FALSE; ue_ctx.ueid = ueid; -#if !defined(EPC_BUILD) +#if !defined(NAS_BUILT_IN_EPC) /* UE identifier sanity check */ if (ueid >= EMM_DATA_NB_UE_MAX) { @@ -1126,7 +1131,7 @@ int emm_proc_attach_request(unsigned int ueid, emm_proc_attach_type_t type, /* Get the UE's EMM context if it exists */ emm_data_context_t **emm_ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_data_context_t *temp = NULL; temp = emm_data_context_get(&_emm_data, ueid); @@ -1197,7 +1202,7 @@ int emm_proc_attach_request(unsigned int ueid, emm_proc_attach_type_t type, (*emm_ctx)->ueid = ueid; emm_fsm_set_status(ueid, *emm_ctx, EMM_DEREGISTERED); -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_data_context_add(&_emm_data, *(emm_ctx)); #endif @@ -1265,7 +1270,7 @@ int emm_proc_attach_reject(unsigned int ueid, int emm_cause) ue_ctx.ueid = ueid; /* Update the EMM cause code */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) #else @@ -1333,7 +1338,7 @@ int emm_proc_attach_complete(unsigned int ueid, const OctetString *esm_msg) /* Get the UE context */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, ueid); @@ -1670,7 +1675,7 @@ static void *_emm_attach_t3450_handler(void *args) /* Get the UE's EMM context */ emm_data_context_t *emm_ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, data->ueid); #else emm_ctx = _emm_data.ctx[data->ueid]; @@ -1768,7 +1773,7 @@ static int _emm_attach_release(void *args) } /* Release the EMM context */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_data_context_remove(&_emm_data, emm_ctx); #else free(_emm_data.ctx[ueid]); @@ -1903,7 +1908,7 @@ static int _emm_attach_abort(void *args) free(data); -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) ctx = emm_data_context_get(&_emm_data, ueid); #else ctx = _emm_data.ctx[ueid]; @@ -1979,7 +1984,7 @@ static int _emm_attach_identify(void *args) */ if (emm_ctx->imsi) { /* The UE identifies itself using an IMSI */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (!emm_ctx->security) { /* Ask upper layer to fetch new security context */ nas_itti_auth_info_req(emm_ctx->ueid, emm_ctx->imsi, 1, NULL); @@ -2096,7 +2101,7 @@ static int _emm_attach_identify(void *args) rc = _emm_attach_security(emm_ctx); } -#if !defined(EPC_BUILD) +#if !defined(NAS_BUILT_IN_EPC) else { /* 3GPP TS 24.401, Figure 5.3.2.1-1, point 5a * No EMM context exists for the UE in the network; authentication @@ -2145,7 +2150,7 @@ static int _emm_attach_identify(void *args) ** Others: _emm_data ** ** ** ***************************************************************************/ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) int emm_attach_security(void *args) { return _emm_attach_security(args); diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/Authentication.c b/openair-cn/NAS/EURECOM-NAS/src/emm/Authentication.c index db0245e87..3aacc3f79 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/Authentication.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/Authentication.c @@ -76,7 +76,7 @@ Description Defines the authentication EMM procedure executed by the #endif #ifdef NAS_MME -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) # include "nas_itti_messaging.h" # endif #endif @@ -710,7 +710,7 @@ int emm_proc_authentication_complete(unsigned int ueid, int emm_cause, /* Get the UE context */ emm_data_context_t *emm_ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, ueid); @@ -739,7 +739,7 @@ int emm_proc_authentication_complete(unsigned int ueid, int emm_cause, if (emm_cause != EMM_CAUSE_SUCCESS) { switch (emm_cause) { -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) case EMM_CAUSE_SYNCH_FAILURE: /* USIM has detected a mismatch in SQN. @@ -1408,7 +1408,7 @@ int _authentication_request(authentication_data_t *data) emm_sap.u.emm_as.u.security.autn = &data->autn; /* TODO: check for pointer validity */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, data->ueid); #else emm_ctx = _emm_data.ctx[data->ueid]; @@ -1467,7 +1467,7 @@ static int _authentication_reject(unsigned int ueid) emm_sap.u.emm_as.u.security.ueid = ueid; emm_sap.u.emm_as.u.security.msgType = EMM_AS_MSG_TYPE_AUTH; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, ueid); #else emm_ctx = _emm_data.ctx[ueid]; diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/Detach.c b/openair-cn/NAS/EURECOM-NAS/src/emm/Detach.c index 4304b46b9..cba18d5a8 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/Detach.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/Detach.c @@ -456,7 +456,7 @@ int emm_proc_detach_request(unsigned int ueid, emm_proc_detach_type_t type, _emm_detach_type_str[type], type, ueid); /* Get the UE context */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, ueid); @@ -513,7 +513,7 @@ int emm_proc_detach_request(unsigned int ueid, emm_proc_detach_type_t type, } /* Release the EMM context */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_data_context_remove(&_emm_data, emm_ctx); free(emm_ctx); #else diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/EmmCommon.c b/openair-cn/NAS/EURECOM-NAS/src/emm/EmmCommon.c index f140ead1a..d142ec405 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/EmmCommon.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/EmmCommon.c @@ -65,7 +65,7 @@ Description Defines callback functions executed within EMM common procedures #include <string.h> #include <assert.h> -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) # include "assertions.h" #endif @@ -90,12 +90,12 @@ typedef struct emm_common_data_s { emm_common_abort_callback_t abort; void *args; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) RB_ENTRY(emm_common_data_s) entries; #endif } emm_common_data_t; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) typedef struct emm_common_data_head_s { RB_HEAD(emm_common_data_map, emm_common_data_s) emm_common_data_root; } emm_common_data_head_t; @@ -185,7 +185,7 @@ int emm_proc_common_initialize(unsigned int ueid, struct emm_common_data_s *emm_common_data_ctx = NULL; LOG_FUNC_IN; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) assert(ueid > 0); emm_common_data_ctx = emm_common_data_context_get(&emm_common_data_head, ueid); #else @@ -195,7 +195,7 @@ int emm_proc_common_initialize(unsigned int ueid, if (emm_common_data_ctx == NULL) { emm_common_data_ctx = (emm_common_data_t *)malloc(sizeof(emm_common_data_t)); emm_common_data_ctx->ueid = ueid; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) RB_INSERT(emm_common_data_map, &emm_common_data_head.emm_common_data_root, emm_common_data_ctx); #endif @@ -244,7 +244,7 @@ int emm_proc_common_success(unsigned int ueid) LOG_FUNC_IN; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) DevCheck(ueid > 0, ueid, 0, 0); emm_common_data_ctx = emm_common_data_context_get(&emm_common_data_head, ueid); #else @@ -259,7 +259,7 @@ int emm_proc_common_success(unsigned int ueid) if (emm_callback) { struct emm_data_context_s *ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) ctx = emm_data_context_get(&_emm_data, ueid); #else ctx = _emm_data.ctx[ueid]; @@ -297,7 +297,7 @@ int emm_proc_common_reject(unsigned int ueid) LOG_FUNC_IN; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) DevCheck(ueid > 0, ueid, 0, 0); emm_common_data_ctx = emm_common_data_context_get(&emm_common_data_head, ueid); #else @@ -312,7 +312,7 @@ int emm_proc_common_reject(unsigned int ueid) if (emm_callback) { struct emm_data_context_s *ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) ctx = emm_data_context_get(&_emm_data, ueid); #else ctx = _emm_data.ctx[ueid]; @@ -352,7 +352,7 @@ int emm_proc_common_failure(unsigned int ueid) LOG_FUNC_IN; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) DevCheck(ueid > 0, ueid, 0, 0); emm_common_data_ctx = emm_common_data_context_get(&emm_common_data_head, ueid); #else @@ -366,7 +366,7 @@ int emm_proc_common_failure(unsigned int ueid) if (emm_callback) { struct emm_data_context_s *ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) ctx = emm_data_context_get(&_emm_data, ueid); #else ctx = _emm_data.ctx[ueid]; @@ -405,7 +405,7 @@ int emm_proc_common_abort(unsigned int ueid) LOG_FUNC_IN; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) DevCheck(ueid > 0, ueid, 0, 0); emm_common_data_ctx = emm_common_data_context_get(&emm_common_data_head, ueid); #else @@ -419,7 +419,7 @@ int emm_proc_common_abort(unsigned int ueid) if (emm_callback) { struct emm_data_context_s *ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) ctx = emm_data_context_get(&_emm_data, ueid); #else ctx = _emm_data.ctx[ueid]; @@ -453,7 +453,7 @@ void *emm_proc_common_get_args(unsigned int ueid) emm_common_data_t *emm_common_data_ctx = NULL; LOG_FUNC_IN; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) DevCheck(ueid > 0, ueid, 0, 0); emm_common_data_ctx = emm_common_data_context_get(&emm_common_data_head, ueid); #else @@ -490,7 +490,7 @@ static void _emm_common_cleanup(unsigned int ueid) { emm_common_data_t *emm_common_data_ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) DevCheck(ueid > 0, ueid, 0, 0); emm_common_data_ctx = emm_common_data_context_get(&emm_common_data_head, ueid); #else @@ -503,7 +503,7 @@ static void _emm_common_cleanup(unsigned int ueid) if (emm_common_data_ctx->ref_count == 0) { /* Release the callback functions */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) RB_REMOVE(emm_common_data_map, &emm_common_data_head.emm_common_data_root, emm_common_data_ctx); diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/EmmStatusHdl.c b/openair-cn/NAS/EURECOM-NAS/src/emm/EmmStatusHdl.c index 714f2c0db..67780db75 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/EmmStatusHdl.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/EmmStatusHdl.c @@ -147,7 +147,7 @@ int emm_proc_status(unsigned int ueid, int emm_cause) #endif #ifdef NAS_MME emm_sap.u.emm_as.u.status.guti = NULL; -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) ctx = emm_data_context_get(&_emm_data, ueid); # else ctx = _emm_data.ctx[ueid]; diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/Identification.c b/openair-cn/NAS/EURECOM-NAS/src/emm/Identification.c index 4f81da3b2..faafc527e 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/Identification.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/Identification.c @@ -384,7 +384,7 @@ int emm_proc_identification_complete(unsigned int ueid, const imsi_t *imsi, } /* Get the UE context */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, ueid); @@ -551,7 +551,7 @@ int _identification_request(identification_data_t *data) emm_sap.u.emm_as.u.security.msgType = EMM_AS_MSG_TYPE_IDENT; emm_sap.u.emm_as.u.security.identType = data->type; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (data->ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, data->ueid); diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/LowerLayer.c b/openair-cn/NAS/EURECOM-NAS/src/emm/LowerLayer.c index 19712e711..0a19feb0a 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/LowerLayer.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/LowerLayer.c @@ -236,7 +236,7 @@ int lowerlayer_data_ind(unsigned int ueid, const OctetString *data) LOG_FUNC_IN; -#if defined(EPC_BUILD) && defined(NAS_MME) +#if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) if (ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, ueid); @@ -290,7 +290,7 @@ int lowerlayer_data_req(unsigned int ueid, const OctetString *data) #ifdef NAS_MME emm_sap.u.emm_as.u.data.guti = NULL; emm_sap.u.emm_as.u.data.ueid = ueid; -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) if (ueid > 0) { ctx = emm_data_context_get(&_emm_data, ueid); diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/SecurityModeControl.c b/openair-cn/NAS/EURECOM-NAS/src/emm/SecurityModeControl.c index a6e764815..f1bad591d 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/SecurityModeControl.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/SecurityModeControl.c @@ -446,7 +446,7 @@ int emm_proc_security_mode_control(unsigned int ueid, int ksi, "KSI = %d EEA = %d EIA = %d", ksi, eea, eia); -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, ueid); @@ -638,7 +638,7 @@ int emm_proc_security_mode_complete(unsigned int ueid) } /* Get the UE context */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, ueid); @@ -721,7 +721,7 @@ int emm_proc_security_mode_reject(unsigned int ueid) } /* Get the UE context */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, ueid); @@ -1074,7 +1074,7 @@ int _security_request(security_data_t *data, int is_new) emm_sap.u.emm_as.u.security.selected_eea = data->selected_eea; emm_sap.u.emm_as.u.security.selected_eia = data->selected_eia; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (data->ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, data->ueid); diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/TrackingAreaUpdate.c b/openair-cn/NAS/EURECOM-NAS/src/emm/TrackingAreaUpdate.c index 2b92ce006..2e95dd303 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/TrackingAreaUpdate.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/TrackingAreaUpdate.c @@ -123,7 +123,7 @@ int emm_proc_tracking_area_update_reject(unsigned int ueid, int emm_cause) ue_ctx.ueid = ueid; /* Update the EMM cause code */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (ueid > 0) #else diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/emmData.h b/openair-cn/NAS/EURECOM-NAS/src/emm/emmData.h index 63c5ebc10..e6824b433 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/emmData.h +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/emmData.h @@ -58,7 +58,7 @@ Description Defines internal private data handled by EPS Mobility #ifdef NAS_MME #include "emm_fsm.h" #include "mme_api.h" -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) # include "tree.h" # endif #endif @@ -356,7 +356,7 @@ typedef struct { * --------------------------------------------------------------------------- */ typedef struct emm_data_context_s { -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) RB_ENTRY(emm_data_context_s) entries; #endif @@ -409,7 +409,7 @@ typedef struct { * EMM contexts * ------------ */ -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) /* Use a tree for ue data context within MME */ RB_HEAD(emm_data_context_map, emm_data_context_s) ctx_map; # else diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/emm_data_ctx.c b/openair-cn/NAS/EURECOM-NAS/src/emm/emm_data_ctx.c index 2d1df241d..97e575469 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/emm_data_ctx.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/emm_data_ctx.c @@ -30,7 +30,7 @@ #include <stdlib.h> #include <string.h> -#if defined(EPC_BUILD) && defined(NAS_MME) +#if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) #include "assertions.h" #include "tree.h" #include "emmData.h" diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.c b/openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.c index 8190d2cc0..8d91573c8 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.c @@ -58,7 +58,7 @@ Description Defines the EPS Mobility Management procedure call manager, #include <stdlib.h> // malloc, free #endif -#if defined(EPC_BUILD) && defined(NAS_MME) +#if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) # include "mme_config.h" #endif @@ -425,7 +425,7 @@ void emm_main_initialize(emm_indication_callback_t cb, const char *imei) ** Others: _emm_data ** ** ** ***************************************************************************/ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) void emm_main_initialize(mme_config_t *mme_config_p) #else void emm_main_initialize(void) @@ -434,7 +434,7 @@ void emm_main_initialize(void) LOG_FUNC_IN; /* Retreive MME supported configuration data */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (mme_api_get_emm_config(&_emm_data.conf, mme_config_p) != RETURNok) #else @@ -444,7 +444,7 @@ void emm_main_initialize(void) LOG_TRACE(ERROR, "EMM-MAIN - Failed to get MME configuration data"); } -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) RB_INIT(&_emm_data.ctx_map); #endif diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.h b/openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.h index 468a5a90f..09eff8763 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.h +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/emm_main.h @@ -46,7 +46,7 @@ Description Defines the EPS Mobility Management procedure call manager, #ifndef __EMM_MAIN_H__ #define __EMM_MAIN_H__ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) # include "mme_config.h" #endif @@ -73,7 +73,7 @@ Description Defines the EPS Mobility Management procedure call manager, void emm_main_initialize(emm_indication_callback_t cb, const char *imei); #endif #ifdef NAS_MME -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) void emm_main_initialize(mme_config_t *mme_config_p); # else void emm_main_initialize(void); diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/msg/emm_msg.c b/openair-cn/NAS/EURECOM-NAS/src/emm/msg/emm_msg.c index d93f9dd8b..979210c61 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/msg/emm_msg.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/msg/emm_msg.c @@ -51,7 +51,7 @@ Description Defines EPS Mobility Management messages #include "TLVDecoder.h" #include "TLVEncoder.h" -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) # include "nas_itti_messaging.h" #endif @@ -97,12 +97,12 @@ int emm_msg_decode(EMM_msg *msg, uint8_t *buffer, uint32_t len) int header_result; int decode_result; -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) uint8_t *buffer_log = buffer; uint32_t len_log = len; int down_link; -# if ((defined(EPC_BUILD) && defined(NAS_MME))) +# if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME))) down_link = 0; # else down_link = 1; @@ -265,7 +265,7 @@ int emm_msg_decode(EMM_msg *msg, uint8_t *buffer, uint32_t len) "(%d)", msg->header.message_type, decode_result); LOG_FUNC_RETURN (decode_result); } else { -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) /* Message has been decoded and security header removed, handle it has a plain message */ nas_itti_plain_msg((char *) buffer_log, (nas_message_t *) msg, len_log, down_link); #endif @@ -298,11 +298,11 @@ int emm_msg_encode(EMM_msg *msg, uint8_t *buffer, uint32_t len) int header_result; int encode_result; -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) uint8_t *buffer_log = buffer; int down_link; -# if ((defined(EPC_BUILD) && defined(NAS_MME))) +# if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME))) down_link = 1; # else down_link = 0; @@ -466,7 +466,7 @@ int emm_msg_encode(EMM_msg *msg, uint8_t *buffer, uint32_t len) LOG_TRACE(ERROR, "EMM-MSG - Failed to encode L3 EMM message 0x%x " "(%d)", msg->header.message_type, encode_result); } else { -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) nas_itti_plain_msg((char *) buffer_log, (nas_message_t *) msg, header_result + encode_result, down_link); #endif } diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_as.c b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_as.c index 979dc9d96..bdc03f6c9 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_as.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_as.c @@ -63,7 +63,7 @@ Description Defines the EMMAS Service Access Point that provides #include <string.h> // memset #include <stdlib.h> // malloc, free -#if (defined(EPC_BUILD) && defined(NAS_MME)) || (defined(UE_BUILD) && defined(NAS_UE)) +#if (defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(NAS_BUILT_IN_UE) && defined(NAS_UE)) # include "nas_itti_messaging.h" #endif @@ -356,11 +356,11 @@ static int _emm_as_recv(unsigned int ueid, const char *msg, int len, emm_security_context_t *security = NULL; /* Current EPS NAS security context */ #if defined(NAS_MME) -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_data_context_t *emm_ctx = NULL; #endif -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, ueid); if (emm_ctx) { @@ -552,7 +552,7 @@ static int _emm_as_data_ind(const emm_as_data_t *msg, int *emm_cause) /* Decrypt the received security protected message */ #if defined(NAS_MME) emm_data_context_t *emm_ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) if (msg->ueid > 0) { emm_ctx = emm_data_context_get(&_emm_data, msg->ueid); @@ -825,7 +825,7 @@ static int _emm_as_establish_req(const emm_as_establish_t *msg, int *emm_cause) memset(&nas_msg, 0 , sizeof(nas_message_t)); #if defined(NAS_MME) -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, msg->ueid); #else @@ -1279,7 +1279,7 @@ static int _emm_as_send(const emm_as_t *msg) /* Send the message to the Access Stratum or S1AP in case of MME */ if (as_msg.msgID > 0) { -#if defined(EPC_BUILD) && defined(NAS_MME) +#if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) LOG_TRACE(DEBUG, "EMMAS-SAP - " "Sending msg with id 0x%x, primitive %s (%d) to S1AP layer for transmission", as_msg.msgID, @@ -1330,7 +1330,7 @@ static int _emm_as_send(const emm_as_t *msg) } #else -# if defined(UE_BUILD) && defined(NAS_UE) +# if defined(NAS_BUILT_IN_UE) && defined(NAS_UE) LOG_TRACE(DEBUG, "EMMAS-SAP - " "Sending msg with id 0x%x, primitive %s (%d) to RRC layer for transmission", as_msg.msgID, @@ -1467,7 +1467,7 @@ static int _emm_as_data_req(const emm_as_data_t *msg, emm_security_context_t *emm_security_context = NULL; #if defined(NAS_MME) struct emm_data_context_s *emm_ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, msg->ueid); #else @@ -1573,7 +1573,7 @@ static int _emm_as_status_ind(const emm_as_status_t *msg, emm_security_context_t *emm_security_context = NULL; #if defined(NAS_MME) struct emm_data_context_s *emm_ctx = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, msg->ueid); #else @@ -1914,7 +1914,7 @@ static int _emm_as_security_req(const emm_as_security_t *msg, if (size > 0) { struct emm_data_context_s *emm_ctx = NULL; emm_security_context_t *emm_security_context = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, msg->ueid); #else @@ -2004,7 +2004,7 @@ static int _emm_as_security_rej(const emm_as_security_t *msg, if (size > 0) { struct emm_data_context_s *emm_ctx = NULL; emm_security_context_t *emm_security_context = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, msg->ueid); #else @@ -2099,7 +2099,7 @@ static int _emm_as_establish_cnf(const emm_as_establish_t *msg, if (size > 0) { struct emm_data_context_s *emm_ctx = NULL; emm_security_context_t *emm_security_context = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, msg->ueid); #else @@ -2217,7 +2217,7 @@ static int _emm_as_establish_rej(const emm_as_establish_t *msg, if (size > 0) { struct emm_data_context_s *emm_ctx = NULL; emm_security_context_t *emm_security_context = NULL; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_ctx = emm_data_context_get(&_emm_data, msg->ueid); #else diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cn.c b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cn.c index 8e99beb36..3798332f8 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cn.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cn.c @@ -46,7 +46,7 @@ Description #include <string.h> -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) #include "nas_log.h" #include "commonDef.h" diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cn.h b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cn.h index 47192d60a..cb4e687b6 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cn.h +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cn.h @@ -49,7 +49,7 @@ Description #ifndef _EMM_CN_H_ #define _EMM_CN_H_ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) int emm_cn_send(const emm_cn_t *msg); #endif diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cnDef.h b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cnDef.h index 8599ec36d..d5a88b992 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cnDef.h +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_cnDef.h @@ -44,7 +44,7 @@ Description *****************************************************************************/ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) #include "intertask_interface.h" #endif @@ -53,7 +53,7 @@ Description typedef enum emmcn_primitive_s { _EMMCN_START = 400, -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) _EMMCN_AUTHENTICATION_PARAM_RES, _EMMCN_AUTHENTICATION_PARAM_FAIL, _EMMCN_DEREGISTER_UE, @@ -63,7 +63,7 @@ typedef enum emmcn_primitive_s { _EMMCN_END } emm_cn_primitive_t; -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) typedef nas_auth_param_rsp_t emm_cn_auth_res_t; typedef nas_auth_param_fail_t emm_cn_auth_fail_t; typedef nas_pdn_connectivity_rsp_t emm_cn_pdn_res_t; diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_fsm.c b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_fsm.c index daf848f52..7a93c1e92 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_fsm.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_fsm.c @@ -52,7 +52,7 @@ Description Defines the EPS Mobility Management procedures executed at #include "mme_api.h" #include "emmData.h" -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) # include "assertions.h" #endif @@ -229,7 +229,7 @@ static const emm_fsm_handler_t _emm_fsm_handlers[EMM_STATE_MAX] = { * ----------------------------------------------------------------------------- */ -#if !defined(EPC_BUILD) +#if !defined(NAS_BUILT_IN_EPC) emm_fsm_state_t _emm_fsm_status[EMM_FSM_NB_UE_MAX]; #endif @@ -260,7 +260,7 @@ void emm_fsm_initialize(void) _emm_fsm_status[0] = EMM_NULL; #endif -#if defined(NAS_MME) && !defined(EPC_BUILD) +#if defined(NAS_MME) && !defined(NAS_BUILT_IN_EPC) for (ueid = 0; ueid < EMM_FSM_NB_UE_MAX; ueid++) { _emm_fsm_status[ueid] = EMM_DEREGISTERED; @@ -299,7 +299,7 @@ int emm_fsm_set_status( unsigned int ueid = 0; #endif -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_data_context_t *emm_ctx = (emm_data_context_t *)ctx; DevAssert(emm_ctx != NULL); @@ -360,7 +360,7 @@ emm_fsm_state_t emm_fsm_get_status(void) #ifdef NAS_MME emm_fsm_state_t emm_fsm_get_status(unsigned int ueid, void *ctx) { -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) emm_data_context_t *emm_ctx = (emm_data_context_t *)ctx; if (emm_ctx != NULL) { @@ -406,7 +406,7 @@ int emm_fsm_process(const emm_reg_t *evt) status = _emm_fsm_status[0]; #endif #ifdef NAS_MME -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) emm_data_context_t *emm_ctx = (emm_data_context_t *)evt->ctx; DevAssert(emm_ctx != NULL); @@ -426,7 +426,7 @@ int emm_fsm_process(const emm_reg_t *evt) _emm_fsm_event_str[primitive - _EMMREG_START - 1], primitive, _emm_fsm_status_str[status]); -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) DevAssert(status != EMM_INVALID); #endif diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_fsm.h b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_fsm.h index b4e311f85..69e6ae793 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_fsm.h +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_fsm.h @@ -112,7 +112,7 @@ int emm_fsm_set_status(emm_fsm_state_t status); emm_fsm_state_t emm_fsm_get_status(void); #endif #ifdef NAS_MME -struct emm_data_context_t; +//LG 2015-03-13 struct emm_data_context_t; int emm_fsm_set_status(unsigned int ueid, void *ctx, emm_fsm_state_t status); emm_fsm_state_t emm_fsm_get_status(unsigned int ueid, void *ctx); #endif diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_recv.c b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_recv.c index cd254b444..d37de4fc9 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_recv.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_recv.c @@ -510,7 +510,8 @@ int emm_recv_security_mode_command(security_mode_command_msg *msg, int emm_recv_attach_request(unsigned int ueid, const attach_request_msg *msg, int *emm_cause) { - int rc; + int rc; + uint8_t gea = 0; emm_proc_attach_type_t type; LOG_FUNC_IN; @@ -639,6 +640,16 @@ int emm_recv_attach_request(unsigned int ueid, const attach_request_msg *msg, } /* Execute the requested UE attach procedure */ +#warning " TODO gea to be review" + + if (msg->msnetworkcapability.msnetworkcapabilityvalue.length > 0) { + gea = (msg->msnetworkcapability.msnetworkcapabilityvalue.value[0] & 0x80) >> 1; + + if ((gea) && (msg->msnetworkcapability.msnetworkcapabilityvalue.length >= 2)) { + gea |= ((msg->msnetworkcapability.msnetworkcapabilityvalue.value[1] & 0x60) >> 1); + } + } + rc = emm_proc_attach_request(ueid, type, msg->naskeysetidentifier.tsc != NAS_KEY_SET_IDENTIFIER_MAPPED, msg->naskeysetidentifier.naskeysetidentifier, @@ -648,13 +659,7 @@ int emm_recv_attach_request(unsigned int ueid, const attach_request_msg *msg, msg->uenetworkcapability.ucs2, msg->uenetworkcapability.uea, msg->uenetworkcapability.uia, - 0x00 | - //((msg->uenetworkcapability.spare & 0x7) << 5) | // spare coded as zero - ((msg->uenetworkcapability.csfb & 0x1) << 4) | - ((msg->uenetworkcapability.lpp & 0x1) << 3) | - ((msg->uenetworkcapability.lcs & 0x1) << 2) | - ((msg->uenetworkcapability.srvcc & 0x1) << 1) | - (msg->uenetworkcapability.nf & 0x1), + gea, msg->uenetworkcapability.umts_present, msg->uenetworkcapability.gprs_present, &msg->esmmessagecontainer.esmmessagecontainercontents); diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_sap.c b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_sap.c index aa91f4a83..861063194 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_sap.c +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_sap.c @@ -132,7 +132,7 @@ int emm_sap_send(emm_sap_t *msg) rc = emm_as_send(&msg->u.emm_as); } -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) else if ( (primitive > EMMCN_PRIMITIVE_MIN) && (primitive < EMMCN_PRIMITIVE_MAX) ) { /* Forward to the EMMCN-SAP */ diff --git a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_sap.h b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_sap.h index 0ae4ac722..865bc0e01 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_sap.h +++ b/openair-cn/NAS/EURECOM-NAS/src/emm/sap/emm_sap.h @@ -133,7 +133,7 @@ typedef enum { EMMAS_CELL_INFO_RES = _EMMAS_CELL_INFO_RES, EMMAS_CELL_INFO_IND = _EMMAS_CELL_INFO_IND, -#ifdef EPC_BUILD +#ifdef NAS_BUILT_IN_EPC EMMCN_AUTHENTICATION_PARAM_RES = _EMMCN_AUTHENTICATION_PARAM_RES, EMMCN_AUTHENTICATION_PARAM_FAIL = _EMMCN_AUTHENTICATION_PARAM_FAIL, EMMCN_DEREGISTER_UE = _EMMCN_DEREGISTER_UE, @@ -171,7 +171,7 @@ typedef struct { emm_reg_t emm_reg; /* EMMREG-SAP primitives */ emm_esm_t emm_esm; /* EMMESM-SAP primitives */ emm_as_t emm_as; /* EMMAS-SAP primitives */ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) emm_cn_t emm_cn; /* EMMCN-SAP primitives */ #endif } u; diff --git a/openair-cn/NAS/EURECOM-NAS/src/esm/PdnConnectivity.c b/openair-cn/NAS/EURECOM-NAS/src/esm/PdnConnectivity.c index 4c27d9350..76552f12c 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/esm/PdnConnectivity.c +++ b/openair-cn/NAS/EURECOM-NAS/src/esm/PdnConnectivity.c @@ -666,7 +666,7 @@ int esm_proc_pdn_connectivity_request(emm_data_context_t *ctx, int pti, (apn) ? (char *)(apn->value) : "null", (pdn_addr) ? (char *)(pdn_addr->value) : "null"); -#if !defined(EPC_BUILD) +#if !defined(NAS_BUILT_IN_EPC) /* UE identifier sanity check */ if (ctx->ueid >= ESM_DATA_NB_UE_MAX) { diff --git a/openair-cn/NAS/EURECOM-NAS/src/esm/esmData.h b/openair-cn/NAS/EURECOM-NAS/src/esm/esmData.h index 63f710a0c..471859725 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/esm/esmData.h +++ b/openair-cn/NAS/EURECOM-NAS/src/esm/esmData.h @@ -53,7 +53,7 @@ Description Defines internal private data handled by EPS Session #include "mme_api.h" #endif -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) # include "tree.h" #endif @@ -244,7 +244,7 @@ typedef struct { * ESM contexts * ------------ */ -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) /* Use a tree for ue data context within MME */ RB_HEAD(esm_data_context_map, esm_data_context_s) ctx_map; # else @@ -253,7 +253,7 @@ typedef struct { # endif } esm_data_t; -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) struct esm_data_context_s *esm_data_context_get( esm_data_t *esm_data, unsigned int _ueid); @@ -282,10 +282,10 @@ esm_data_t _esm_data; extern char ip_addr_str[100]; -extern inline char *esm_data_get_ipv4_addr(const OctetString *ip_addr); +extern char *esm_data_get_ipv4_addr(const OctetString *ip_addr); -extern inline char *esm_data_get_ipv6_addr(const OctetString *ip_addr); +extern char *esm_data_get_ipv6_addr(const OctetString *ip_addr); -extern inline char *esm_data_get_ipv4v6_addr(const OctetString *ip_addr); +extern char *esm_data_get_ipv4v6_addr(const OctetString *ip_addr); #endif /* __ESMDATA_H__*/ diff --git a/openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr.c b/openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr.c index 3d3df1db3..1b24bee2f 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr.c +++ b/openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr.c @@ -86,7 +86,7 @@ static const char *_esm_ebr_state_str[ESM_EBR_STATE_MAX] = { * ---------------------------------- */ -#if !defined(EPC_BUILD) +#if !defined(NAS_BUILT_IN_EPC) static esm_ebr_data_t _esm_ebr_data[ESM_EBR_NB_UE_MAX]; #endif @@ -151,7 +151,7 @@ void esm_ebr_initialize( #endif ) { -#if !defined(EPC_BUILD) +#if !defined(NAS_BUILT_IN_EPC) int ueid, i; LOG_FUNC_IN; @@ -249,7 +249,7 @@ int esm_ebr_assign(emm_data_context_t *ctx, int ebi) LOG_FUNC_RETURN(ESM_EBI_UNASSIGNED); } -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) ctx->esm_data_ctx.ebr.context[ebi - ESM_EBI_MIN] = ebr_ctx; #else _esm_ebr_data[ueid].context[ebi - ESM_EBI_MIN] = ebr_ctx; diff --git a/openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr_context.c b/openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr_context.c index 147ce14c6..28b69ff56 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr_context.c +++ b/openair-cn/NAS/EURECOM-NAS/src/esm/esm_ebr_context.c @@ -128,7 +128,7 @@ int esm_ebr_context_create( esm_ctx = &_esm_data; #endif #ifdef NAS_MME -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) esm_ctx = &ctx->esm_data_ctx; # else @@ -369,7 +369,7 @@ int esm_ebr_context_release( #endif #ifdef NAS_MME -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) esm_ctx = &ctx->esm_data_ctx; # else diff --git a/openair-cn/NAS/EURECOM-NAS/src/esm/esm_main.c b/openair-cn/NAS/EURECOM-NAS/src/esm/esm_main.c index 662369d63..a87b0830b 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/esm/esm_main.c +++ b/openair-cn/NAS/EURECOM-NAS/src/esm/esm_main.c @@ -135,7 +135,7 @@ void esm_main_initialize(void) LOG_TRACE(ERROR, "ESM-MAIN - Failed to get MME configuration data"); } -# if !defined(EPC_BUILD) +# if !defined(NAS_BUILT_IN_EPC) /* Initialize ESM contexts */ for (i = 0; i < ESM_DATA_NB_UE_MAX; i++) { diff --git a/openair-cn/NAS/EURECOM-NAS/src/esm/msg/esm_msg.c b/openair-cn/NAS/EURECOM-NAS/src/esm/msg/esm_msg.c index 1eba82829..2f5dbc872 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/esm/msg/esm_msg.c +++ b/openair-cn/NAS/EURECOM-NAS/src/esm/msg/esm_msg.c @@ -50,7 +50,7 @@ Description Defines EPS Session Management messages #include "TLVDecoder.h" #include "TLVEncoder.h" -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) # include "nas_itti_messaging.h" #endif @@ -92,12 +92,12 @@ int esm_msg_decode(ESM_msg *msg, uint8_t *buffer, uint32_t len) int header_result; int decode_result; -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) uint8_t *buffer_log = buffer; uint32_t len_log = len; int down_link; -# if ((defined(EPC_BUILD) && defined(NAS_MME))) +# if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME))) down_link = 0; # else down_link = 1; @@ -219,7 +219,7 @@ int esm_msg_decode(ESM_msg *msg, uint8_t *buffer, uint32_t len) "(%u)", msg->header.message_type, decode_result); LOG_FUNC_RETURN (decode_result); } else { -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) /* Message has been decoded and security header removed, handle it has a plain message */ nas_itti_plain_msg((char *) buffer_log, (nas_message_t *) msg, len_log, down_link); #endif @@ -252,11 +252,11 @@ int esm_msg_encode(ESM_msg *msg, uint8_t *buffer, uint32_t len) int header_result; int encode_result; -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) uint8_t *buffer_log = buffer; int down_link; -# if ((defined(EPC_BUILD) && defined(NAS_MME))) +# if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME))) down_link = 1; # else down_link = 0; @@ -378,7 +378,7 @@ int esm_msg_encode(ESM_msg *msg, uint8_t *buffer, uint32_t len) LOG_TRACE(ERROR, "ESM-MSG - Failed to encode L3 ESM message 0x%x " "(%d)", msg->header.message_type, encode_result); } else { -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) nas_itti_plain_msg((char *) buffer_log, (nas_message_t *) msg, header_result + encode_result, down_link); #endif } diff --git a/openair-cn/NAS/EURECOM-NAS/src/ies/UeNetworkCapability.c b/openair-cn/NAS/EURECOM-NAS/src/ies/UeNetworkCapability.c index 9e65c5df2..839acc080 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/ies/UeNetworkCapability.c +++ b/openair-cn/NAS/EURECOM-NAS/src/ies/UeNetworkCapability.c @@ -80,6 +80,9 @@ int decode_ue_network_capability(UeNetworkCapability *uenetworkcapability, uint8 uenetworkcapability->gprs_present =1; LOG_TRACE(INFO, "uenetworkcapability decoded GPRS\n"); } + +#warning "Force GPRS present if UMTS present" + uenetworkcapability->gprs_present =1; } } diff --git a/openair-cn/NAS/EURECOM-NAS/src/ies/UeSecurityCapability.c b/openair-cn/NAS/EURECOM-NAS/src/ies/UeSecurityCapability.c index 0fc73584e..5c4610ccd 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/ies/UeSecurityCapability.c +++ b/openair-cn/NAS/EURECOM-NAS/src/ies/UeSecurityCapability.c @@ -96,18 +96,32 @@ int encode_ue_security_capability(UeSecurityCapability *uesecuritycapability, ui *(buffer + encoded) = uesecuritycapability->eia; encoded++; + // From ETSI TS 124 301 V10.15.0 (2014-10) 9.9.3.36 Security capability: + // Octets 5, 6, and 7 are optional. If octet 5 is included, then also octet 6 shall be included and octet 7 may be included. + // If a UE did not indicate support of any security algorithm for Gb mode, octet 7 shall not be included. If the UE did not + // indicate support of any security algorithm for Iu mode and Gb mode, octets 5, 6, and 7 shall not be included. + // If the UE did not indicate support of any security algorithm for Iu mode but indicated support of a security algorithm for + // Gb mode, octets 5, 6, and 7 shall be included. In this case octets 5 and 6 are filled with the value of zeroes. if (uesecuritycapability->umts_present) { *(buffer + encoded) = uesecuritycapability->uea; encoded++; *(buffer + encoded) = 0x00 | (uesecuritycapability->uia & 0x7f); encoded++; -#warning "force gea to 0x60 if umts security capability present" - //if (uesecuritycapability->gprs_present) { - *(buffer + encoded) = 0x00 | 0x60; - //(uesecuritycapability->gea & 0x7f); - encoded++; - //} + + if (uesecuritycapability->gprs_present) { + *(buffer + encoded) = 0x00 | (uesecuritycapability->gea & 0x7f); + encoded++; + } + } else { + if (uesecuritycapability->gprs_present) { + *(buffer + encoded) = 0x00; + encoded++; + *(buffer + encoded) = 0x00; + encoded++; + *(buffer + encoded) = 0x00 | (uesecuritycapability->gea & 0x7f); + encoded++; + } } *lenPtr = encoded - 1 - ((iei > 0) ? 1 : 0); diff --git a/openair-cn/NAS/EURECOM-NAS/src/nas_network.c b/openair-cn/NAS/EURECOM-NAS/src/nas_network.c index 3936e241f..9c5a0c38f 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/nas_network.c +++ b/openair-cn/NAS/EURECOM-NAS/src/nas_network.c @@ -77,7 +77,7 @@ Description NAS procedure functions triggered by the network ** Others: None ** ** ** ***************************************************************************/ -#if defined(EPC_BUILD) && defined(NAS_MME) +#if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) void nas_network_initialize(mme_config_t *mme_config_p) #else void nas_network_initialize(void) @@ -87,7 +87,7 @@ void nas_network_initialize(void) #ifdef NAS_MME /* Initialize the internal NAS processing data */ -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) nas_timer_init(); nas_proc_initialize(mme_config_p); # else diff --git a/openair-cn/NAS/EURECOM-NAS/src/nas_network.h b/openair-cn/NAS/EURECOM-NAS/src/nas_network.h index 10d487139..193d98784 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/nas_network.h +++ b/openair-cn/NAS/EURECOM-NAS/src/nas_network.h @@ -43,7 +43,7 @@ Description NAS procedure functions triggered by the network *****************************************************************************/ -#if defined(EPC_BUILD) && defined(NAS_MME) +#if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) # include "mme_config.h" #endif @@ -66,7 +66,7 @@ Description NAS procedure functions triggered by the network /****************** E X P O R T E D F U N C T I O N S ******************/ /****************************************************************************/ -#if defined(EPC_BUILD) && defined(NAS_MME) +#if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) void nas_network_initialize(mme_config_t *mme_config_p); #else void nas_network_initialize(void); diff --git a/openair-cn/NAS/EURECOM-NAS/src/nas_proc.c b/openair-cn/NAS/EURECOM-NAS/src/nas_proc.c index 8809f68e4..5a7613106 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/nas_proc.c +++ b/openair-cn/NAS/EURECOM-NAS/src/nas_proc.c @@ -140,7 +140,7 @@ void nas_proc_initialize(emm_indication_callback_t emm_cb, ** Others: None ** ** ** ***************************************************************************/ -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) void nas_proc_initialize(mme_config_t *mme_config_p) { LOG_FUNC_IN; @@ -1482,7 +1482,7 @@ int nas_proc_ul_transfer_ind(UInt32_t ueid, const Byte_t *data, UInt32_t len) LOG_FUNC_RETURN (rc); } -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) int nas_proc_auth_param_res(emm_cn_auth_res_t *emm_cn_auth_res) { int rc = RETURNerror; diff --git a/openair-cn/NAS/EURECOM-NAS/src/nas_proc.h b/openair-cn/NAS/EURECOM-NAS/src/nas_proc.h index 4923db540..11573a176 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/nas_proc.h +++ b/openair-cn/NAS/EURECOM-NAS/src/nas_proc.h @@ -45,7 +45,7 @@ Description NAS procedure call manager #ifndef __NAS_PROC_H__ #define __NAS_PROC_H__ -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) # include "mme_config.h" # include "emm_cnDef.h" #endif @@ -74,7 +74,7 @@ void nas_proc_initialize(emm_indication_callback_t emm_cb, esm_indication_callback_t esm_cb, const char *imei); #endif #ifdef NAS_MME -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) void nas_proc_initialize(mme_config_t *mme_config_p); # else void nas_proc_initialize(void); @@ -159,7 +159,7 @@ int nas_proc_ul_transfer_ind(UInt32_t ueid, const Byte_t *data, UInt32_t len); * NAS procedures triggered by the mme applicative layer * -------------------------------------------------------------------------- */ -#if defined(NAS_MME) && defined(EPC_BUILD) +#if defined(NAS_MME) && defined(NAS_BUILT_IN_EPC) int nas_proc_auth_param_res(emm_cn_auth_res_t *emm_cn_auth_res); int nas_proc_auth_param_fail(emm_cn_auth_fail_t *emm_cn_auth_fail); int nas_proc_deregister_ue(UInt32_t ue_id); diff --git a/openair-cn/NAS/EURECOM-NAS/src/util/nas_log.c b/openair-cn/NAS/EURECOM-NAS/src/util/nas_log.c index a1bd627b6..c9aac7ad4 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/util/nas_log.c +++ b/openair-cn/NAS/EURECOM-NAS/src/util/nas_log.c @@ -44,7 +44,7 @@ Description Usefull logging functions *****************************************************************************/ #include "nas_log.h" -#if defined(UE_BUILD) && defined(NAS_UE) +#if defined(NAS_BUILT_IN_UE) && defined(NAS_UE) int nas_log_func_indent; #else #include <stdio.h> // stderr, sprintf, fprintf, vfprintf diff --git a/openair-cn/NAS/EURECOM-NAS/src/util/nas_log.h b/openair-cn/NAS/EURECOM-NAS/src/util/nas_log.h index 173568b66..9c3bfb098 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/util/nas_log.h +++ b/openair-cn/NAS/EURECOM-NAS/src/util/nas_log.h @@ -45,7 +45,7 @@ Description Usefull logging functions #ifndef __NAS_LOG_H__ #define __NAS_LOG_H__ -#if defined(UE_BUILD) && defined(NAS_UE) +#if defined(NAS_BUILT_IN_UE) && defined(NAS_UE) # include "UTIL/LOG/log.h" # undef LOG_TRACE #endif @@ -102,7 +102,7 @@ typedef enum { /****************** E X P O R T E D F U N C T I O N S ******************/ /****************************************************************************/ -#if defined(UE_BUILD) && defined(NAS_UE) +#if defined(NAS_BUILT_IN_UE) && defined(NAS_UE) # define LOG_TRACE(s, x, args...) \ do { \ switch (s) { \ diff --git a/openair-cn/NAS/EURECOM-NAS/src/util/nas_timer.c b/openair-cn/NAS/EURECOM-NAS/src/util/nas_timer.c index 24efd9b9d..4eea8c36c 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/util/nas_timer.c +++ b/openair-cn/NAS/EURECOM-NAS/src/util/nas_timer.c @@ -278,7 +278,7 @@ int nas_timer_start(long sec, nas_timer_callback_t cb, void *args) /* Insert the new entry into the timer queue */ _nas_timer_db_insert_entry(id, te); #if defined(ENABLE_ITTI) -# if defined(EPC_BUILD) +# if defined(NAS_BUILT_IN_EPC) ret = timer_setup(sec, 0, TASK_NAS_MME, INSTANCE_DEFAULT, TIMER_PERIODIC, args, &timer_id); # else ret = timer_setup(sec, 0, TASK_NAS_UE, INSTANCE_DEFAULT, TIMER_PERIODIC, args, &timer_id); diff --git a/openair-cn/NAS/EURECOM-NAS/src/util/nas_timer.h b/openair-cn/NAS/EURECOM-NAS/src/util/nas_timer.h index 9c2ee8924..891eeab5e 100644 --- a/openair-cn/NAS/EURECOM-NAS/src/util/nas_timer.h +++ b/openair-cn/NAS/EURECOM-NAS/src/util/nas_timer.h @@ -81,7 +81,7 @@ int nas_timer_start(long sec, nas_timer_callback_t cb, void *args); int nas_timer_stop(int id); int nas_timer_restart(int id); -#if defined(EPC_BUILD) +#if defined(NAS_BUILT_IN_EPC) void nas_timer_handle_signal_expiry(long timer_id, void *arg_p); #endif diff --git a/openair-cn/NAS/EURECOM-NAS/tools/network.h b/openair-cn/NAS/EURECOM-NAS/tools/network.h index a9bcd8658..077071ff1 100644 --- a/openair-cn/NAS/EURECOM-NAS/tools/network.h +++ b/openair-cn/NAS/EURECOM-NAS/tools/network.h @@ -52,6 +52,7 @@ Description Defines a list of PLMN network operators /********************* G L O B A L C O N S T A N T S *******************/ /****************************************************************************/ +#define TEST_PLMN {0,0,0x0f,1,1,0} // 00101 #define SFR_PLMN_1 {0,2,0x0f,8,0,1} // 20810 #define SFR_PLMN_2 {0,2,0x0f,8,1,1} // 20811 #define SFR_PLMN_3 {0,2,0x0f,8,3,1} // 20813 @@ -71,7 +72,8 @@ Description Defines a list of PLMN network operators * PLMN network operator record index */ enum { - SFR1=0, + TEST1=0, + SFR1, SFR2, SFR3, TM1, @@ -104,6 +106,7 @@ typedef struct { * The list of PLMN network operator records */ network_record_t network_records[] = { + {00101, TEST_PLMN, "Test network", "OAI4G", 0x0001, 0xfffd}, {20810, SFR_PLMN_1, "SFR France", "SFR", 0x0001, 0xfffd}, {20811, SFR_PLMN_2, "SFR France", "SFR", 0x0001, 0xfffd}, {20813, SFR_PLMN_3, "SFR France", "SFR", 0x0001, 0xfffd}, diff --git a/openair-cn/NAS/EURECOM-NAS/tools/ue_data.c b/openair-cn/NAS/EURECOM-NAS/tools/ue_data.c index 71be083fa..8608ee117 100644 --- a/openair-cn/NAS/EURECOM-NAS/tools/ue_data.c +++ b/openair-cn/NAS/EURECOM-NAS/tools/ue_data.c @@ -53,7 +53,7 @@ Description Implements the utility used to generate data stored in the #include <stdlib.h> // exit, free #include <string.h> // memset, strncpy -#define SELECTED_PLMN SFR1 +#define SELECTED_PLMN TEST1 /****************************************************************************/ /**************** E X T E R N A L D E F I N I T I O N S ****************/ @@ -331,31 +331,34 @@ static void _gen_emm_data(emm_nvdata_t* data) * International Mobile Subscriber Identity * IMSI = MCC + MNC + MSIN = 208 (France) + 10 (SFR) + 00001234 */ -#warning "IMSI 208.10.000001234" /* data->imsi.length = 8; - data->imsi.u.num.parity = 0x0; // Type of identity = IMSI, even - data->imsi.u.num.digit1 = 2; // MCC digit 1 - data->imsi.u.num.digit2 = 0; // MCC digit 2 - data->imsi.u.num.digit3 = 8; // MCC digit 3 - data->imsi.u.num.digit4 = 1; // MNC digit 1 - data->imsi.u.num.digit5 = 0; // MNC digit 2 - data->imsi.u.num.digit6 = 0xF; // MNC digit 3 - data->imsi.u.num.digit7 = 0; - data->imsi.u.num.digit8 = 0; - data->imsi.u.num.digit9 = 0; - data->imsi.u.num.digit10 = 0; - data->imsi.u.num.digit11 = 1; - data->imsi.u.num.digit12 = 2; - data->imsi.u.num.digit13 = 3; - data->imsi.u.num.digit14 = 4; - data->imsi.u.num.digit15 = 0xF;*/ + data->imsi.u.num.parity = 0x0; // Type of identity = IMSI, even + data->imsi.u.num.digit1 = 2; // MCC digit 1 + data->imsi.u.num.digit2 = 0; // MCC digit 2 + data->imsi.u.num.digit3 = 8; // MCC digit 3 + data->imsi.u.num.digit4 = 1; // MNC digit 1 + data->imsi.u.num.digit5 = 0; // MNC digit 2 + data->imsi.u.num.digit6 = 0xF; // MNC digit 3 + data->imsi.u.num.digit7 = 0; + data->imsi.u.num.digit8 = 0; + data->imsi.u.num.digit9 = 0; + data->imsi.u.num.digit10 = 0; + data->imsi.u.num.digit11 = 1; + data->imsi.u.num.digit12 = 2; + data->imsi.u.num.digit13 = 3; + data->imsi.u.num.digit14 = 4; + data->imsi.u.num.digit15 = 0xF;*/ + /* + * International Mobile Subscriber Identity + * IMSI = MCC + MNC + MSIN = 001 + 01 + 00001234 + */ data->imsi.length = 8; data->imsi.u.num.parity = 0x0; // Type of identity = IMSI, even - data->imsi.u.num.digit1 = 2; // MCC digit 1 + data->imsi.u.num.digit1 = 0; // MCC digit 1 data->imsi.u.num.digit2 = 0; // MCC digit 2 - data->imsi.u.num.digit3 = 8; // MCC digit 3 - data->imsi.u.num.digit4 = 1; // MNC digit 1 - data->imsi.u.num.digit5 = 0; // MNC digit 2 + data->imsi.u.num.digit3 = 1; // MCC digit 3 + data->imsi.u.num.digit4 = 0; // MNC digit 1 + data->imsi.u.num.digit5 = 1; // MNC digit 2 data->imsi.u.num.digit6 = 0; data->imsi.u.num.digit7 = 0; data->imsi.u.num.digit8 = 0; @@ -370,11 +373,11 @@ static void _gen_emm_data(emm_nvdata_t* data) /* * Last registered home PLMN */ - data->rplmn.MCCdigit1 = 2; + data->rplmn.MCCdigit1 = 0; data->rplmn.MCCdigit2 = 0; - data->rplmn.MCCdigit3 = 8; - data->rplmn.MNCdigit1 = 1; - data->rplmn.MNCdigit2 = 0; + data->rplmn.MCCdigit3 = 1; + data->rplmn.MNCdigit1 = 0; + data->rplmn.MNCdigit2 = 1; data->rplmn.MNCdigit3 = 0xf; #endif /* diff --git a/openair-cn/NAS/EURECOM-NAS/tools/usim_data.c b/openair-cn/NAS/EURECOM-NAS/tools/usim_data.c index 1e4350da9..c84486670 100644 --- a/openair-cn/NAS/EURECOM-NAS/tools/usim_data.c +++ b/openair-cn/NAS/EURECOM-NAS/tools/usim_data.c @@ -27,20 +27,20 @@ *******************************************************************************/ /***************************************************************************** - Source usim_data.c +Source usim_data.c - Version 0.1 +Version 0.1 - Date 2012/10/31 +Date 2012/10/31 - Product USIM data generator +Product USIM data generator - Subsystem USIM data generator main process +Subsystem USIM data generator main process - Author Frederic Maurel +Author Frederic Maurel - Description Implements the utility used to generate data stored in the - USIM application +Description Implements the utility used to generate data stored in the + USIM application *****************************************************************************/ @@ -53,7 +53,7 @@ #include <stdlib.h> // exit #include <string.h> // memset, memcpy, strncpy -#define SELECTED_PLMN SFR1 +#define SELECTED_PLMN TEST1 /****************************************************************************/ /**************** E X T E R N A L D E F I N I T I O N S ****************/ @@ -104,7 +104,6 @@ int main (int argc, const char* argv[]) { int rc; usim_data_t usim_data; - int i; unsigned char gen_data; @@ -115,12 +114,12 @@ int main (int argc, const char* argv[]) fprintf(stderr, "Invalid parameter\n"); _display_usage(argv[0]); exit(EXIT_FAILURE); - } else if ((strcmp(argv[1], "--gen") == 0) - || (strcmp(argv[1], "-g") == 0)) { + } else if ( (strcmp(argv[1], "--gen") == 0) || + (strcmp(argv[1], "-g") == 0) ) { /* Generate USIM data files */ gen_data = TRUE; - } else if ((strcmp(argv[1], "--print") == 0) - || (strcmp(argv[1], "-p") == 0)) { + } else if ( (strcmp(argv[1], "--print") == 0) || + (strcmp(argv[1], "-p") == 0) ) { /* Display content of USIM data files */ gen_data = FALSE; } else { @@ -164,31 +163,31 @@ int main (int argc, const char* argv[]) * International Mobile Subscriber Identity * IMSI = MCC + MNC + MSIN = 208 (France) + 10 (SFR) + 00001234 */ -#warning "IMSI 208.10.00001234" + //#warning "IMSI 208.10.00001234" /* usim_data.imsi.length = 8; - usim_data.imsi.u.num.parity = EVEN_PARITY; // Parity: even - usim_data.imsi.u.num.digit1 = 2; // MCC digit 1 - usim_data.imsi.u.num.digit2 = 0; // MCC digit 2 - usim_data.imsi.u.num.digit3 = 8; // MCC digit 3 - usim_data.imsi.u.num.digit4 = 1; // MNC digit 1 - usim_data.imsi.u.num.digit5 = 0; // MNC digit 2 - usim_data.imsi.u.num.digit6 = 0b1111; // MNC digit 3 - usim_data.imsi.u.num.digit7 = 0; - usim_data.imsi.u.num.digit8 = 0; - usim_data.imsi.u.num.digit9 = 0; - usim_data.imsi.u.num.digit10 = 0; - usim_data.imsi.u.num.digit11 = 1; - usim_data.imsi.u.num.digit12 = 2; - usim_data.imsi.u.num.digit13 = 3; - usim_data.imsi.u.num.digit14 = 4; - usim_data.imsi.u.num.digit15 = 0b1111;*/ + usim_data.imsi.u.num.parity = EVEN_PARITY; // Parity: even + usim_data.imsi.u.num.digit1 = 2; // MCC digit 1 + usim_data.imsi.u.num.digit2 = 0; // MCC digit 2 + usim_data.imsi.u.num.digit3 = 8; // MCC digit 3 + usim_data.imsi.u.num.digit4 = 1; // MNC digit 1 + usim_data.imsi.u.num.digit5 = 0; // MNC digit 2 + usim_data.imsi.u.num.digit6 = 0b1111; // MNC digit 3 + usim_data.imsi.u.num.digit7 = 0; + usim_data.imsi.u.num.digit8 = 0; + usim_data.imsi.u.num.digit9 = 0; + usim_data.imsi.u.num.digit10 = 0; + usim_data.imsi.u.num.digit11 = 1; + usim_data.imsi.u.num.digit12 = 2; + usim_data.imsi.u.num.digit13 = 3; + usim_data.imsi.u.num.digit14 = 4; + usim_data.imsi.u.num.digit15 = 0b1111;*/ usim_data.imsi.length = 8; usim_data.imsi.u.num.parity = 0x0; // Type of identity = IMSI, even - usim_data.imsi.u.num.digit1 = 2;// MCC digit 1 - usim_data.imsi.u.num.digit2 = 0;// MCC digit 2 - usim_data.imsi.u.num.digit3 = 8;// MCC digit 3 - usim_data.imsi.u.num.digit4 = 1;// MNC digit 1 - usim_data.imsi.u.num.digit5 = 0;// MNC digit 2 + usim_data.imsi.u.num.digit1 = 0; // MCC digit 1 + usim_data.imsi.u.num.digit2 = 0; // MCC digit 2 + usim_data.imsi.u.num.digit3 = 1; // MCC digit 3 + usim_data.imsi.u.num.digit4 = 0; // MNC digit 1 + usim_data.imsi.u.num.digit5 = 1; // MNC digit 2 usim_data.imsi.u.num.digit6 = 0; usim_data.imsi.u.num.digit7 = 0; usim_data.imsi.u.num.digit8 = 0; @@ -210,12 +209,12 @@ int main (int argc, const char* argv[]) /* * Higher Priority PLMN search period */ - usim_data.hpplmn = 0x00; /* Disable timer */ + usim_data.hpplmn = 0x00; /* Disable timer */ /* * List of Forbidden PLMNs */ - for (i = 0; i < USIM_FPLMN_MAX; i++) { + for (int i = 0; i < USIM_FPLMN_MAX; i++) { memset(&usim_data.fplmn[i], 0xff, sizeof(plmn_t)); } @@ -292,21 +291,21 @@ int main (int argc, const char* argv[]) usim_data.msisdn.number.digit[8].lsb = 0xf; usim_data.msisdn.number.digit[9].msb = 0xf; usim_data.msisdn.number.digit[9].lsb = 0xf; - usim_data.msisdn.conf1_record_id = 0xff; /* Not used */ - usim_data.msisdn.ext1_record_id = 0xff; /* Not used */ + usim_data.msisdn.conf1_record_id = 0xff; /* Not used */ + usim_data.msisdn.ext1_record_id = 0xff; /* Not used */ /* * PLMN Network Name and Operator PLMN List */ - for (i = SFR1; i < VDF2; i++) { + for (int i = TEST1; i < VDF1; i++) { network_record_t record = network_records[i]; usim_data.pnn[i].fullname.type = USIM_PNN_FULLNAME_TAG; usim_data.pnn[i].fullname.length = strlen(record.fullname); - strncpy((char*) usim_data.pnn[i].fullname.value, record.fullname, + strncpy((char*)usim_data.pnn[i].fullname.value, record.fullname, usim_data.pnn[i].fullname.length); usim_data.pnn[i].shortname.type = USIM_PNN_SHORTNAME_TAG; usim_data.pnn[i].shortname.length = strlen(record.shortname); - strncpy((char*) usim_data.pnn[i].shortname.value, record.shortname, + strncpy((char*)usim_data.pnn[i].shortname.value, record.shortname, usim_data.pnn[i].shortname.length); usim_data.opl[i].plmn = record.plmn; usim_data.opl[i].start = record.tac_start; @@ -314,7 +313,7 @@ int main (int argc, const char* argv[]) usim_data.opl[i].record_id = i; } - for (i = VDF2; i < USIM_OPL_MAX; i++) { + for (int i = VDF2; i < USIM_OPL_MAX; i++) { memset(&usim_data.opl[i].plmn, 0xff, sizeof(plmn_t)); } @@ -332,7 +331,7 @@ int main (int argc, const char* argv[]) /* * List of user controlled PLMN selector with Access Technology */ - for (i = 0; i < USIM_PLMN_MAX; i++) { + for (int i = 0; i < USIM_PLMN_MAX; i++) { memset(&usim_data.plmn[i], 0xff, sizeof(plmn_t)); } @@ -340,30 +339,24 @@ int main (int argc, const char* argv[]) * List of operator controlled PLMN selector with Access Technology */ usim_data.oplmn[0].plmn = network_records[VDF1].plmn; - usim_data.oplmn[0].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN - | USIM_ACT_EUTRAN); + usim_data.oplmn[0].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN | USIM_ACT_EUTRAN); usim_data.oplmn[1].plmn = network_records[VDF2].plmn; - usim_data.oplmn[1].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN - | USIM_ACT_EUTRAN); + usim_data.oplmn[1].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN | USIM_ACT_EUTRAN); usim_data.oplmn[2].plmn = network_records[VDF3].plmn; - usim_data.oplmn[2].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN - | USIM_ACT_EUTRAN); + usim_data.oplmn[2].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN | USIM_ACT_EUTRAN); usim_data.oplmn[3].plmn = network_records[VDF4].plmn; - usim_data.oplmn[3].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN - | USIM_ACT_EUTRAN); + usim_data.oplmn[3].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN | USIM_ACT_EUTRAN); usim_data.oplmn[4].plmn = network_records[VDF5].plmn; - usim_data.oplmn[4].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN - | USIM_ACT_EUTRAN); + usim_data.oplmn[4].AcT = (USIM_ACT_GSM | USIM_ACT_UTRAN | USIM_ACT_EUTRAN); - for (i = 5; i < USIM_OPLMN_MAX; i++) { + for (int i = 5; i < USIM_OPLMN_MAX; i++) { memset(&usim_data.oplmn[i], 0xff, sizeof(plmn_t)); } /* * EPS Location Information */ - usim_data.epsloci.guti.gummei.plmn = - network_records[SELECTED_PLMN].plmn; + usim_data.epsloci.guti.gummei.plmn = network_records[SELECTED_PLMN].plmn; usim_data.epsloci.guti.gummei.MMEgid = DEFAULT_MME_ID; usim_data.epsloci.guti.gummei.MMEcode = DEFAULT_MME_CODE; usim_data.epsloci.guti.m_tmsi = DEFAULT_M_TMSI; @@ -373,8 +366,7 @@ int main (int argc, const char* argv[]) /* * Non-Access Stratum configuration */ - usim_data.nasconfig.NAS_SignallingPriority.type = - USIM_NAS_SIGNALLING_PRIORITY_TAG; + usim_data.nasconfig.NAS_SignallingPriority.type = USIM_NAS_SIGNALLING_PRIORITY_TAG; usim_data.nasconfig.NAS_SignallingPriority.length = 1; usim_data.nasconfig.NAS_SignallingPriority.value[0] = 0x00; usim_data.nasconfig.NMO_I_Behaviour.type = USIM_NMO_I_BEHAVIOUR_TAG; @@ -387,16 +379,13 @@ int main (int argc, const char* argv[]) #else usim_data.nasconfig.AttachWithImsi.value[0] = 0x01; #endif - usim_data.nasconfig.MinimumPeriodicSearchTimer.type = - USIM_MINIMUM_PERIODIC_SEARCH_TIMER_TAG; + usim_data.nasconfig.MinimumPeriodicSearchTimer.type = USIM_MINIMUM_PERIODIC_SEARCH_TIMER_TAG; usim_data.nasconfig.MinimumPeriodicSearchTimer.length = 1; usim_data.nasconfig.MinimumPeriodicSearchTimer.value[0] = 0x00; - usim_data.nasconfig.ExtendedAccessBarring.type = - USIM_EXTENDED_ACCESS_BARRING_TAG; + usim_data.nasconfig.ExtendedAccessBarring.type = USIM_EXTENDED_ACCESS_BARRING_TAG; usim_data.nasconfig.ExtendedAccessBarring.length = 1; usim_data.nasconfig.ExtendedAccessBarring.value[0] = 0x00; - usim_data.nasconfig.Timer_T3245_Behaviour.type = - USIM_TIMER_T3245_BEHAVIOUR_TAG; + usim_data.nasconfig.Timer_T3245_Behaviour.type = USIM_TIMER_T3245_BEHAVIOUR_TAG; usim_data.nasconfig.Timer_T3245_Behaviour.length = 1; usim_data.nasconfig.Timer_T3245_Behaviour.value[0] = 0x00; @@ -449,8 +438,7 @@ static void _display_usage(const char* command) { fprintf(stderr, "usage: %s [OPTION]\n", command); fprintf(stderr, "\t[--gen|-g]\tGenerate the USIM data file\n"); - fprintf(stderr, - "\t[--print|-p]\tDisplay the content of the USIM data file\n"); + fprintf(stderr, "\t[--print|-p]\tDisplay the content of the USIM data file\n"); fprintf(stderr, "\t[--help|-h]\tDisplay this usage\n"); const char* path = getenv("USIM_DIR"); @@ -467,7 +455,6 @@ static void _display_usage(const char* command) static void _display_usim_data(const usim_data_t* data) { int digits; - int i; printf("Administrative Data:\n"); printf("\tUE_Operation_Mode\t= 0x%.2x\n", data->ad.UE_Operation_Mode); @@ -476,10 +463,8 @@ static void _display_usim_data(const usim_data_t* data) printf("IMSI:\n"); printf("\tlength\t= %d\n", data->imsi.length); - printf("\tparity\t= %s\n", - data->imsi.u.num.parity == EVEN_PARITY ? "Even" : "Odd"); - digits = (data->imsi.length * 2) - 1 - - (data->imsi.u.num.parity == EVEN_PARITY ? 1 : 0); + printf("\tparity\t= %s\n", data->imsi.u.num.parity == EVEN_PARITY ? "Even" : "Odd"); + digits = (data->imsi.length * 2) - 1 - (data->imsi.u.num.parity == EVEN_PARITY ? 1 : 0); printf("\tdigits\t= %d\n", digits); printf("\tdigits\t= %u%u%u%u%u%x%u%u%u%u", data->imsi.u.num.digit1, // MCC digit 1 @@ -488,8 +473,10 @@ static void _display_usim_data(const usim_data_t* data) data->imsi.u.num.digit4, // MNC digit 1 data->imsi.u.num.digit5, // MNC digit 2 data->imsi.u.num.digit6, // MNC digit 3 - data->imsi.u.num.digit7, data->imsi.u.num.digit8, - data->imsi.u.num.digit9, data->imsi.u.num.digit10); + data->imsi.u.num.digit7, + data->imsi.u.num.digit8, + data->imsi.u.num.digit9, + data->imsi.u.num.digit10); if (digits >= 11) printf("%x", data->imsi.u.num.digit11); @@ -524,32 +511,37 @@ static void _display_usim_data(const usim_data_t* data) memcpy(kasme, data->securityctx.Kasme.value, USIM_K_ASME_SIZE); printf("\tKasme\t: \"%s\"\n", kasme); printf("\tulNAScount\t: 0x%.8x\n", - *(UInt32_t*) data->securityctx.ulNAScount.value); + *(UInt32_t*)data->securityctx.ulNAScount.value); printf("\tdlNAScount\t: 0x%.8x\n", - *(UInt32_t*) data->securityctx.dlNAScount.value); + *(UInt32_t*)data->securityctx.dlNAScount.value); printf("\talgorithmID\t: 0x%.2x\n\n", data->securityctx.algorithmID.value[0]); printf("MSISDN\t= %u%u%u %u%u%u%u %u%u%u%u\n\n", - data->msisdn.number.digit[0].msb, data->msisdn.number.digit[0].lsb, - data->msisdn.number.digit[1].msb, data->msisdn.number.digit[1].lsb, - data->msisdn.number.digit[2].msb, data->msisdn.number.digit[2].lsb, - data->msisdn.number.digit[3].msb, data->msisdn.number.digit[3].lsb, - data->msisdn.number.digit[4].msb, data->msisdn.number.digit[4].lsb, + data->msisdn.number.digit[0].msb, + data->msisdn.number.digit[0].lsb, + data->msisdn.number.digit[1].msb, + data->msisdn.number.digit[1].lsb, + data->msisdn.number.digit[2].msb, + data->msisdn.number.digit[2].lsb, + data->msisdn.number.digit[3].msb, + data->msisdn.number.digit[3].lsb, + data->msisdn.number.digit[4].msb, + data->msisdn.number.digit[4].lsb, data->msisdn.number.digit[5].msb); - for (i = 0; i < USIM_PNN_MAX; i++) { - printf("PNN[%d]\t= {%s, %s}\n", i, data->pnn[i].fullname.value, - data->pnn[i].shortname.value); + for (int i = 0; i < USIM_PNN_MAX; i++) { + printf("PNN[%d]\t= {%s, %s}\n", i, + data->pnn[i].fullname.value, data->pnn[i].shortname.value); } printf("\n"); - for (i = 0; i < USIM_OPL_MAX; i++) { + for (int i = 0; i < USIM_OPL_MAX; i++) { printf("OPL[%d]\t= ", i); PRINT_PLMN(data->opl[i].plmn); - printf(", TAC = [%.4x - %.4x], record_id = %d\n", data->opl[i].start, - data->opl[i].end, data->opl[i].record_id); + printf(", TAC = [%.4x - %.4x], record_id = %d\n", + data->opl[i].start, data->opl[i].end, data->opl[i].record_id); } printf("\n"); @@ -558,7 +550,7 @@ static void _display_usim_data(const usim_data_t* data) PRINT_PLMN(data->hplmn.plmn); printf(", AcT = 0x%x\n\n", data->hplmn.AcT); - for (i = 0; i < USIM_FPLMN_MAX; i++) { + for (int i = 0; i < USIM_FPLMN_MAX; i++) { printf("FPLMN[%d]\t= ", i); PRINT_PLMN(data->fplmn[i]); printf("\n"); @@ -566,7 +558,7 @@ static void _display_usim_data(const usim_data_t* data) printf("\n"); - for (i = 0; i < USIM_EHPLMN_MAX; i++) { + for (int i = 0; i < USIM_EHPLMN_MAX; i++) { printf("EHPLMN[%d]\t= ", i); PRINT_PLMN(data->ehplmn[i]); printf("\n"); @@ -574,7 +566,7 @@ static void _display_usim_data(const usim_data_t* data) printf("\n"); - for (i = 0; i < USIM_PLMN_MAX; i++) { + for (int i = 0; i < USIM_PLMN_MAX; i++) { printf("PLMN[%d]\t\t= ", i); PRINT_PLMN(data->plmn[i].plmn); printf(", AcTPLMN = 0x%x", data->plmn[i].AcT); @@ -583,7 +575,7 @@ static void _display_usim_data(const usim_data_t* data) printf("\n"); - for (i = 0; i < USIM_OPLMN_MAX; i++) { + for (int i = 0; i < USIM_OPLMN_MAX; i++) { printf("OPLMN[%d]\t= ", i); PRINT_PLMN(data->oplmn[i].plmn); printf(", AcTPLMN = 0x%x", data->oplmn[i].AcT); @@ -603,12 +595,14 @@ static void _display_usim_data(const usim_data_t* data) printf("PSLOCI:\n"); printf("\tP-TMSI = 0x%.4x\n", data->psloci.p_tmsi); - printf("\tsignature = 0x%x 0x%x 0x%x\n", data->psloci.signature[0], - data->psloci.signature[1], data->psloci.signature[2]); + printf("\tsignature = 0x%x 0x%x 0x%x\n", + data->psloci.signature[0], + data->psloci.signature[1], + data->psloci.signature[2]); printf("\tRAI\t: PLMN = "); PRINT_PLMN(data->psloci.rai.plmn); - printf(", LAC = 0x%.2x, RAC = 0x%.1x\n", data->psloci.rai.lac, - data->psloci.rai.rac); + printf(", LAC = 0x%.2x, RAC = 0x%.1x\n", + data->psloci.rai.lac, data->psloci.rai.rac); printf("\tstatus\t= %d\n\n", data->psloci.status); printf("EPSLOCI:\n"); @@ -620,7 +614,8 @@ static void _display_usim_data(const usim_data_t* data) printf(", M-TMSI = 0x%.4x\n", data->epsloci.guti.m_tmsi); printf("\tTAI\t: PLMN = "); PRINT_PLMN(data->epsloci.tai.plmn); - printf(", TAC = 0x%.2x\n", data->epsloci.tai.tac); + printf(", TAC = 0x%.2x\n", + data->epsloci.tai.tac); printf("\tstatus\t= %d\n\n", data->epsloci.status); printf("NASCONFIG:\n"); diff --git a/openair-cn/NAS/Makefile.UE b/openair-cn/NAS/Makefile.UE index 09b96b3ab..7700c683d 100644 --- a/openair-cn/NAS/Makefile.UE +++ b/openair-cn/NAS/Makefile.UE @@ -307,7 +307,7 @@ CFLAGS = \ -g \ -Wall \ -DNAS_UE \ - -DUE_BUILD \ + -DNAS_BUILT_IN_UE \ -Wuninitialized \ -Werror=implicit-function-declaration \ $(UENAS_CFLAGS) \ diff --git a/openair-cn/NAS/Makefile.am b/openair-cn/NAS/Makefile.am index 13e9e1e5b..4e71ef5e7 100644 --- a/openair-cn/NAS/Makefile.am +++ b/openair-cn/NAS/Makefile.am @@ -33,7 +33,7 @@ libnas_la_LDFLAGS = -all-static AM_CFLAGS = \ @ADD_CFLAGS@ \ -DNAS_MME \ - -DEPC_BUILD \ + -DNAS_BUILT_IN_EPC \ -DENABLE_ITTI \ -I$(top_srcdir)/COMMON \ -I$(top_srcdir)/SECU \ diff --git a/openair-cn/NAS/nas_itti_messaging.c b/openair-cn/NAS/nas_itti_messaging.c index 3621fdab5..4e7ea4b92 100644 --- a/openair-cn/NAS/nas_itti_messaging.c +++ b/openair-cn/NAS/nas_itti_messaging.c @@ -31,15 +31,15 @@ #include "intertask_interface.h" #include "nas_itti_messaging.h" -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(UE_BUILD) && defined(NAS_UE))) -# if (defined(EPC_BUILD) && defined(NAS_MME)) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) +# if (defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) # define TASK_ORIGIN TASK_NAS_MME # else # define TASK_ORIGIN TASK_NAS_UE # endif #endif -#if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +#if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) static const UInt8_t emm_message_ids[] = { ATTACH_REQUEST, ATTACH_ACCEPT, @@ -188,7 +188,7 @@ int nas_itti_protected_msg(const char *buffer, const nas_message_t *msg, const i } #endif -#if defined(EPC_BUILD) && defined(NAS_MME) +#if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) int nas_itti_dl_data_req(const uint32_t ue_id, void *const data, const uint32_t length) { @@ -205,7 +205,7 @@ int nas_itti_dl_data_req(const uint32_t ue_id, void *const data, #endif -#if defined(UE_BUILD) && defined(NAS_UE) +#if defined(NAS_BUILT_IN_UE) && defined(NAS_UE) extern unsigned char NB_eNB_INST; int nas_itti_cell_info_req(const plmn_t plmnID, const Byte_t rat) diff --git a/openair-cn/NAS/nas_itti_messaging.h b/openair-cn/NAS/nas_itti_messaging.h index b425c550b..7293cd663 100644 --- a/openair-cn/NAS/nas_itti_messaging.h +++ b/openair-cn/NAS/nas_itti_messaging.h @@ -37,7 +37,7 @@ #ifndef NAS_ITTI_MESSAGING_H_ #define NAS_ITTI_MESSAGING_H_ -# if ((defined(EPC_BUILD) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(UE_BUILD) && defined(NAS_UE))) +# if ((defined(NAS_BUILT_IN_EPC) && defined(NAS_MME)) || (defined(ENABLE_NAS_UE_LOGGING) && defined(NAS_BUILT_IN_UE) && defined(NAS_UE))) int nas_itti_plain_msg( const char *buffer, const nas_message_t *msg, @@ -51,7 +51,7 @@ int nas_itti_protected_msg( const int instance); # endif -# if defined(EPC_BUILD) && defined(NAS_MME) +# if defined(NAS_BUILT_IN_EPC) && defined(NAS_MME) #include "conversions.h" int nas_itti_dl_data_req( @@ -223,7 +223,7 @@ static inline void nas_itti_establish_rej( } # endif -# if defined(UE_BUILD) && defined(NAS_UE) +# if defined(NAS_BUILT_IN_UE) && defined(NAS_UE) int nas_itti_cell_info_req(const plmn_t plmnID, const Byte_t rat); int nas_itti_nas_establish_req(as_cause_t cause, as_call_type_t type, as_stmsi_t s_tmsi, plmn_t plmnID, Byte_t *data_pP, UInt32_t lengthP); diff --git a/openair-cn/OAI_EPC/oai_epc.c b/openair-cn/OAI_EPC/oai_epc.c index bf9156c0d..66eadb9d8 100644 --- a/openair-cn/OAI_EPC/oai_epc.c +++ b/openair-cn/OAI_EPC/oai_epc.c @@ -85,7 +85,9 @@ int main(int argc, char *argv[]) CHECK_INIT_RETURN(mme_app_init(&mme_config)); CHECK_INIT_RETURN(s6a_init(&mme_config)); CHECK_INIT_RETURN(sgw_lite_init(mme_config.config_file)); +#if ! defined(ENABLE_USE_GTPU_IN_KERNEL) CHECK_INIT_RETURN(sgi_init(&spgw_config.pgw_config)); +#endif /* Handle signals here */ itti_wait_tasks_end(); diff --git a/openair-cn/S1AP/s1ap_eNB.c b/openair-cn/S1AP/s1ap_eNB.c index 489fc0f74..fa50924fe 100644 --- a/openair-cn/S1AP/s1ap_eNB.c +++ b/openair-cn/S1AP/s1ap_eNB.c @@ -55,6 +55,9 @@ #include "s1ap_eNB_itti_messaging.h" +#include "s1ap_eNB_ue_context.h" // test, to be removed + + #include "assertions.h" #include "conversions.h" @@ -322,8 +325,22 @@ void *s1ap_eNB_task(void *arg) break; case S1AP_UE_CONTEXT_RELEASE_REQ: { + s1ap_eNB_instance_t *s1ap_eNB_instance_p = NULL; // test + struct s1ap_eNB_ue_context_s *ue_context_p = NULL; // test + s1ap_ue_context_release_req(ITTI_MESSAGE_GET_INSTANCE(received_msg), &S1AP_UE_CONTEXT_RELEASE_REQ(received_msg)); + + + s1ap_eNB_instance_p = s1ap_eNB_get_instance(ITTI_MESSAGE_GET_INSTANCE(received_msg)); // test + DevAssert(s1ap_eNB_instance_p != NULL); // test + + if ((ue_context_p = s1ap_eNB_get_ue_context(s1ap_eNB_instance_p, + S1AP_UE_CONTEXT_RELEASE_REQ(received_msg).eNB_ue_s1ap_id)) == NULL) { // test + /* The context for this eNB ue s1ap id doesn't exist in the map of eNB UEs */ + S1AP_ERROR("Failed to find ue context associated with eNB ue s1ap id: %u\n", + S1AP_UE_CONTEXT_RELEASE_REQ(received_msg).eNB_ue_s1ap_id); // test + } // test } break; diff --git a/openair-cn/S1AP/s1ap_eNB_context_management_procedures.c b/openair-cn/S1AP/s1ap_eNB_context_management_procedures.c index e02bc9be7..adcc5dcd3 100755 --- a/openair-cn/S1AP/s1ap_eNB_context_management_procedures.c +++ b/openair-cn/S1AP/s1ap_eNB_context_management_procedures.c @@ -48,6 +48,9 @@ #include "s1ap_eNB_nas_procedures.h" #include "s1ap_eNB_management_procedures.h" #include "s1ap_eNB_context_management_procedures.h" +#ifdef MESSAGE_CHART_GENERATOR +#include "msc.h" +#endif int s1ap_ue_context_release_complete(instance_t instance, @@ -98,6 +101,18 @@ int s1ap_ue_context_release_complete(instance_t instance, return -1; } +#ifdef MESSAGE_CHART_GENERATOR + msc_log_tx_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + buffer, + length, + MSC_AS_TIME_FMT" UEContextRelease successfulOutcome eNB_ue_s1ap_id %u mme_ue_s1ap_id %u", + 0,0, //MSC_AS_TIME_ARGS(ctxt_pP), + ue_ctxt_release_complete_ies_p->eNB_UE_S1AP_ID, + ue_ctxt_release_complete_ies_p->mme_ue_s1ap_id); +#endif + /* UE associated signalling -> use the allocated stream */ s1ap_eNB_itti_send_sctp_data_req(s1ap_eNB_instance_p->instance, ue_context_p->mme_ref->assoc_id, buffer, @@ -114,7 +129,12 @@ int s1ap_ue_context_release_complete(instance_t instance, if ((ue_context2_p = RB_REMOVE(s1ap_ue_map, &s1ap_eNB_instance_p->s1ap_ue_head, ue_context_p)) == NULL) { + S1AP_WARN("Removed UE context eNB_ue_s1ap_id %u\n", + ue_context2_p->eNB_ue_s1ap_id); s1ap_eNB_free_ue_context(ue_context2_p); + } else { + S1AP_WARN("Removing UE context eNB_ue_s1ap_id %u: did not find context\n", + ue_context_p->eNB_ue_s1ap_id); } return ret; @@ -195,6 +215,18 @@ int s1ap_ue_context_release_req(instance_t instance, return -1; } +#ifdef MESSAGE_CHART_GENERATOR + msc_log_tx_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + buffer, + length, + MSC_AS_TIME_FMT" UEContextReleaseRequest initiatingMessage eNB_ue_s1ap_id %u mme_ue_s1ap_id %u", + 0,0,//MSC_AS_TIME_ARGS(ctxt_pP), + ue_ctxt_release_request_ies_p->eNB_UE_S1AP_ID, + ue_ctxt_release_request_ies_p->mme_ue_s1ap_id); +#endif + /* UE associated signalling -> use the allocated stream */ s1ap_eNB_itti_send_sctp_data_req(s1ap_eNB_instance_p->instance, ue_context_p->mme_ref->assoc_id, buffer, diff --git a/openair-cn/S1AP/s1ap_eNB_defs.h b/openair-cn/S1AP/s1ap_eNB_defs.h index c1658fd08..3474f9e7f 100644 --- a/openair-cn/S1AP/s1ap_eNB_defs.h +++ b/openair-cn/S1AP/s1ap_eNB_defs.h @@ -226,7 +226,7 @@ typedef struct { uint16_t global_cnx_id; } s1ap_eNB_internal_data_t; -inline int s1ap_eNB_compare_assoc_id( +int s1ap_eNB_compare_assoc_id( struct s1ap_eNB_mme_data_s *p1, struct s1ap_eNB_mme_data_s *p2); /* Generate the tree management functions */ diff --git a/openair-cn/S1AP/s1ap_eNB_nas_procedures.c b/openair-cn/S1AP/s1ap_eNB_nas_procedures.c index f88a5f674..44843081c 100644 --- a/openair-cn/S1AP/s1ap_eNB_nas_procedures.c +++ b/openair-cn/S1AP/s1ap_eNB_nas_procedures.c @@ -47,9 +47,14 @@ #include "s1ap_eNB_ue_context.h" #include "s1ap_eNB_nas_procedures.h" #include "s1ap_eNB_management_procedures.h" +#ifdef MESSAGE_CHART_GENERATOR +#include "msc.h" +#endif +//------------------------------------------------------------------------------ int s1ap_eNB_handle_nas_first_req( instance_t instance, s1ap_nas_first_req_t *s1ap_nas_first_req_p) +//------------------------------------------------------------------------------ { s1ap_eNB_instance_t *instance_p = NULL; struct s1ap_eNB_mme_data_s *mme_desc_p = NULL; @@ -221,8 +226,21 @@ int s1ap_eNB_handle_nas_first_req( mme_desc_p->nextstream += 1; } +#if defined(S1AP_LIMIT_STREAM_ID_TO_1) + mme_desc_p->nextstream = 1; +#endif ue_desc_p->stream = mme_desc_p->nextstream; +#ifdef MESSAGE_CHART_GENERATOR + msc_log_tx_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + (const char *)NULL, + 0, + MSC_AS_TIME_FMT" initialUEMessage initiatingMessage eNB_ue_s1ap_id %u", + 0,0,//MSC_AS_TIME_ARGS(ctxt_pP), + initial_ue_message_p->eNB_UE_S1AP_ID); +#endif /* Send encoded message over sctp */ s1ap_eNB_itti_send_sctp_data_req(instance_p->instance, mme_desc_p->assoc_id, buffer, length, ue_desc_p->stream); @@ -230,11 +248,13 @@ int s1ap_eNB_handle_nas_first_req( return 0; } +//------------------------------------------------------------------------------ int s1ap_eNB_handle_nas_downlink(const uint32_t assoc_id, const uint32_t stream, const struct s1ap_message_s *const message_p) +//------------------------------------------------------------------------------ { - S1ap_DownlinkNASTransportIEs_t *downlink_NAS_transport_p = NULL; + const S1ap_DownlinkNASTransportIEs_t *downlink_NAS_transport_p = NULL; s1ap_eNB_mme_data_t *mme_desc_p = NULL; s1ap_eNB_ue_context_t *ue_desc_p = NULL; @@ -262,7 +282,19 @@ int s1ap_eNB_handle_nas_downlink(const uint32_t assoc_id, if ((ue_desc_p = s1ap_eNB_get_ue_context(s1ap_eNB_instance, downlink_NAS_transport_p->eNB_UE_S1AP_ID)) == NULL) { - S1AP_ERROR("[SCTP %d] Received NAS downlink message for non existing UE context: 0x%08x %l(10)\n", +#ifdef MESSAGE_CHART_GENERATOR + msc_log_rx_discarded_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + (const char *)downlink_NAS_transport_p, + sizeof(S1ap_DownlinkNASTransportIEs_t), + MSC_AS_TIME_FMT" downlinkNASTransport eNB_ue_s1ap_id %u mme_ue_s1ap_id %u", + 0,0,//MSC_AS_TIME_ARGS(ctxt_pP), + downlink_NAS_transport_p->eNB_UE_S1AP_ID, + downlink_NAS_transport_p->mme_ue_s1ap_id); +#endif + + S1AP_ERROR("[SCTP %d] Received NAS downlink message for non existing UE context eNB_UE_S1AP_ID: 0x%"PRIx32" %u\n", assoc_id, downlink_NAS_transport_p->eNB_UE_S1AP_ID, downlink_NAS_transport_p->eNB_UE_S1AP_ID); @@ -277,7 +309,7 @@ int s1ap_eNB_handle_nas_downlink(const uint32_t assoc_id, } else { /* We already have a mme ue s1ap id check the received is the same */ if (ue_desc_p->mme_ue_s1ap_id != downlink_NAS_transport_p->mme_ue_s1ap_id) { - S1AP_ERROR("[SCTP %d] Mismatch in MME UE S1AP ID (0x%08x != 0x%08x)\n", + S1AP_ERROR("[SCTP %d] Mismatch in MME UE S1AP ID (0x%"PRIx32" != 0x%"PRIx32")\n", assoc_id, downlink_NAS_transport_p->mme_ue_s1ap_id, ue_desc_p->mme_ue_s1ap_id @@ -285,6 +317,18 @@ int s1ap_eNB_handle_nas_downlink(const uint32_t assoc_id, } } +#ifdef MESSAGE_CHART_GENERATOR + msc_log_rx_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + (const char *)downlink_NAS_transport_p, + sizeof(S1ap_DownlinkNASTransportIEs_t), + MSC_AS_TIME_FMT" downlinkNASTransport eNB_ue_s1ap_id %u mme_ue_s1ap_id %u", + 0,0,//MSC_AS_TIME_ARGS(ctxt_pP), + downlink_NAS_transport_p->eNB_UE_S1AP_ID, + downlink_NAS_transport_p->mme_ue_s1ap_id); +#endif + /* Forward the NAS PDU to RRC */ s1ap_eNB_itti_send_nas_downlink_ind(s1ap_eNB_instance->instance, ue_desc_p->ue_initial_id, @@ -292,12 +336,15 @@ int s1ap_eNB_handle_nas_downlink(const uint32_t assoc_id, downlink_NAS_transport_p->nas_pdu.buf, downlink_NAS_transport_p->nas_pdu.size); - ue_desc_p->ue_initial_id = 0; + // LG: Why set to 0 ?? + //ue_desc_p->ue_initial_id = 0; return 0; } +//------------------------------------------------------------------------------ int s1ap_eNB_nas_uplink(instance_t instance, s1ap_uplink_nas_t *s1ap_uplink_nas_p) +//------------------------------------------------------------------------------ { struct s1ap_eNB_ue_context_s *ue_context_p; s1ap_eNB_instance_t *s1ap_eNB_instance_p; @@ -370,6 +417,18 @@ int s1ap_eNB_nas_uplink(instance_t instance, s1ap_uplink_nas_t *s1ap_uplink_nas_ return -1; } +#ifdef MESSAGE_CHART_GENERATOR + msc_log_tx_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + (const char *)NULL, + 0, + MSC_AS_TIME_FMT" uplinkNASTransport initiatingMessage eNB_ue_s1ap_id %u mme_ue_s1ap_id %u", + 0,0,//MSC_AS_TIME_ARGS(ctxt_pP), + uplink_NAS_transport_p->eNB_UE_S1AP_ID, + uplink_NAS_transport_p->mme_ue_s1ap_id); +#endif + /* UE associated signalling -> use the allocated stream */ s1ap_eNB_itti_send_sctp_data_req(s1ap_eNB_instance_p->instance, ue_context_p->mme_ref->assoc_id, buffer, @@ -378,8 +437,11 @@ int s1ap_eNB_nas_uplink(instance_t instance, s1ap_uplink_nas_t *s1ap_uplink_nas_ return 0; } + +//------------------------------------------------------------------------------ void s1ap_eNB_nas_non_delivery_ind(instance_t instance, s1ap_nas_non_delivery_ind_t *s1ap_nas_non_delivery_ind) +//------------------------------------------------------------------------------ { struct s1ap_eNB_ue_context_s *ue_context_p; s1ap_eNB_instance_t *s1ap_eNB_instance_p; @@ -426,6 +488,17 @@ void s1ap_eNB_nas_non_delivery_ind(instance_t instance, /* Send a dummy cause */ nas_non_delivery_p->cause.present = S1ap_Cause_PR_radioNetwork; nas_non_delivery_p->cause.choice.radioNetwork = S1ap_CauseRadioNetwork_radio_connection_with_ue_lost; +#ifdef MESSAGE_CHART_GENERATOR + msc_log_tx_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + (const char *)s1ap_nas_non_delivery_ind, + sizeof(s1ap_nas_non_delivery_ind_t), + MSC_AS_TIME_FMT" NASNonDeliveryIndication initiatingMessage eNB_ue_s1ap_id %u mme_ue_s1ap_id %u", + 0,0,//MSC_AS_TIME_ARGS(ctxt_pP), + nas_non_delivery_p->eNB_UE_S1AP_ID, + nas_non_delivery_p->mme_ue_s1ap_id); +#endif /* UE associated signalling -> use the allocated stream */ s1ap_eNB_itti_send_sctp_data_req(s1ap_eNB_instance_p->instance, @@ -433,8 +506,10 @@ void s1ap_eNB_nas_non_delivery_ind(instance_t instance, length, ue_context_p->stream); } +//------------------------------------------------------------------------------ int s1ap_eNB_initial_ctxt_resp( instance_t instance, s1ap_initial_context_setup_resp_t *initial_ctxt_resp_p) +//------------------------------------------------------------------------------ { s1ap_eNB_instance_t *s1ap_eNB_instance_p = NULL; struct s1ap_eNB_ue_context_s *ue_context_p = NULL; @@ -505,6 +580,18 @@ int s1ap_eNB_initial_ctxt_resp( return -1; } +#ifdef MESSAGE_CHART_GENERATOR + msc_log_tx_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + (const char *)buffer, + length, + MSC_AS_TIME_FMT" InitialContextSetup successfulOutcome eNB_ue_s1ap_id %u mme_ue_s1ap_id %u", + 0,0,//MSC_AS_TIME_ARGS(ctxt_pP), + initial_ies_p->eNB_UE_S1AP_ID, + initial_ies_p->mme_ue_s1ap_id); +#endif + /* UE associated signalling -> use the allocated stream */ s1ap_eNB_itti_send_sctp_data_req(s1ap_eNB_instance_p->instance, ue_context_p->mme_ref->assoc_id, buffer, @@ -513,8 +600,10 @@ int s1ap_eNB_initial_ctxt_resp( return ret; } +//------------------------------------------------------------------------------ int s1ap_eNB_ue_capabilities(instance_t instance, s1ap_ue_cap_info_ind_t *ue_cap_info_ind_p) +//------------------------------------------------------------------------------ { s1ap_eNB_instance_t *s1ap_eNB_instance_p; struct s1ap_eNB_ue_context_s *ue_context_p; @@ -572,6 +661,18 @@ int s1ap_eNB_ue_capabilities(instance_t instance, return -1; } +#ifdef MESSAGE_CHART_GENERATOR + msc_log_tx_message( + MSC_S1AP_ENB, + MSC_S1AP_MME, + (const char *)buffer, + length, + MSC_AS_TIME_FMT" UECapabilityInfoIndication initiatingMessage eNB_ue_s1ap_id %u mme_ue_s1ap_id %u", + 0,0,//MSC_AS_TIME_ARGS(ctxt_pP), + ue_cap_info_ind_ies_p->eNB_UE_S1AP_ID, + ue_cap_info_ind_ies_p->mme_ue_s1ap_id); +#endif + /* UE associated signalling -> use the allocated stream */ s1ap_eNB_itti_send_sctp_data_req(s1ap_eNB_instance_p->instance, ue_context_p->mme_ref->assoc_id, buffer, diff --git a/openair-cn/S1AP/s1ap_eNB_ue_context.h b/openair-cn/S1AP/s1ap_eNB_ue_context.h index 797ef18e2..911f6e367 100644 --- a/openair-cn/S1AP/s1ap_eNB_ue_context.h +++ b/openair-cn/S1AP/s1ap_eNB_ue_context.h @@ -78,7 +78,7 @@ typedef struct s1ap_eNB_ue_context_s { s1ap_eNB_instance_t *eNB_instance; } s1ap_eNB_ue_context_t; -inline int s1ap_eNB_compare_eNB_ue_s1ap_id( +int s1ap_eNB_compare_eNB_ue_s1ap_id( struct s1ap_eNB_ue_context_s *p1, struct s1ap_eNB_ue_context_s *p2); /* Generate the tree management functions prototypes */ diff --git a/openair-cn/S1AP/s1ap_mme.c b/openair-cn/S1AP/s1ap_mme.c index bcbdad3e6..431228c0a 100644 --- a/openair-cn/S1AP/s1ap_mme.c +++ b/openair-cn/S1AP/s1ap_mme.c @@ -291,14 +291,14 @@ void s1ap_dump_ue(ue_description_t *ue_ref) #endif } -eNB_description_t* s1ap_is_eNB_id_in_list(uint32_t eNB_id) +eNB_description_t* s1ap_is_eNB_id_in_list(const uint32_t eNB_id) { eNB_description_t *eNB_ref; STAILQ_FOREACH(eNB_ref, &eNB_list_head, eNB_entries) { if (eNB_ref->eNB_id == eNB_id) { - /* We fount a matching reference, return it */ + /* We found a matching reference, return it */ return eNB_ref; } } @@ -306,14 +306,14 @@ eNB_description_t* s1ap_is_eNB_id_in_list(uint32_t eNB_id) return eNB_ref; } -eNB_description_t* s1ap_is_eNB_assoc_id_in_list(uint32_t sctp_assoc_id) +eNB_description_t* s1ap_is_eNB_assoc_id_in_list(const uint32_t sctp_assoc_id) { eNB_description_t *eNB_ref; STAILQ_FOREACH(eNB_ref, &eNB_list_head, eNB_entries) { if (eNB_ref->sctp_assoc_id == sctp_assoc_id) { - /* We fount a matching reference, return it */ + /* We found a matching reference, return it */ return eNB_ref; } } @@ -322,7 +322,7 @@ eNB_description_t* s1ap_is_eNB_assoc_id_in_list(uint32_t sctp_assoc_id) } ue_description_t *s1ap_is_ue_eNB_id_in_list(eNB_description_t *eNB_ref, - uint32_t eNB_ue_s1ap_id) + const uint32_t eNB_ue_s1ap_id) { ue_description_t *ue_ref; @@ -337,7 +337,7 @@ ue_description_t *s1ap_is_ue_eNB_id_in_list(eNB_description_t *eNB_ref, return NULL; } -ue_description_t* s1ap_is_ue_mme_id_in_list(uint32_t mme_ue_s1ap_id) +ue_description_t* s1ap_is_ue_mme_id_in_list(const uint32_t mme_ue_s1ap_id) { ue_description_t *ue_ref; @@ -345,7 +345,7 @@ ue_description_t* s1ap_is_ue_mme_id_in_list(uint32_t mme_ue_s1ap_id) STAILQ_FOREACH(eNB_ref, &eNB_list_head, eNB_entries) { STAILQ_FOREACH(ue_ref, &eNB_ref->ue_list_head, ue_entries) { - // We fount a matching reference, return it + // We found a matching reference, return it if (ue_ref->mme_ue_s1ap_id == mme_ue_s1ap_id) { return ue_ref; } @@ -355,7 +355,7 @@ ue_description_t* s1ap_is_ue_mme_id_in_list(uint32_t mme_ue_s1ap_id) return NULL; } -ue_description_t* s1ap_is_teid_in_list(uint32_t teid) +ue_description_t* s1ap_is_teid_in_list(const uint32_t teid) { ue_description_t *ue_ref; @@ -363,7 +363,7 @@ ue_description_t* s1ap_is_teid_in_list(uint32_t teid) STAILQ_FOREACH(eNB_ref, &eNB_list_head, eNB_entries) { STAILQ_FOREACH(ue_ref, &eNB_ref->ue_list_head, ue_entries) { - // We fount a matching reference, return it + // We found a matching reference, return it if (ue_ref->teid == teid) { return ue_ref; } @@ -397,7 +397,7 @@ eNB_description_t* s1ap_new_eNB(void) return eNB_ref; } -ue_description_t* s1ap_new_ue(uint32_t sctp_assoc_id) +ue_description_t* s1ap_new_ue(const uint32_t sctp_assoc_id) { eNB_description_t *eNB_ref = NULL; @@ -438,6 +438,7 @@ void s1ap_remove_ue(ue_description_t *ue_ref) /* Freeing memory */ free(ue_ref); + ue_ref = NULL; } void s1ap_remove_eNB(eNB_description_t *eNB_ref) @@ -456,6 +457,7 @@ void s1ap_remove_eNB(eNB_description_t *eNB_ref) STAILQ_REMOVE(&eNB_list_head, eNB_ref, eNB_description_s, eNB_entries); free(eNB_ref); + eNB_ref = NULL; nb_eNB_associated--; } diff --git a/openair-cn/S1AP/s1ap_mme.h b/openair-cn/S1AP/s1ap_mme.h index d802fb2b9..1b33ec297 100644 --- a/openair-cn/S1AP/s1ap_mme.h +++ b/openair-cn/S1AP/s1ap_mme.h @@ -123,27 +123,27 @@ int s1ap_mme_init(const mme_config_t *mme_config); * \param eNB_id The unique eNB id to search in list * @returns NULL if no eNB matchs the eNB id, or reference to the eNB element in list if matches **/ -eNB_description_t* s1ap_is_eNB_id_in_list(uint32_t eNB_id); +eNB_description_t* s1ap_is_eNB_id_in_list(const uint32_t eNB_id); /** \brief Look for given eNB SCTP assoc id in the list * \param eNB_id The unique sctp assoc id to search in list * @returns NULL if no eNB matchs the sctp assoc id, or reference to the eNB element in list if matches **/ -eNB_description_t* s1ap_is_eNB_assoc_id_in_list(uint32_t sctp_assoc_id); +eNB_description_t* s1ap_is_eNB_assoc_id_in_list(const uint32_t sctp_assoc_id); /** \brief Look for given ue eNB id in the list * \param eNB_id The unique ue_eNB_id to search in list * @returns NULL if no UE matchs the ue_eNB_id, or reference to the ue element in list if matches **/ ue_description_t* s1ap_is_ue_eNB_id_in_list(eNB_description_t *eNB_ref, - uint32_t eNB_ue_s1ap_id); + const uint32_t eNB_ue_s1ap_id); /** \brief Look for given ue mme id in the list * \param eNB_id The unique ue_mme_id to search in list * @returns NULL if no UE matchs the ue_mme_id, or reference to the ue element in list if matches **/ -ue_description_t* s1ap_is_ue_mme_id_in_list(uint32_t ue_mme_id); -ue_description_t* s1ap_is_teid_in_list(uint32_t teid); +ue_description_t* s1ap_is_ue_mme_id_in_list(const uint32_t ue_mme_id); +ue_description_t* s1ap_is_teid_in_list(const uint32_t teid); /** \brief Allocate and add to the list a new eNB descriptor * @returns Reference to the new eNB element in list @@ -154,7 +154,7 @@ eNB_description_t* s1ap_new_eNB(void); * \param sctp_assoc_id association ID over SCTP * @returns Reference to the new UE element in list **/ -ue_description_t* s1ap_new_ue(uint32_t sctp_assoc_id); +ue_description_t* s1ap_new_ue(const uint32_t sctp_assoc_id); /** \brief Dump the eNB list * Calls dump_eNB for each eNB in list diff --git a/openair-cn/S1AP/s1ap_mme_handlers.c b/openair-cn/S1AP/s1ap_mme_handlers.c index 0fee597f0..8885daa59 100644 --- a/openair-cn/S1AP/s1ap_mme_handlers.c +++ b/openair-cn/S1AP/s1ap_mme_handlers.c @@ -77,7 +77,7 @@ s1ap_message_decoded_callback messages_callback[][3] = { { 0, 0, 0 }, /* ErrorIndication */ { s1ap_mme_handle_nas_non_delivery, 0, 0 }, /* NASNonDeliveryIndication */ { s1ap_mme_handle_s1_setup_request, 0, 0 }, /* S1Setup */ - { 0, 0, 0 }, /* UEContextReleaseRequest */ + { s1ap_mme_handle_ue_context_release_request, 0, 0 }, /* UEContextReleaseRequest */ { 0, 0, 0 }, /* DownlinkS1cdma2000tunneling */ { 0, 0, 0 }, /* UplinkS1cdma2000tunneling */ { 0, 0, 0 }, /* UEContextModification */ @@ -586,6 +586,9 @@ int s1ap_mme_handle_ue_context_release_request(uint32_t assoc_id, /* MME doesn't know the MME UE S1AP ID provided. * TODO */ + S1AP_DEBUG("UE_CONTEXT_RELEASE_REQUEST ignored cause could not get context with mme_ue_s1ap_id 0x%08x %u(10)\n", + ueContextReleaseRequest_p->mme_ue_s1ap_id, + ueContextReleaseRequest_p->mme_ue_s1ap_id); return -1; } else { if (ue_ref->eNB_ue_s1ap_id == (ueContextReleaseRequest_p->eNB_UE_S1AP_ID & @@ -594,6 +597,8 @@ int s1ap_mme_handle_ue_context_release_request(uint32_t assoc_id, * -> Send a UE context Release Command to eNB. * TODO */ + s1ap_mme_generate_ue_context_release_command(ue_ref); + // UE context will be removed when receiving UE_CONTEXT_RELEASE_COMPLETE } else { // TODO return -1; @@ -888,15 +893,15 @@ int s1ap_handle_create_session_response(SgwCreateSessionResponse initialContextSetupRequest_p->eNB_UE_S1AP_ID = ue_ref->eNB_ue_s1ap_id; /* uEaggregateMaximumBitrateDL and uEaggregateMaximumBitrateUL expressed in term of bits/sec */ - // asn_int642INTEGER( - // &initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateDL, - // 100000000UL); - // asn_int642INTEGER( - // &initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateUL, - // 50000000UL); - - initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateDL = 100000000UL; - initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateUL = 50000000UL; + asn_int642INTEGER( + &initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateDL, + 100000000UL); + asn_int642INTEGER( + &initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateUL, + 50000000UL); + + //initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateDL = 100000000UL; + //initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateUL = 50000000UL; e_RABToBeSetup.e_RAB_ID = session_response_p->bearer_context_created.eps_bearer_id; /* ??? */ diff --git a/openair-cn/S1AP/s1ap_mme_nas_procedures.c b/openair-cn/S1AP/s1ap_mme_nas_procedures.c index 22bc99dc4..aa60b94be 100644 --- a/openair-cn/S1AP/s1ap_mme_nas_procedures.c +++ b/openair-cn/S1AP/s1ap_mme_nas_procedures.c @@ -30,6 +30,7 @@ #include <stdio.h> #include <stdint.h> + #include "s1ap_common.h" #include "s1ap_ies_defs.h" #include "s1ap_mme_encoder.h" @@ -211,7 +212,7 @@ int s1ap_generate_downlink_nas_transport(const uint32_t ue_id, void * const data /* If the UE-associated logical S1-connection is not established, * the MME shall allocate a unique MME UE S1AP ID to be used for the UE. */ - DevMessage("This case is not handled right now\n"); + S1AP_DEBUG("Unknown UE MME ID %08X, This case is not handled right now\n", ue_id); return -1; } else { @@ -580,8 +581,8 @@ void s1ap_handle_conn_est_cnf(const mme_app_connection_establishment_cnf_t * con initialContextSetupRequest_p->eNB_UE_S1AP_ID = (unsigned long)ue_ref->eNB_ue_s1ap_id; /* uEaggregateMaximumBitrateDL and uEaggregateMaximumBitrateUL expressed in term of bits/sec */ - initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateDL = conn_est_cnf_pP->ambr.br_dl; - initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateUL = conn_est_cnf_pP->ambr.br_ul; + asn_uint642INTEGER(&initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateDL, conn_est_cnf_pP->ambr.br_dl); + asn_uint642INTEGER(&initialContextSetupRequest_p->uEaggregateMaximumBitrate.uEaggregateMaximumBitRateUL, conn_est_cnf_pP->ambr.br_ul); e_RABToBeSetup.e_RAB_ID = conn_est_cnf_pP->eps_bearer_id; //5; e_RABToBeSetup.e_RABlevelQoSParameters.qCI = conn_est_cnf_pP->bearer_qos_qci; diff --git a/openair-cn/S1AP/s1ap_mme_retransmission.c b/openair-cn/S1AP/s1ap_mme_retransmission.c index 3b26a2bc6..1595462d0 100644 --- a/openair-cn/S1AP/s1ap_mme_retransmission.c +++ b/openair-cn/S1AP/s1ap_mme_retransmission.c @@ -55,7 +55,7 @@ RB_PROTOTYPE(s1ap_timer_map, s1ap_timer_map_s, entries, RB_GENERATE(s1ap_timer_map, s1ap_timer_map_s, entries, s1ap_mme_timer_map_compare_id); -inline int s1ap_mme_timer_map_compare_id( +int s1ap_mme_timer_map_compare_id( struct s1ap_timer_map_s *p1, struct s1ap_timer_map_s *p2) { if (p1->mme_ue_s1ap_id > 0) { diff --git a/openair-cn/S1AP/s1ap_mme_retransmission.h b/openair-cn/S1AP/s1ap_mme_retransmission.h index f3330f0d8..f13a0c597 100644 --- a/openair-cn/S1AP/s1ap_mme_retransmission.h +++ b/openair-cn/S1AP/s1ap_mme_retransmission.h @@ -39,7 +39,7 @@ typedef struct s1ap_timer_map_s { RB_ENTRY(s1ap_timer_map_s) entries; } s1ap_timer_map_t; -inline int s1ap_mme_timer_map_compare_id( +int s1ap_mme_timer_map_compare_id( struct s1ap_timer_map_s *p1, struct s1ap_timer_map_s *p2); int s1ap_handle_timer_expiry(timer_has_expired_t *timer_has_expired); diff --git a/openair-cn/S6A/freediameter/freeDiameter-1.2.0.patch b/openair-cn/S6A/freediameter/freediameter-1.2.0.patch similarity index 99% rename from openair-cn/S6A/freediameter/freeDiameter-1.2.0.patch rename to openair-cn/S6A/freediameter/freediameter-1.2.0.patch index c3984b371..1474f1213 100644 --- a/openair-cn/S6A/freediameter/freeDiameter-1.2.0.patch +++ b/openair-cn/S6A/freediameter/freediameter-1.2.0.patch @@ -171,7 +171,7 @@ diff -rupN freeDiameter-1.2.0/extensions/dict_s6a/dict_s6a.c freeDiameter-1.2.0. + { + struct dict_avp_data data = { + 493, /* Code */ -+ 0, /* Vendor */ ++ VENDOR_3GPP_Id, /* Vendor , EURECOM: with FD 1.2.0 does not work if vendor ID is 0 for this AVP*/ + "Service-Selection", /* Name */ + AVP_FLAG_VENDOR | AVP_FLAG_MANDATORY, /* Fixed flags */ + AVP_FLAG_VENDOR | AVP_FLAG_MANDATORY, /* Fixed flag values */ diff --git a/openair-cn/S6A/s6a_defs.h b/openair-cn/S6A/s6a_defs.h index 3d97ea403..03ee45a05 100644 --- a/openair-cn/S6A/s6a_defs.h +++ b/openair-cn/S6A/s6a_defs.h @@ -117,6 +117,7 @@ typedef struct { struct dict_object *dataobj_s6a_immediate_response_pref; struct dict_object *dataobj_s6a_authentication_info; struct dict_object *dataobj_s6a_re_synchronization_info; + struct dict_object *dataobj_s6a_service_selection; struct dict_object *dataobj_s6a_ue_srvcc_cap; /* Handlers */ diff --git a/openair-cn/S6A/s6a_dict.c b/openair-cn/S6A/s6a_dict.c index 700d9900c..20a43a67e 100644 --- a/openair-cn/S6A/s6a_dict.c +++ b/openair-cn/S6A/s6a_dict.c @@ -148,6 +148,9 @@ int s6a_fd_init_dict_objs(void) CHECK_FD_FCT(fd_dict_search(fd_g_config->cnf_dict, DICT_AVP, AVP_BY_NAME_ALL_VENDORS, "Re-Synchronization-Info", &s6a_fd_cnf.dataobj_s6a_re_synchronization_info, ENOENT)); + CHECK_FD_FCT(fd_dict_search(fd_g_config->cnf_dict, DICT_AVP, + AVP_BY_NAME_ALL_VENDORS, "Service-Selection", + &s6a_fd_cnf.dataobj_s6a_service_selection, ENOENT)); CHECK_FD_FCT(fd_dict_search(fd_g_config->cnf_dict, DICT_AVP, AVP_BY_NAME_ALL_VENDORS, "UE-SRVCC-Capability", &s6a_fd_cnf.dataobj_s6a_ue_srvcc_cap, ENOENT)); diff --git a/openair-cn/S6A/s6a_task.c b/openair-cn/S6A/s6a_task.c index e0fc63887..9849b6cab 100644 --- a/openair-cn/S6A/s6a_task.c +++ b/openair-cn/S6A/s6a_task.c @@ -89,8 +89,7 @@ void *s6a_thread(void *args) itti_exit_task(); } break; default: { - S6A_DEBUG("Unkwnon message ID %d: - %s\n", + S6A_DEBUG("Unkwnon message ID %d: %s\n", ITTI_MSG_ID(received_message_p), ITTI_MSG_NAME(received_message_p)); } break; } @@ -121,8 +120,7 @@ int s6a_init(const mme_config_t *mme_config_p) S6A_DEBUG("Initializing freeDiameter core...\n"); ret = fd_core_initialize(); if (ret != 0) { - S6A_ERROR("An error occurred during freeDiameter core library initialization: - %d\n",ret); + S6A_ERROR("An error occurred during freeDiameter core library initialization: %d\n",ret); return ret; } else { S6A_DEBUG("Initializing freeDiameter core done\n"); @@ -130,13 +128,11 @@ int s6a_init(const mme_config_t *mme_config_p) - S6A_DEBUG("Default ext path: - %s\n", DEFAULT_EXTENSIONS_PATH); + S6A_DEBUG("Default ext path: %s\n", DEFAULT_EXTENSIONS_PATH); ret = fd_core_parseconf(mme_config_p->s6a_config.conf_file); if (ret != 0) { - S6A_ERROR("An error occurred during fd_core_parseconf file : - %s.\n", mme_config_p->s6a_config.conf_file); + S6A_ERROR("An error occurred during fd_core_parseconf file : %s.\n", mme_config_p->s6a_config.conf_file); return ret; } else { S6A_DEBUG("fd_core_parseconf done\n"); @@ -183,8 +179,7 @@ int s6a_init(const mme_config_t *mme_config_p) S6A_ERROR("s6a create task\n"); return -1; } - S6A_DEBUG("Initializing S6a interface: - DONE\n"); + S6A_DEBUG("Initializing S6a interface: DONE\n"); return 0; } diff --git a/openair-cn/SGW-LITE/sgw_lite_task.c b/openair-cn/SGW-LITE/sgw_lite_task.c index 7620b4b4e..8a9a91355 100644 --- a/openair-cn/SGW-LITE/sgw_lite_task.c +++ b/openair-cn/SGW-LITE/sgw_lite_task.c @@ -155,6 +155,15 @@ int sgw_lite_init(char* config_file_name_pP) spgw_system("rmmod x_tables > /dev/null 2>&1", SPGW_WARN_ON_ERROR, __FILE__, __LINE__); spgw_system("rmmod nf_conntrack_netlink nfnetlink nf_nat nf_conntrack_ipv4 nf_conntrack > /dev/null 2>&1", SPGW_WARN_ON_ERROR, __FILE__, __LINE__); spgw_system("modprobe ip_tables", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe iptable_filter", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe iptable_mangle", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe iptable_nat", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe iptable_raw", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe ipt_MASQUERADE", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe ipt_LOG", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe nf_conntrack", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe nf_conntrack_ipv4", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); + spgw_system("modprobe nf_nat", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); spgw_system("modprobe x_tables", SPGW_ABORT_ON_ERROR, __FILE__, __LINE__); spgw_system("sysctl -w net.ipv4.netfilter.ip_conntrack_max=16000", SPGW_WARN_ON_ERROR, __FILE__, __LINE__); spgw_system("sysctl -w net.ipv4.ip_forward=1", SPGW_WARN_ON_ERROR, __FILE__, __LINE__); diff --git a/openair-cn/UDP/udp_eNB_task.c b/openair-cn/UDP/udp_eNB_task.c index 942960561..875dfc5ab 100644 --- a/openair-cn/UDP/udp_eNB_task.c +++ b/openair-cn/UDP/udp_eNB_task.c @@ -168,7 +168,7 @@ int udp_eNB_create_socket(int port, char *ip_addr, task_id_t task_id) sin.sin_port = htons(port); if (ip_addr == NULL) { - sin.sin_addr.s_addr = INADDR_ANY; + sin.sin_addr.s_addr = inet_addr(INADDR_ANY); } else { sin.sin_addr.s_addr = inet_addr(ip_addr); } diff --git a/openair-cn/UTILS/CONF/enb_default.conf b/openair-cn/UTILS/CONF/enb_default.conf deleted file mode 100755 index 679f5616b..000000000 --- a/openair-cn/UTILS/CONF/enb_default.conf +++ /dev/null @@ -1,12 +0,0 @@ -# ------- Interfaces definitions -ENB_INTERFACE_NAME_FOR_S1_MME = "eth0"; -ENB_IP_ADDRESS_FOR_S1_MME = "192.168.12.30"; -ENB_IP_NETMASK_FOR_S1_MME = 24; - -ENB_INTERFACE_NAME_FOR_S1U = "eth2"; -ENB_IP_ADDRESS_FOR_S1U = "192.168.14.30"; -ENB_IP_NETMASK_FOR_S1U = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "eth0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.12.175"; -MME_IP_NETMASK_FOR_S1_MME = 24; diff --git a/openair-cn/UTILS/CONF/enb_orcus.conf b/openair-cn/UTILS/CONF/enb_orcus.conf deleted file mode 100644 index cb362cfde..000000000 --- a/openair-cn/UTILS/CONF/enb_orcus.conf +++ /dev/null @@ -1,12 +0,0 @@ -# ------- Interfaces definitions -ENB_INTERFACE_NAME_FOR_S1_MME = "eth2"; -ENB_IP_ADDRESS_FOR_S1_MME = "192.168.14.30"; -ENB_IP_NETMASK_FOR_S1_MME = 24; - -ENB_INTERFACE_NAME_FOR_S1U = "eth2"; -ENB_IP_ADDRESS_FOR_S1U = "192.168.14.30"; -ENB_IP_NETMASK_FOR_S1U = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "eth0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.14.162"; -MME_IP_NETMASK_FOR_S1_MME = 24; diff --git a/openair-cn/UTILS/CONF/enb_yang.conf b/openair-cn/UTILS/CONF/enb_yang.conf deleted file mode 100755 index 55dbccd57..000000000 --- a/openair-cn/UTILS/CONF/enb_yang.conf +++ /dev/null @@ -1,12 +0,0 @@ -# ------- Interfaces definitions -ENB_INTERFACE_NAME_FOR_S1_MME = "cpenb0"; -ENB_IP_ADDRESS_FOR_S1_MME = "192.168.30.117"; -ENB_IP_NETMASK_FOR_S1_MME = 24; - -ENB_INTERFACE_NAME_FOR_S1U = "upenb0"; -ENB_IP_ADDRESS_FOR_S1U = "192.168.31.117"; -ENB_IP_NETMASK_FOR_S1U = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "cpmme0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.30.17"; -MME_IP_NETMASK_FOR_S1_MME = 24; diff --git a/openair-cn/UTILS/CONF/epc_caviar.conf b/openair-cn/UTILS/CONF/epc_caviar.conf deleted file mode 100644 index 55f87e57e..000000000 --- a/openair-cn/UTILS/CONF/epc_caviar.conf +++ /dev/null @@ -1,73 +0,0 @@ -S6A_CONF = "../objs/UTILS/CONF/s6a.conf"; - -REALM = "eur"; - -# Define the limits of the system in terms of served eNB and served UE. -# When the limits will be reached, overload procedure will take place. - -MAXENB = 10; -MAXUE = 100; - -RELATIVE_CAPACITY = 10; - -# Display statistics about whole system (expressed in seconds) -MME_STATISTIC_TIMER = 60; - -# max queue size per task -ITTI_QUEUE_SIZE = 2000000; - -# ------- SCTP definitions -# Number of streams to use in input/output - -SCTP_INSTREAMS = 32; -SCTP_OUTSTREAMS = 32; - -# ------- S1AP definitions - -# outcome drop timer value (seconds) -S1AP_OUTCOME_TIMER = 10; - -# ------- MME served GUMMEI -# MME code DEFAULT = 0 -# size = 8 bits -# maximum of 256 values, comma separated -MME_CODE = 30,56,1,8; - -# MME GROUP ID DEFAULT = 0 -# size = 16 bits -# maximum of 65535 values, comma separated -MME_GID = 3,4,5,30,8,9,50021; - -# TA (mcc.mnc:tracking area code) DEFAULT = 208.34:0 -# max values = 999.999:65535 -# maximum of 32 values, comma separated -PLMN = 208.38:0,209.130:4,208.92:1; - -# ------- Interfaces definitions -SGW_INTERFACE_NAME_FOR_S11 = "eth0"; -SGW_IP_ADDRESS_FOR_S11 = "192.168.12.87"; -SGW_IP_NETMASK_FOR_S11 = 24; - -SGW_INTERFACE_NAME_FOR_S1U_S12_S4_UP = "eth0"; -SGW_IP_ADDRESS_FOR_S1U_S12_S4_UP = "192.168.12.87"; -SGW_IP_NETMASK_FOR_S1U_S12_S4_UP = 24; - -SGW_INTERFACE_NAME_FOR_S5_S8_UP = "upsgw1"; -SGW_IP_ADDRESS_FOR_S5_S8_UP = "192.168.5.2"; -SGW_IP_NETMASK_FOR_S5_S8_UP = 24; - -PGW_INTERFACE_NAME_FOR_S5_S8 = "uppgw0"; -PGW_IP_ADDRESS_FOR_S5_S8 = "192.168.5.1"; -PGW_IP_NETMASK_FOR_S5_S8 = 24; - -PGW_INTERFACE_NAME_FOR_SGI = "eth0"; -PGW_IP_ADDR_FOR_SGI = "192.168.12.87"; -PGW_IP_NETMASK_FOR_SGI = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "eth0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.12.87"; -MME_IP_NETMASK_FOR_S1_MME = 24; - -MME_INTERFACE_NAME_FOR_S11_MME = "eth0"; -MME_IP_ADDRESS_FOR_S11_MME = "192.168.12.87"; -MME_IP_NETMASK_FOR_S11_MME = 24; diff --git a/openair-cn/UTILS/CONF/epc_nord.conf b/openair-cn/UTILS/CONF/epc_nord.conf deleted file mode 100644 index fc0130215..000000000 --- a/openair-cn/UTILS/CONF/epc_nord.conf +++ /dev/null @@ -1,73 +0,0 @@ -S6A_CONF = "../objs/UTILS/CONF/s6a.conf"; - -REALM = "eur"; - -# Define the limits of the system in terms of served eNB and served UE. -# When the limits will be reached, overload procedure will take place. - -MAXENB = 10; -MAXUE = 100; - -RELATIVE_CAPACITY = 10; - -# Display statistics about whole system (expressed in seconds) -MME_STATISTIC_TIMER = 10; - -# max queue size per task -ITTI_QUEUE_SIZE = 2000000; - -# ------- SCTP definitions -# Number of streams to use in input/output - -SCTP_INSTREAMS = 32; -SCTP_OUTSTREAMS = 32; - -# ------- S1AP definitions - -# outcome drop timer value (seconds) -S1AP_OUTCOME_TIMER = 10; - -# ------- MME served GUMMEI -# MME code DEFAULT = 0 -# size = 8 bits -# maximum of 256 values, comma separated -MME_CODE = 30,56,1,8; - -# MME GROUP ID DEFAULT = 0 -# size = 16 bits -# maximum of 65535 values, comma separated -MME_GID = 3,4,5,30,8,9,50021; - -# TA (mcc.mnc:tracking area code) DEFAULT = 208.34:0 -# max values = 999.999:65535 -# maximum of 32 values, comma separated -PLMN = 208.38:0,209.130:4,208.35:8; - -# ------- Interfaces definitions -SGW_INTERFACE_NAME_FOR_S11 = "eth0"; -SGW_IP_ADDRESS_FOR_S11 = "192.168.14.162"; -SGW_IP_NETMASK_FOR_S11 = 24; - -SGW_INTERFACE_NAME_FOR_S1U_S12_S4_UP = "eth0"; -SGW_IP_ADDRESS_FOR_S1U_S12_S4_UP = "192.168.14.162"; -SGW_IP_NETMASK_FOR_S1U_S12_S4_UP = 24; - -SGW_INTERFACE_NAME_FOR_S5_S8_UP = "upsgw1"; -SGW_IP_ADDRESS_FOR_S5_S8_UP = "192.168.5.2"; -SGW_IP_NETMASK_FOR_S5_S8_UP = 24; - -PGW_INTERFACE_NAME_FOR_S5_S8 = "uppgw0"; -PGW_IP_ADDRESS_FOR_S5_S8 = "192.168.5.1"; -PGW_IP_NETMASK_FOR_S5_S8 = 24; - -PGW_INTERFACE_NAME_FOR_SGI = "eth0"; -PGW_IP_ADDR_FOR_SGI = "192.168.14.162"; -PGW_IP_NETMASK_FOR_SGI = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "eth0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.12.30"; -MME_IP_NETMASK_FOR_S1_MME = 24; - -MME_INTERFACE_NAME_FOR_S11_MME = "eth2"; -MME_IP_ADDRESS_FOR_S11_MME = "192.168.14.30"; -MME_IP_NETMASK_FOR_S11_MME = 24; diff --git a/openair-cn/UTILS/CONF/epc_orcus.conf b/openair-cn/UTILS/CONF/epc_orcus.conf deleted file mode 100644 index 8b3a86068..000000000 --- a/openair-cn/UTILS/CONF/epc_orcus.conf +++ /dev/null @@ -1,73 +0,0 @@ -S6A_CONF = "../objs/UTILS/CONF/s6a.conf"; - -REALM = "eur"; - -# Define the limits of the system in terms of served eNB and served UE. -# When the limits will be reached, overload procedure will take place. - -MAXENB = 10; -MAXUE = 100; - -RELATIVE_CAPACITY = 10; - -# Display statistics about whole system (expressed in seconds) -MME_STATISTIC_TIMER = 10; - -# max queue size per task -ITTI_QUEUE_SIZE = 2000000; - -# ------- SCTP definitions -# Number of streams to use in input/output - -SCTP_INSTREAMS = 32; -SCTP_OUTSTREAMS = 32; - -# ------- S1AP definitions - -# outcome drop timer value (seconds) -S1AP_OUTCOME_TIMER = 10; - -# ------- MME served GUMMEI -# MME code DEFAULT = 0 -# size = 8 bits -# maximum of 256 values, comma separated -MME_CODE = 30,56,1,8; - -# MME GROUP ID DEFAULT = 0 -# size = 16 bits -# maximum of 65535 values, comma separated -MME_GID = 3,4,5,30,8,9,50021; - -# TA (mcc.mnc:tracking area code) DEFAULT = 208.34:0 -# max values = 999.999:65535 -# maximum of 32 values, comma separated -PLMN = 208.38:0,209.130:4,208.35:8; - -# ------- Interfaces definitions -SGW_INTERFACE_NAME_FOR_S11 = "eth0"; -SGW_IP_ADDRESS_FOR_S11 = "192.168.14.162"; -SGW_IP_NETMASK_FOR_S11 = 24; - -SGW_INTERFACE_NAME_FOR_S1U_S12_S4_UP = "eth0"; -SGW_IP_ADDRESS_FOR_S1U_S12_S4_UP = "192.168.14.162"; -SGW_IP_NETMASK_FOR_S1U_S12_S4_UP = 24; - -SGW_INTERFACE_NAME_FOR_S5_S8_UP = "upsgw1"; -SGW_IP_ADDRESS_FOR_S5_S8_UP = "192.168.5.2"; -SGW_IP_NETMASK_FOR_S5_S8_UP = 24; - -PGW_INTERFACE_NAME_FOR_S5_S8 = "uppgw0"; -PGW_IP_ADDRESS_FOR_S5_S8 = "192.168.5.1"; -PGW_IP_NETMASK_FOR_S5_S8 = 24; - -PGW_INTERFACE_NAME_FOR_SGI = "eth0"; -PGW_IP_ADDR_FOR_SGI = "192.168.14.162"; -PGW_IP_NETMASK_FOR_SGI = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "eth0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.14.162"; -MME_IP_NETMASK_FOR_S1_MME = 24; - -MME_INTERFACE_NAME_FOR_S11_MME = "eth0"; -MME_IP_ADDRESS_FOR_S11_MME = "192.168.14.162"; -MME_IP_NETMASK_FOR_S11_MME = 24; diff --git a/openair-cn/UTILS/CONF/epc_sud.conf b/openair-cn/UTILS/CONF/epc_sud.conf deleted file mode 100644 index 8af6a389d..000000000 --- a/openair-cn/UTILS/CONF/epc_sud.conf +++ /dev/null @@ -1,73 +0,0 @@ -S6A_CONF = "../epc_nas/UTILS/CONF/s6a.conf"; - -REALM = "eur"; - -# Define the limits of the system in terms of served eNB and served UE. -# When the limits will be reached, overload procedure will take place. - -MAXENB = 10; -MAXUE = 100; - -RELATIVE_CAPACITY = 10; - -# Display statistics about whole system (expressed in seconds) -MME_STATISTIC_TIMER = 10; - -# max queue size per task -ITTI_QUEUE_SIZE = 2000000; - -# ------- SCTP definitions -# Number of streams to use in input/output - -SCTP_INSTREAMS = 32; -SCTP_OUTSTREAMS = 32; - -# ------- S1AP definitions - -# outcome drop timer value (seconds) -S1AP_OUTCOME_TIMER = 10; - -# ------- MME served GUMMEI -# MME code DEFAULT = 0 -# size = 8 bits -# maximum of 256 values, comma separated -MME_CODE = 30,56,1,8; - -# MME GROUP ID DEFAULT = 0 -# size = 16 bits -# maximum of 65535 values, comma separated -MME_GID = 3,4,5,30,8,9,50021; - -# TA (mcc.mnc:tracking area code) DEFAULT = 208.34:0 -# max values = 999.999:65535 -# maximum of 32 values, comma separated -PLMN = 208.38:0,209.130:4,208.92:1,208.10:1; - -# ------- Interfaces definitions -SGW_INTERFACE_NAME_FOR_S11 = "eth0"; -SGW_IP_ADDRESS_FOR_S11 = "192.168.12.31"; -SGW_IP_NETMASK_FOR_S11 = 24; - -SGW_INTERFACE_NAME_FOR_S1U_S12_S4_UP = "eth0"; -SGW_IP_ADDRESS_FOR_S1U_S12_S4_UP = "192.168.12.31"; -SGW_IP_NETMASK_FOR_S1U_S12_S4_UP = 24; - -SGW_INTERFACE_NAME_FOR_S5_S8_UP = "eth0"; -SGW_IP_ADDRESS_FOR_S5_S8_UP = "192.168.12.31"; -SGW_IP_NETMASK_FOR_S5_S8_UP = 24; - -PGW_INTERFACE_NAME_FOR_S5_S8 = "eth0"; -PGW_IP_ADDRESS_FOR_S5_S8 = "192.168.12.31"; -PGW_IP_NETMASK_FOR_S5_S8 = 24; - -PGW_INTERFACE_NAME_FOR_SGI = "eth0"; -PGW_IP_ADDR_FOR_SGI = "192.168.12.31"; -PGW_IP_NETMASK_FOR_SGI = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "eth0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.12.31"; -MME_IP_NETMASK_FOR_S1_MME = 24; - -MME_INTERFACE_NAME_FOR_S11_MME = "eth0"; -MME_IP_ADDRESS_FOR_S11_MME = "192.168.12.31"; -MME_IP_NETMASK_FOR_S11_MME = 24; diff --git a/openair-cn/UTILS/CONF/epc_tapenade.conf b/openair-cn/UTILS/CONF/epc_tapenade.conf deleted file mode 100644 index 76162a4f3..000000000 --- a/openair-cn/UTILS/CONF/epc_tapenade.conf +++ /dev/null @@ -1,73 +0,0 @@ -S6A_CONF = "../epc_nas/UTILS/CONF/s6a.conf"; - -REALM = "eur"; - -# Define the limits of the system in terms of served eNB and served UE. -# When the limits will be reached, overload procedure will take place. - -MAXENB = 10; -MAXUE = 100; - -RELATIVE_CAPACITY = 10; - -# Display statistics about whole system (expressed in seconds) -MME_STATISTIC_TIMER = 60; - -# max queue size per task -ITTI_QUEUE_SIZE = 2000000; - -# ------- SCTP definitions -# Number of streams to use in input/output - -SCTP_INSTREAMS = 32; -SCTP_OUTSTREAMS = 32; - -# ------- S1AP definitions - -# outcome drop timer value (seconds) -S1AP_OUTCOME_TIMER = 10; - -# ------- MME served GUMMEI -# MME code DEFAULT = 0 -# size = 8 bits -# maximum of 256 values, comma separated -MME_CODE = 30,56,1,8; - -# MME GROUP ID DEFAULT = 0 -# size = 16 bits -# maximum of 65535 values, comma separated -MME_GID = 3,4,5,30,8,9,50021; - -# TA (mcc.mnc:tracking area code) DEFAULT = 208.34:0 -# max values = 999.999:65535 -# maximum of 32 values, comma separated -PLMN = 208.38:0,209.130:4,208.92:1,208.10:1; - -# ------- Interfaces definitions -SGW_INTERFACE_NAME_FOR_S11 = "eth0"; -SGW_IP_ADDRESS_FOR_S11 = "192.168.12.86"; -SGW_IP_NETMASK_FOR_S11 = 24; - -SGW_INTERFACE_NAME_FOR_S1U_S12_S4_UP = "eth0"; -SGW_IP_ADDRESS_FOR_S1U_S12_S4_UP = "192.168.12.86"; -SGW_IP_NETMASK_FOR_S1U_S12_S4_UP = 24; - -SGW_INTERFACE_NAME_FOR_S5_S8_UP = "eth0"; -SGW_IP_ADDRESS_FOR_S5_S8_UP = "192.168.12.86"; -SGW_IP_NETMASK_FOR_S5_S8_UP = 24; - -PGW_INTERFACE_NAME_FOR_S5_S8 = "eth0"; -PGW_IP_ADDRESS_FOR_S5_S8 = "192.168.12.86"; -PGW_IP_NETMASK_FOR_S5_S8 = 24; - -PGW_INTERFACE_NAME_FOR_SGI = "eth0"; -PGW_IP_ADDR_FOR_SGI = "192.168.12.86"; -PGW_IP_NETMASK_FOR_SGI = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "eth0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.12.86"; -MME_IP_NETMASK_FOR_S1_MME = 24; - -MME_INTERFACE_NAME_FOR_S11_MME = "eth0"; -MME_IP_ADDRESS_FOR_S11_MME = "192.168.12.86"; -MME_IP_NETMASK_FOR_S11_MME = 24; diff --git a/openair-cn/UTILS/CONF/epc_yang.conf b/openair-cn/UTILS/CONF/epc_yang.conf deleted file mode 100755 index 1fc9ff674..000000000 --- a/openair-cn/UTILS/CONF/epc_yang.conf +++ /dev/null @@ -1,73 +0,0 @@ -S6A_CONF = "../objs/UTILS/CONF/s6a.conf"; - -REALM = "eur"; - -# Define the limits of the system in terms of served eNB and served UE. -# When the limits will be reached, overload procedure will take place. - -MAXENB = 10; -MAXUE = 100; - -RELATIVE_CAPACITY = 10; - -# Display statistics about whole system (expressed in seconds) -MME_STATISTIC_TIMER = 10; - -# max queue size per task -ITTI_QUEUE_SIZE = 2000000; - -# ------- SCTP definitions -# Number of streams to use in input/output - -SCTP_INSTREAMS = 32; -SCTP_OUTSTREAMS = 32; - -# ------- S1AP definitions - -# outcome drop timer value (seconds) -S1AP_OUTCOME_TIMER = 10; - -# ------- MME served GUMMEI -# MME code DEFAULT = 0 -# size = 8 bits -# maximum of 256 values, comma separated -MME_CODE = 30,56,1,8; - -# MME GROUP ID DEFAULT = 0 -# size = 16 bits -# maximum of 65535 values, comma separated -MME_GID = 3,4,5,30,8,9,50021; - -# TA (mcc.mnc:tracking area code) DEFAULT = 208.34:0 -# max values = 999.999:65535 -# maximum of 32 values, comma separated -PLMN = 208.38:0,209.130:4,208.35:8; - -# ------- Interfaces definitions -SGW_INTERFACE_NAME_FOR_S11 = "s11sgw"; -SGW_IP_ADDRESS_FOR_S11 = "192.168.33.17"; -SGW_IP_NETMASK_FOR_S11 = 24; - -SGW_INTERFACE_NAME_FOR_S1U_S12_S4_UP = "upsgw0"; -SGW_IP_ADDRESS_FOR_S1U_S12_S4_UP = "192.168.31.17"; -SGW_IP_NETMASK_FOR_S1U_S12_S4_UP = 24; - -SGW_INTERFACE_NAME_FOR_S5_S8_UP = "upsgw1"; -SGW_IP_ADDRESS_FOR_S5_S8_UP = "192.168.5.2"; -SGW_IP_NETMASK_FOR_S5_S8_UP = 24; - -PGW_INTERFACE_NAME_FOR_S5_S8 = "uppgw0"; -PGW_IP_ADDRESS_FOR_S5_S8 = "192.168.5.1"; -PGW_IP_NETMASK_FOR_S5_S8 = 24; - -PGW_INTERFACE_NAME_FOR_SGI = "eth2"; -PGW_IP_ADDR_FOR_SGI = "192.168.13.17"; -PGW_IP_NETMASK_FOR_SGI = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "cpmme0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.30.17"; -MME_IP_NETMASK_FOR_S1_MME = 24; - -MME_INTERFACE_NAME_FOR_S11_MME = "s11mme"; -MME_IP_ADDRESS_FOR_S11_MME = "192.168.33.117"; -MME_IP_NETMASK_FOR_S11_MME = 24; diff --git a/openair-cn/UTILS/CONF/mme_default.conf b/openair-cn/UTILS/CONF/mme_default.conf deleted file mode 100644 index 807b304be..000000000 --- a/openair-cn/UTILS/CONF/mme_default.conf +++ /dev/null @@ -1,73 +0,0 @@ -S6A_CONF = "../objs/UTILS/CONF/s6a.conf"; - -REALM = "eur"; - -# Define the limits of the system in terms of served eNB and served UE. -# When the limits will be reached, overload procedure will take place. - -MAXENB = 10; -MAXUE = 100; - -RELATIVE_CAPACITY = 10; - -# Display statistics about whole system (expressed in seconds) -MME_STATISTIC_TIMER = 10; - -# max queue size per task -ITTI_QUEUE_SIZE = 2000000; - -# ------- SCTP definitions -# Number of streams to use in input/output - -SCTP_INSTREAMS = 32; -SCTP_OUTSTREAMS = 32; - -# ------- S1AP definitions - -# outcome drop timer value (seconds) -S1AP_OUTCOME_TIMER = 10; - -# ------- MME served GUMMEI -# MME code DEFAULT = 0 -# size = 8 bits -# maximum of 256 values, comma separated -MME_CODE = 30,56,1,8; - -# MME GROUP ID DEFAULT = 0 -# size = 16 bits -# maximum of 65535 values, comma separated -MME_GID = 3,4,5,30,8,9,50021; - -# TA (mcc.mnc:tracking area code) DEFAULT = 208.34:0 -# max values = 999.999:65535 -# maximum of 32 values, comma separated -PLMN = 208.38:0,209.130:4,208.35:8; - -# ------- Interfaces definitions -SGW_INTERFACE_NAME_FOR_S11 = "eth0"; -SGW_IP_ADDRESS_FOR_S11 = "192.168.14.162"; -SGW_IP_NETMASK_FOR_S11 = 24; - -SGW_INTERFACE_NAME_FOR_S1U_S12_S4_UP = "eth0"; -SGW_IP_ADDRESS_FOR_S1U_S12_S4_UP = "192.168.14.162"; -SGW_IP_NETMASK_FOR_S1U_S12_S4_UP = 24; - -SGW_INTERFACE_NAME_FOR_S5_S8_UP = "upsgw1"; -SGW_IP_ADDRESS_FOR_S5_S8_UP = "192.168.5.2"; -SGW_IP_NETMASK_FOR_S5_S8_UP = 24; - -PGW_INTERFACE_NAME_FOR_S5_S8 = "uppgw0"; -PGW_IP_ADDRESS_FOR_S5_S8 = "192.168.5.1"; -PGW_IP_NETMASK_FOR_S5_S8 = 24; - -PGW_INTERFACE_NAME_FOR_SGI = "eth0"; -PGW_IP_ADDR_FOR_SGI = "192.168.14.162"; -PGW_IP_NETMASK_FOR_SGI = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "eth0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.12.175"; -MME_IP_NETMASK_FOR_S1_MME = 24; - -MME_INTERFACE_NAME_FOR_S11_MME = "eth0"; -MME_IP_ADDRESS_FOR_S11_MME = "192.168.12.175"; -MME_IP_NETMASK_FOR_S11_MME = 24; diff --git a/openair-cn/UTILS/CONF/mme_yang.conf b/openair-cn/UTILS/CONF/mme_yang.conf deleted file mode 100755 index 1fc9ff674..000000000 --- a/openair-cn/UTILS/CONF/mme_yang.conf +++ /dev/null @@ -1,73 +0,0 @@ -S6A_CONF = "../objs/UTILS/CONF/s6a.conf"; - -REALM = "eur"; - -# Define the limits of the system in terms of served eNB and served UE. -# When the limits will be reached, overload procedure will take place. - -MAXENB = 10; -MAXUE = 100; - -RELATIVE_CAPACITY = 10; - -# Display statistics about whole system (expressed in seconds) -MME_STATISTIC_TIMER = 10; - -# max queue size per task -ITTI_QUEUE_SIZE = 2000000; - -# ------- SCTP definitions -# Number of streams to use in input/output - -SCTP_INSTREAMS = 32; -SCTP_OUTSTREAMS = 32; - -# ------- S1AP definitions - -# outcome drop timer value (seconds) -S1AP_OUTCOME_TIMER = 10; - -# ------- MME served GUMMEI -# MME code DEFAULT = 0 -# size = 8 bits -# maximum of 256 values, comma separated -MME_CODE = 30,56,1,8; - -# MME GROUP ID DEFAULT = 0 -# size = 16 bits -# maximum of 65535 values, comma separated -MME_GID = 3,4,5,30,8,9,50021; - -# TA (mcc.mnc:tracking area code) DEFAULT = 208.34:0 -# max values = 999.999:65535 -# maximum of 32 values, comma separated -PLMN = 208.38:0,209.130:4,208.35:8; - -# ------- Interfaces definitions -SGW_INTERFACE_NAME_FOR_S11 = "s11sgw"; -SGW_IP_ADDRESS_FOR_S11 = "192.168.33.17"; -SGW_IP_NETMASK_FOR_S11 = 24; - -SGW_INTERFACE_NAME_FOR_S1U_S12_S4_UP = "upsgw0"; -SGW_IP_ADDRESS_FOR_S1U_S12_S4_UP = "192.168.31.17"; -SGW_IP_NETMASK_FOR_S1U_S12_S4_UP = 24; - -SGW_INTERFACE_NAME_FOR_S5_S8_UP = "upsgw1"; -SGW_IP_ADDRESS_FOR_S5_S8_UP = "192.168.5.2"; -SGW_IP_NETMASK_FOR_S5_S8_UP = 24; - -PGW_INTERFACE_NAME_FOR_S5_S8 = "uppgw0"; -PGW_IP_ADDRESS_FOR_S5_S8 = "192.168.5.1"; -PGW_IP_NETMASK_FOR_S5_S8 = 24; - -PGW_INTERFACE_NAME_FOR_SGI = "eth2"; -PGW_IP_ADDR_FOR_SGI = "192.168.13.17"; -PGW_IP_NETMASK_FOR_SGI = 24; - -MME_INTERFACE_NAME_FOR_S1_MME = "cpmme0"; -MME_IP_ADDRESS_FOR_S1_MME = "192.168.30.17"; -MME_IP_NETMASK_FOR_S1_MME = 24; - -MME_INTERFACE_NAME_FOR_S11_MME = "s11mme"; -MME_IP_ADDRESS_FOR_S11_MME = "192.168.33.117"; -MME_IP_NETMASK_FOR_S11_MME = 24; diff --git a/openair-cn/UTILS/CONF/s6a.conf.in b/openair-cn/UTILS/CONF/s6a.conf.in deleted file mode 100644 index 000544ad7..000000000 --- a/openair-cn/UTILS/CONF/s6a.conf.in +++ /dev/null @@ -1,97 +0,0 @@ -# -------- Local --------- - -# Uncomment if the framework cannot resolv it. -Identity = "@MME_FQDN@"; -Realm = "@REALM@"; - -# TLS configuration (see previous section) -TLS_Cred = "${FREEDIAMETER_PATH}/../etc/freeDiameter/mme.cert.pem", - "${FREEDIAMETER_PATH}/../etc/freeDiameter/mme.key.pem"; -TLS_CA = "${FREEDIAMETER_PATH}/../etc/freeDiameter/mme.cacert.pem"; - -# Disable use of TCP protocol (only listen and connect in SCTP) -# Default : TCP enabled -@TRANSPORT_option@; - -# This option is ignored if freeDiameter is compiled with DISABLE_SCTP option. -# Prefer TCP instead of SCTP for establishing new connections. -# This setting may be overwritten per peer in peer configuration blocs. -# Default : SCTP is attempted first. -@TRANSPORT_PREFER_TCP_option@; - - -No_IPv6; - -# Overwrite the number of SCTP streams. This value should be kept low, -# especially if you are using TLS over SCTP, because it consumes a lot of -# resources in that case. See tickets 19 and 27 for some additional details on -# this. -# Limit the number of SCTP streams -SCTP_streams = 3; - - -# By default, freeDiameter acts as a Diameter Relay Agent by forwarding all -# messages it cannot handle locally. This parameter disables this behavior. -NoRelay; - - -TLS_old_method; - - -AppServThreads = 1; - -# Specify the addresses on which to bind the listening server. This must be -# specified if the framework is unable to auto-detect these addresses, or if the -# auto-detected values are incorrect. Note that the list of addresses is sent -# in CER or CEA message, so one should pay attention to this parameter if some -# adresses should be kept hidden. -@ListenOn@ - -@DIAMETER_PORT@; -@DIAMETER_SEC_PORT@; - -# -------- Extensions --------- - -# Uncomment (and create rtd.conf) to specify routing table for this peer. -#LoadExtension = "rt_default.fdx" : "rtd.conf"; - -# Uncomment (and create acl.conf) to allow incoming connections from other peers. -#LoadExtension = "acl_wl.fdx" : "acl.conf"; - -# Uncomment to display periodic state information -#LoadExtension = "dbg_monitor.fdx"; - -# Uncomment to enable an interactive Python interpreter session. -# (see doc/dbg_interactive.py.sample for more information) -#LoadExtension = "dbg_interactive.fdx"; - -# Load the RFC4005 dictionary objects -#LoadExtension = "dict_nasreq.fdx"; - -LoadExtension = "dict_nas_mipv6.fdx"; -LoadExtension = "dict_s6a.fdx"; - -# Load RFC4072 dictionary objects -#LoadExtension = "dict_eap.fdx"; - -# Load the Diameter EAP server extension (requires diameap.conf) -#LoadExtension = "app_diameap.fdx" : "diameap.conf"; - -# Load the Accounting Server extension (requires app_acct.conf) -#LoadExtension = "app_acct.fdx" : "app_acct.conf"; - -# -------- Peers --------- - -# The framework will actively attempt to establish and maintain a connection -# with the peers listed here. -# For only accepting incoming connections, see the acl_wl.fx extension. - -# ConnectPeer -# Declare a remote peer to which this peer must maintain a connection. -# In addition, this allows specifying non-default parameters for this peer only -# (for example disable SCTP with this peer, or use RFC3588-flavour TLS). -# Note that by default, if a peer is not listed as a ConnectPeer entry, an -# incoming connection from this peer will be rejected. If you want to accept -# incoming connections from other peers, see the acl_wl.fdx? extension which -# allows exactly this. -@ConnectPeer@ = "@HSS_FQDN@" { ConnectTo = "@HSS_IP@"; No_IPv6; No_TLS ; port = 3868; Realm = "@REALM@"; }; -- GitLab