2020-08-13 00:31:22 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2019 by Sukchan Lee <acetcom@gmail.com>
|
|
|
|
*
|
|
|
|
* This file is part of Open5GS.
|
|
|
|
*
|
|
|
|
* This program is free software: you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation, either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "gtp-path.h"
|
|
|
|
#include "pfcp-path.h"
|
|
|
|
|
|
|
|
#include "s11-handler.h"
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
static void sess_timeout(ogs_gtp_xact_t *xact, void *data)
|
2020-08-13 00:31:22 +00:00
|
|
|
{
|
|
|
|
sgwc_sess_t *sess = data;
|
|
|
|
sgwc_ue_t *sgwc_ue = NULL;
|
|
|
|
uint8_t type = 0;
|
|
|
|
|
|
|
|
ogs_assert(xact);
|
|
|
|
ogs_assert(sess);
|
|
|
|
sgwc_ue = sess->sgwc_ue;
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
|
|
|
|
type = xact->seq[0].type;
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
switch (type) {
|
|
|
|
case OGS_GTP_DELETE_SESSION_REQUEST_TYPE:
|
|
|
|
ogs_error("[%s] No Delete Session Response", sgwc_ue->imsi_bcd);
|
|
|
|
sgwc_pfcp_send_session_deletion_request(sess, NULL, NULL);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ogs_error("GTP Timeout : IMSI[%s] Message-Type[%d]",
|
|
|
|
sgwc_ue->imsi_bcd, type);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
static void bearer_timeout(ogs_gtp_xact_t *xact, void *data)
|
|
|
|
{
|
|
|
|
sgwc_bearer_t *bearer = data;
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
sgwc_ue_t *sgwc_ue = NULL;
|
|
|
|
uint8_t type = 0;
|
|
|
|
|
|
|
|
ogs_assert(xact);
|
|
|
|
ogs_assert(bearer);
|
|
|
|
sess = bearer->sess;
|
|
|
|
ogs_assert(sess);
|
|
|
|
sgwc_ue = sess->sgwc_ue;
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
|
|
|
|
type = xact->seq[0].type;
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_error("GTP Timeout : IMSI[%s] Message-Type[%d]",
|
|
|
|
sgwc_ue->imsi_bcd, type);
|
|
|
|
}
|
|
|
|
|
2020-10-21 00:00:02 +00:00
|
|
|
/* This code was created in case it will be used later,
|
|
|
|
* and is currently not being used. */
|
2020-08-13 00:31:22 +00:00
|
|
|
static uint8_t pfcp_cause_from_gtp(uint8_t gtp_cause)
|
|
|
|
{
|
|
|
|
switch (gtp_cause) {
|
|
|
|
case OGS_GTP_CAUSE_REQUEST_ACCEPTED:
|
|
|
|
return OGS_PFCP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
case OGS_GTP_CAUSE_REQUEST_REJECTED_REASON_NOT_SPECIFIED:
|
|
|
|
return OGS_PFCP_CAUSE_REQUEST_REJECTED;
|
|
|
|
case OGS_GTP_CAUSE_CONTEXT_NOT_FOUND:
|
|
|
|
return OGS_PFCP_CAUSE_SESSION_CONTEXT_NOT_FOUND;
|
|
|
|
case OGS_GTP_CAUSE_MANDATORY_IE_MISSING:
|
|
|
|
return OGS_PFCP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
case OGS_GTP_CAUSE_CONDITIONAL_IE_MISSING:
|
|
|
|
return OGS_PFCP_CAUSE_CONDITIONAL_IE_MISSING;
|
|
|
|
case OGS_GTP_CAUSE_INVALID_LENGTH:
|
|
|
|
return OGS_PFCP_CAUSE_INVALID_LENGTH;
|
|
|
|
case OGS_GTP_CAUSE_MANDATORY_IE_INCORRECT:
|
|
|
|
return OGS_PFCP_CAUSE_MANDATORY_IE_INCORRECT;
|
|
|
|
case OGS_GTP_CAUSE_INVALID_MESSAGE_FORMAT:
|
|
|
|
return OGS_PFCP_CAUSE_INVALID_FORWARDING_POLICY;
|
|
|
|
case OGS_GTP_CAUSE_REMOTE_PEER_NOT_RESPONDING:
|
|
|
|
return OGS_PFCP_CAUSE_NO_ESTABLISHED_PFCP_ASSOCIATION;
|
|
|
|
case OGS_GTP_CAUSE_SEMANTIC_ERROR_IN_THE_TFT_OPERATION:
|
|
|
|
return OGS_PFCP_CAUSE_RULE_CREATION_MODIFICATION_FAILURE;
|
|
|
|
case OGS_GTP_CAUSE_GTP_C_ENTITY_CONGESTION:
|
|
|
|
return OGS_PFCP_CAUSE_PFCP_ENTITY_IN_CONGESTION;
|
|
|
|
case OGS_GTP_CAUSE_NO_RESOURCES_AVAILABLE:
|
|
|
|
return OGS_PFCP_CAUSE_NO_RESOURCES_AVAILABLE;
|
|
|
|
case OGS_GTP_CAUSE_SERVICE_NOT_SUPPORTED:
|
|
|
|
return OGS_PFCP_CAUSE_SERVICE_NOT_SUPPORTED;
|
|
|
|
case OGS_GTP_CAUSE_SYSTEM_FAILURE:
|
|
|
|
return OGS_PFCP_CAUSE_SYSTEM_FAILURE;
|
|
|
|
default:
|
|
|
|
return OGS_PFCP_CAUSE_SYSTEM_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return OGS_PFCP_CAUSE_SYSTEM_FAILURE;
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_create_session_request(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
uint8_t cause_value = 0;
|
|
|
|
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
sgwc_bearer_t *bearer = NULL;
|
|
|
|
|
|
|
|
ogs_gtp_create_session_request_t *req = NULL;
|
|
|
|
|
|
|
|
uint16_t decoded;
|
|
|
|
ogs_gtp_f_teid_t *mme_s11_teid = NULL;
|
|
|
|
ogs_gtp_uli_t uli;
|
2020-10-01 17:27:58 +00:00
|
|
|
ogs_gtp_bearer_qos_t bearer_qos;
|
2020-08-13 00:31:22 +00:00
|
|
|
char apn[OGS_MAX_APN_LEN];
|
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
ogs_assert(gtpbuf);
|
|
|
|
ogs_assert(message);
|
|
|
|
req = &message->create_session_request;
|
|
|
|
ogs_assert(req);
|
|
|
|
|
|
|
|
ogs_debug("Create Session Request");
|
|
|
|
|
|
|
|
cause_value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
|
|
|
if (req->imsi.presence == 0) {
|
|
|
|
ogs_error("No IMSI");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (req->bearer_contexts_to_be_created.presence == 0) {
|
|
|
|
ogs_error("No Bearer");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (req->bearer_contexts_to_be_created.eps_bearer_id.presence == 0) {
|
|
|
|
ogs_error("No EPS Bearer ID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
2020-10-01 17:27:58 +00:00
|
|
|
if (req->bearer_contexts_to_be_created.bearer_level_qos.presence == 0) {
|
|
|
|
ogs_error("No Bearer QoS");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
2020-08-13 00:31:22 +00:00
|
|
|
if (req->access_point_name.presence == 0) {
|
|
|
|
ogs_error("No APN");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (req->sender_f_teid_for_control_plane.presence == 0) {
|
|
|
|
ogs_error("No Sender F-TEID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (req->pgw_s5_s8_address_for_control_plane_or_pmip.presence == 0) {
|
|
|
|
ogs_error("No PGW IP");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (req->user_location_information.presence == 0) {
|
|
|
|
ogs_error("No User Location Inforamtion");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (req->pdn_type.presence == 0) {
|
|
|
|
ogs_error("No PDN Type");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (!sgwc_ue) {
|
|
|
|
ogs_warn("No Context");
|
|
|
|
cause_value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
if (cause_value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_CREATE_SESSION_RESPONSE_TYPE, cause_value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Add Session */
|
|
|
|
ogs_fqdn_parse(apn,
|
|
|
|
req->access_point_name.data, req->access_point_name.len);
|
|
|
|
sess = sgwc_sess_find_by_ebi(sgwc_ue,
|
|
|
|
req->bearer_contexts_to_be_created.eps_bearer_id.u8);
|
|
|
|
if (sess) {
|
|
|
|
ogs_warn("OLD Session Release [IMSI:%s,APN:%s]",
|
|
|
|
sgwc_ue->imsi_bcd, sess->pdn.apn);
|
|
|
|
sgwc_sess_remove(sess);
|
|
|
|
}
|
|
|
|
sess = sgwc_sess_add(sgwc_ue, apn);
|
|
|
|
ogs_assert(sess);
|
|
|
|
|
|
|
|
/* Set User Location Information */
|
|
|
|
decoded = ogs_gtp_parse_uli(&uli, &req->user_location_information);
|
|
|
|
ogs_assert(req->user_location_information.len == decoded);
|
|
|
|
memcpy(&sgwc_ue->e_tai.plmn_id, &uli.tai.plmn_id, sizeof(uli.tai.plmn_id));
|
|
|
|
sgwc_ue->e_tai.tac = uli.tai.tac;
|
|
|
|
memcpy(&sgwc_ue->e_cgi.plmn_id,
|
|
|
|
&uli.e_cgi.plmn_id, sizeof(uli.e_cgi.plmn_id));
|
|
|
|
sgwc_ue->e_cgi.cell_id = uli.e_cgi.cell_id;
|
|
|
|
|
|
|
|
/* Select SGW-U based on UE Location Information */
|
|
|
|
sgwc_sess_select_sgwu(sess);
|
|
|
|
|
|
|
|
/* Check if selected SGW-U is associated with SGW-C */
|
|
|
|
ogs_assert(sess->pfcp_node);
|
|
|
|
if (!OGS_FSM_CHECK(&sess->pfcp_node->sm, sgwc_pfcp_state_associated)) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_CREATE_SESSION_RESPONSE_TYPE,
|
|
|
|
OGS_GTP_CAUSE_REMOTE_PEER_NOT_RESPONDING);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-10-01 17:27:58 +00:00
|
|
|
/* Set Bearer QoS */
|
|
|
|
decoded = ogs_gtp_parse_bearer_qos(&bearer_qos,
|
|
|
|
&req->bearer_contexts_to_be_created.bearer_level_qos);
|
|
|
|
ogs_assert(req->bearer_contexts_to_be_created.bearer_level_qos.len ==
|
|
|
|
decoded);
|
|
|
|
sess->pdn.qos.qci = bearer_qos.qci;
|
|
|
|
sess->pdn.qos.arp.priority_level = bearer_qos.priority_level;
|
|
|
|
sess->pdn.qos.arp.pre_emption_capability =
|
|
|
|
bearer_qos.pre_emption_capability;
|
|
|
|
sess->pdn.qos.arp.pre_emption_vulnerability =
|
|
|
|
bearer_qos.pre_emption_vulnerability;
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
/* Set PDN Type */
|
|
|
|
sess->pdn.pdn_type = req->pdn_type.u8;
|
|
|
|
sess->pdn.paa.pdn_type = req->pdn_type.u8;
|
|
|
|
|
|
|
|
/* Remove all previous bearer */
|
|
|
|
sgwc_bearer_remove_all(sess);
|
|
|
|
|
|
|
|
/* Setup Default Bearer */
|
|
|
|
bearer = sgwc_bearer_add(sess);
|
|
|
|
ogs_assert(bearer);
|
|
|
|
|
|
|
|
/* Set Bearer EBI */
|
|
|
|
bearer->ebi = req->bearer_contexts_to_be_created.eps_bearer_id.u8;
|
|
|
|
|
|
|
|
/* Receive Control Plane(DL) : MME-S11 */
|
|
|
|
mme_s11_teid = req->sender_f_teid_for_control_plane.data;
|
|
|
|
ogs_assert(mme_s11_teid);
|
|
|
|
sgwc_ue->mme_s11_teid = be32toh(mme_s11_teid->teid);
|
|
|
|
|
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
|
|
|
|
sgwc_pfcp_send_session_establishment_request(sess, s11_xact, gtpbuf);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_modify_bearer_request(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
uint16_t decoded;
|
|
|
|
uint64_t flags = 0;
|
|
|
|
|
2020-10-26 02:43:53 +00:00
|
|
|
sgwc_sess_t *sess = NULL;
|
2020-08-13 00:31:22 +00:00
|
|
|
sgwc_bearer_t *bearer = NULL;
|
|
|
|
sgwc_tunnel_t *dl_tunnel = NULL;
|
|
|
|
ogs_pfcp_far_t *far = NULL;
|
|
|
|
ogs_ip_t remote_ip;
|
|
|
|
ogs_ip_t zero_ip;
|
|
|
|
|
|
|
|
ogs_gtp_modify_bearer_request_t *req = NULL;
|
|
|
|
|
|
|
|
ogs_gtp_cause_t cause;
|
|
|
|
ogs_gtp_uli_t uli;
|
|
|
|
ogs_gtp_f_teid_t *enb_s1u_teid = NULL;
|
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
ogs_assert(message);
|
|
|
|
req = &message->modify_bearer_request;
|
|
|
|
ogs_assert(req);
|
|
|
|
|
|
|
|
ogs_debug("Modify Bearer Request");
|
|
|
|
|
|
|
|
memset(&cause, 0, sizeof(cause));
|
|
|
|
cause.value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
|
|
|
if (req->bearer_contexts_to_be_modified.presence == 0) {
|
|
|
|
ogs_error("No Bearer");
|
|
|
|
cause.value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (req->bearer_contexts_to_be_modified.eps_bearer_id.presence == 0) {
|
|
|
|
ogs_error("No EPS Bearer ID");
|
|
|
|
cause.value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
2020-11-07 22:27:12 +00:00
|
|
|
if (req->bearer_contexts_to_be_modified.s1_u_enodeb_f_teid.presence == 0) {
|
|
|
|
ogs_error("No eNB TEID");
|
|
|
|
cause.value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
2020-08-13 00:31:22 +00:00
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (!sgwc_ue) {
|
|
|
|
ogs_error("No Context");
|
|
|
|
cause.value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cause.value == OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
2020-08-13 00:31:22 +00:00
|
|
|
bearer = sgwc_bearer_find_by_ue_ebi(sgwc_ue,
|
|
|
|
req->bearer_contexts_to_be_modified.eps_bearer_id.u8);
|
2020-09-07 02:41:12 +00:00
|
|
|
if (!bearer)
|
|
|
|
ogs_error("Unknown EPS Bearer ID[%d]",
|
|
|
|
req->bearer_contexts_to_be_modified.eps_bearer_id.u8);
|
2020-08-13 00:31:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (!bearer) {
|
|
|
|
ogs_warn("No Context");
|
|
|
|
cause.value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cause.value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_MODIFY_BEARER_RESPONSE_TYPE, cause.value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-10-26 02:43:53 +00:00
|
|
|
ogs_assert(bearer);
|
|
|
|
sess = bearer->sess;
|
|
|
|
ogs_assert(sess);
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
dl_tunnel = sgwc_dl_tunnel_in_bearer(bearer);
|
|
|
|
ogs_assert(dl_tunnel);
|
|
|
|
|
|
|
|
/* Data Plane(DL) : eNB-S1U */
|
|
|
|
enb_s1u_teid = req->bearer_contexts_to_be_modified.s1_u_enodeb_f_teid.data;
|
|
|
|
dl_tunnel->remote_teid = be32toh(enb_s1u_teid->teid);
|
|
|
|
|
|
|
|
rv = ogs_gtp_f_teid_to_ip(enb_s1u_teid, &remote_ip);
|
|
|
|
if (rv != OGS_OK) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_MODIFY_BEARER_RESPONSE_TYPE,
|
|
|
|
OGS_GTP_CAUSE_MANDATORY_IE_MISSING);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (req->user_location_information.presence == 1) {
|
|
|
|
decoded = ogs_gtp_parse_uli(
|
|
|
|
&uli, &req->user_location_information);
|
|
|
|
ogs_assert(req->user_location_information.len == decoded);
|
|
|
|
memcpy(&sgwc_ue->e_tai.plmn_id, &uli.tai.plmn_id,
|
|
|
|
sizeof(uli.tai.plmn_id));
|
|
|
|
sgwc_ue->e_tai.tac = uli.tai.tac;
|
|
|
|
memcpy(&sgwc_ue->e_cgi.plmn_id, &uli.e_cgi.plmn_id,
|
|
|
|
sizeof(uli.e_cgi.plmn_id));
|
|
|
|
sgwc_ue->e_cgi.cell_id = uli.e_cgi.cell_id;
|
|
|
|
ogs_debug(" TAI[PLMN_ID:%06x,TAC:%d]",
|
|
|
|
ogs_plmn_id_hexdump(&sgwc_ue->e_tai.plmn_id),
|
|
|
|
sgwc_ue->e_tai.tac);
|
|
|
|
ogs_debug(" E_CGI[PLMN_ID:%06x,CELL_ID:%d]",
|
|
|
|
ogs_plmn_id_hexdump(&sgwc_ue->e_cgi.plmn_id),
|
|
|
|
sgwc_ue->e_cgi.cell_id);
|
|
|
|
}
|
|
|
|
|
|
|
|
flags = (OGS_PFCP_MODIFY_DL_ONLY|OGS_PFCP_MODIFY_ACTIVATE);
|
|
|
|
|
|
|
|
memset(&zero_ip, 0, sizeof(ogs_ip_t));
|
|
|
|
|
|
|
|
if (memcmp(&dl_tunnel->remote_ip, &zero_ip, sizeof(ogs_ip_t)) != 0 &&
|
|
|
|
memcmp(&dl_tunnel->remote_ip, &remote_ip, sizeof(ogs_ip_t)) != 0) {
|
|
|
|
|
2020-10-26 02:43:53 +00:00
|
|
|
ogs_assert(sess->pfcp_node);
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
/* eNB IP is changed during handover */
|
2020-10-26 02:43:53 +00:00
|
|
|
if (sess->pfcp_node->up_function_features.empu) {
|
2020-10-22 02:54:40 +00:00
|
|
|
flags |= OGS_PFCP_MODIFY_END_MARKER;
|
|
|
|
} else {
|
|
|
|
ogs_error("SGW-U does not support End Marker");
|
|
|
|
}
|
2020-08-13 00:31:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
memcpy(&dl_tunnel->remote_ip, &remote_ip, sizeof(ogs_ip_t));
|
|
|
|
|
|
|
|
far = dl_tunnel->far;
|
|
|
|
ogs_assert(far);
|
|
|
|
|
2020-12-03 06:16:57 +00:00
|
|
|
far->apply_action = OGS_PFCP_APPLY_ACTION_FORW;
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_pfcp_ip_to_outer_header_creation(&dl_tunnel->remote_ip,
|
|
|
|
&far->outer_header_creation, &far->outer_header_creation_len);
|
|
|
|
far->outer_header_creation.teid = dl_tunnel->remote_teid;
|
|
|
|
|
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
ogs_debug(" ENB_S1U_TEID[%d] SGW_S1U_TEID[%d]",
|
|
|
|
dl_tunnel->remote_teid, dl_tunnel->local_teid);
|
|
|
|
|
|
|
|
sgwc_pfcp_send_bearer_modification_request(
|
|
|
|
bearer, s11_xact, gtpbuf, flags);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_delete_session_request(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
uint8_t cause_value = 0;
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
ogs_gtp_xact_t *s5c_xact = NULL;
|
|
|
|
ogs_gtp_delete_session_request_t *req = NULL;
|
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
ogs_assert(gtpbuf);
|
|
|
|
ogs_assert(message);
|
|
|
|
req = &message->delete_session_request;
|
|
|
|
ogs_assert(req);
|
|
|
|
|
|
|
|
ogs_debug("Delete Session Request");
|
|
|
|
|
|
|
|
cause_value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (req->linked_eps_bearer_id.presence == 0) {
|
|
|
|
ogs_error("No EPS Bearer ID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
if (!sgwc_ue) {
|
2020-11-07 22:27:12 +00:00
|
|
|
ogs_error("No Context");
|
2020-08-13 00:31:22 +00:00
|
|
|
cause_value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (cause_value == OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
sess = sgwc_sess_find_by_ebi(sgwc_ue, req->linked_eps_bearer_id.u8);
|
|
|
|
if (!sess)
|
|
|
|
ogs_error("Unknown EPS Bearer [IMSI:%s, EBI:%d]",
|
|
|
|
sgwc_ue->imsi_bcd, req->linked_eps_bearer_id.u8);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!sess) {
|
|
|
|
ogs_error("No Context");
|
|
|
|
cause_value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
2020-08-13 00:31:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (cause_value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_DELETE_SESSION_RESPONSE_TYPE, cause_value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
ogs_assert(sess);
|
2020-09-22 18:03:45 +00:00
|
|
|
ogs_assert(sess->gnode);
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
ogs_debug(" SGW_S5C_TEID[0x%x] PGW_S5C_TEID[0x%x]",
|
|
|
|
sess->sgw_s5c_teid, sess->pgw_s5c_teid);
|
|
|
|
|
|
|
|
message->h.type = OGS_GTP_DELETE_SESSION_REQUEST_TYPE;
|
|
|
|
message->h.teid = sess->pgw_s5c_teid;
|
|
|
|
|
|
|
|
gtpbuf = ogs_gtp_build_msg(message);
|
|
|
|
ogs_expect_or_return(gtpbuf);
|
|
|
|
|
|
|
|
s5c_xact = ogs_gtp_xact_local_create(
|
2020-11-07 22:27:12 +00:00
|
|
|
sess->gnode, &message->h, gtpbuf, sess_timeout, sess);
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_expect_or_return(s5c_xact);
|
|
|
|
|
|
|
|
ogs_gtp_xact_associate(s11_xact, s5c_xact);
|
|
|
|
|
|
|
|
rv = ogs_gtp_xact_commit(s5c_xact);
|
|
|
|
ogs_expect(rv == OGS_OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_create_bearer_response(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
uint8_t cause_value;
|
|
|
|
uint16_t decoded;
|
|
|
|
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
sgwc_bearer_t *bearer = NULL;
|
|
|
|
sgwc_tunnel_t *dl_tunnel = NULL, *ul_tunnel = NULL;
|
|
|
|
ogs_pfcp_far_t *far = NULL;
|
|
|
|
|
|
|
|
ogs_gtp_xact_t *s5c_xact = NULL;
|
|
|
|
|
|
|
|
ogs_gtp_create_bearer_response_t *rsp = NULL;
|
|
|
|
ogs_gtp_f_teid_t *sgw_s1u_teid = NULL, *enb_s1u_teid = NULL;
|
|
|
|
ogs_gtp_uli_t uli;
|
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
s5c_xact = s11_xact->assoc_xact;
|
|
|
|
ogs_assert(s5c_xact);
|
|
|
|
ogs_assert(message);
|
|
|
|
rsp = &message->create_bearer_response;
|
|
|
|
ogs_assert(rsp);
|
|
|
|
|
|
|
|
ogs_debug("Create Bearer Response");
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
cause_value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
|
|
|
rv = ogs_gtp_xact_commit(s11_xact);
|
|
|
|
ogs_expect(rv == OGS_OK);
|
|
|
|
|
|
|
|
if (rsp->bearer_contexts.presence == 0) {
|
|
|
|
ogs_error("No Bearer");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (rsp->bearer_contexts.eps_bearer_id.presence == 0) {
|
|
|
|
ogs_error("No EPS Bearer ID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (rsp->bearer_contexts.s1_u_enodeb_f_teid.presence == 0) {
|
|
|
|
ogs_error("No eNB TEID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (rsp->bearer_contexts.s4_u_sgsn_f_teid.presence == 0) {
|
|
|
|
ogs_error("No SGW TEID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (rsp->user_location_information.presence == 0) {
|
|
|
|
ogs_error("No User Location Inforamtion");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (s11_xact->xid & OGS_GTP_CMD_XACT_ID)
|
|
|
|
/* MME received Bearer Resource Modification Request */
|
|
|
|
bearer = s5c_xact->data;
|
|
|
|
else
|
|
|
|
bearer = s11_xact->data;
|
2020-08-13 00:31:22 +00:00
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
ogs_assert(bearer);
|
|
|
|
sess = bearer->sess;
|
|
|
|
ogs_assert(sess);
|
|
|
|
|
|
|
|
if (!sgwc_ue) {
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_warn("No Context in TEID");
|
2020-11-07 22:27:12 +00:00
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
sgwc_ue = sess->sgwc_ue;
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
cause_value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
2020-08-13 00:31:22 +00:00
|
|
|
|
|
|
|
if (rsp->cause.presence) {
|
|
|
|
ogs_gtp_cause_t *cause = rsp->cause.data;
|
|
|
|
ogs_assert(cause);
|
|
|
|
|
|
|
|
cause_value = cause->value;
|
|
|
|
if (cause_value == OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
if (rsp->bearer_contexts.cause.presence) {
|
|
|
|
cause = rsp->bearer_contexts.cause.data;
|
|
|
|
ogs_assert(cause);
|
|
|
|
|
|
|
|
cause_value = cause->value;
|
|
|
|
} else {
|
|
|
|
ogs_error("No Cause");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
2020-11-07 22:27:12 +00:00
|
|
|
} else {
|
|
|
|
ogs_warn("GTP Failed [CAUSE:%d]", cause_value);
|
2020-08-13 00:31:22 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ogs_error("No Cause");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cause_value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
2020-11-07 22:27:12 +00:00
|
|
|
sgwc_pfcp_send_bearer_modification_request(
|
|
|
|
bearer, NULL, NULL,
|
|
|
|
OGS_PFCP_MODIFY_UL_ONLY|OGS_PFCP_MODIFY_REMOVE);
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_gtp_send_error_message(s5c_xact, sess ? sess->pgw_s5c_teid : 0,
|
|
|
|
OGS_GTP_CREATE_BEARER_RESPONSE_TYPE, cause_value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
/* Correlate with SGW-S1U-TEID */
|
|
|
|
sgw_s1u_teid = rsp->bearer_contexts.s4_u_sgsn_f_teid.data;
|
|
|
|
ogs_assert(sgw_s1u_teid);
|
|
|
|
|
|
|
|
/* Find the Tunnel by SGW-S1U-TEID */
|
2020-10-26 02:43:53 +00:00
|
|
|
ul_tunnel = sgwc_tunnel_find_by_teid(sgwc_ue, be32toh(sgw_s1u_teid->teid));
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_assert(ul_tunnel);
|
|
|
|
dl_tunnel = sgwc_dl_tunnel_in_bearer(bearer);
|
|
|
|
ogs_assert(dl_tunnel);
|
|
|
|
|
|
|
|
/* Set EBI */
|
|
|
|
bearer->ebi = rsp->bearer_contexts.eps_bearer_id.u8;
|
|
|
|
|
|
|
|
/* Data Plane(DL) : eNB-S1U */
|
|
|
|
enb_s1u_teid = rsp->bearer_contexts.s1_u_enodeb_f_teid.data;
|
|
|
|
dl_tunnel->remote_teid = be32toh(enb_s1u_teid->teid);
|
|
|
|
|
|
|
|
ogs_debug(" ENB_S1U_TEID[%d] SGW_S1U_TEID[%d]",
|
|
|
|
dl_tunnel->remote_teid, dl_tunnel->local_teid);
|
|
|
|
|
|
|
|
rv = ogs_gtp_f_teid_to_ip(enb_s1u_teid, &dl_tunnel->remote_ip);
|
|
|
|
if (rv != OGS_OK) {
|
|
|
|
ogs_gtp_send_error_message(s5c_xact, sess ? sess->pgw_s5c_teid : 0,
|
|
|
|
OGS_GTP_CREATE_BEARER_RESPONSE_TYPE,
|
|
|
|
OGS_GTP_CAUSE_MANDATORY_IE_MISSING);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
far = dl_tunnel->far;
|
|
|
|
ogs_assert(far);
|
|
|
|
|
2020-12-03 06:16:57 +00:00
|
|
|
far->apply_action = OGS_PFCP_APPLY_ACTION_FORW;
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_pfcp_ip_to_outer_header_creation(&dl_tunnel->remote_ip,
|
|
|
|
&far->outer_header_creation, &far->outer_header_creation_len);
|
|
|
|
far->outer_header_creation.teid = dl_tunnel->remote_teid;
|
|
|
|
|
|
|
|
decoded = ogs_gtp_parse_uli(&uli, &rsp->user_location_information);
|
|
|
|
ogs_assert(rsp->user_location_information.len == decoded);
|
|
|
|
memcpy(&sgwc_ue->e_tai.plmn_id, &uli.tai.plmn_id, sizeof(uli.tai.plmn_id));
|
|
|
|
sgwc_ue->e_tai.tac = uli.tai.tac;
|
|
|
|
memcpy(&sgwc_ue->e_cgi.plmn_id,
|
|
|
|
&uli.e_cgi.plmn_id, sizeof(uli.e_cgi.plmn_id));
|
|
|
|
sgwc_ue->e_cgi.cell_id = uli.e_cgi.cell_id;
|
|
|
|
|
|
|
|
ogs_debug(" TAI[PLMN_ID:%06x,TAC:%d]",
|
|
|
|
ogs_plmn_id_hexdump(&sgwc_ue->e_tai.plmn_id),
|
|
|
|
sgwc_ue->e_tai.tac);
|
|
|
|
ogs_debug(" E_CGI[PLMN_ID:%06x,CELL_ID:%d]",
|
|
|
|
ogs_plmn_id_hexdump(&sgwc_ue->e_cgi.plmn_id),
|
|
|
|
sgwc_ue->e_cgi.cell_id);
|
|
|
|
|
|
|
|
sgwc_pfcp_send_bearer_modification_request(
|
|
|
|
bearer, s5c_xact, gtpbuf,
|
|
|
|
OGS_PFCP_MODIFY_DL_ONLY|OGS_PFCP_MODIFY_CREATE);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_update_bearer_response(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
uint8_t cause_value;
|
|
|
|
ogs_pkbuf_t *pkbuf = NULL;
|
|
|
|
ogs_gtp_xact_t *s5c_xact = NULL;
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
sgwc_bearer_t *bearer = NULL;
|
2020-11-07 22:27:12 +00:00
|
|
|
ogs_gtp_update_bearer_response_t *rsp = NULL;
|
2020-08-13 00:31:22 +00:00
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
s5c_xact = s11_xact->assoc_xact;
|
|
|
|
ogs_assert(s5c_xact);
|
|
|
|
ogs_assert(message);
|
2020-11-07 22:27:12 +00:00
|
|
|
rsp = &message->update_bearer_response;
|
|
|
|
ogs_assert(rsp);
|
2020-08-13 00:31:22 +00:00
|
|
|
|
|
|
|
ogs_debug("Update Bearer Response");
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
cause_value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
|
|
|
rv = ogs_gtp_xact_commit(s11_xact);
|
|
|
|
ogs_expect(rv == OGS_OK);
|
|
|
|
|
|
|
|
if (rsp->bearer_contexts.presence == 0) {
|
|
|
|
ogs_error("No Bearer");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (rsp->bearer_contexts.eps_bearer_id.presence == 0) {
|
|
|
|
ogs_error("No EPS Bearer ID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (s11_xact->xid & OGS_GTP_CMD_XACT_ID)
|
|
|
|
/* MME received Bearer Resource Modification Request */
|
|
|
|
bearer = s5c_xact->data;
|
|
|
|
else
|
|
|
|
bearer = s11_xact->data;
|
|
|
|
|
|
|
|
ogs_assert(bearer);
|
|
|
|
sess = bearer->sess;
|
|
|
|
ogs_assert(sess);
|
|
|
|
|
|
|
|
if (!sgwc_ue) {
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_warn("No Context in TEID");
|
2020-11-07 22:27:12 +00:00
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
sgwc_ue = sess->sgwc_ue;
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
cause_value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
2020-08-13 00:31:22 +00:00
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (rsp->cause.presence) {
|
|
|
|
ogs_gtp_cause_t *cause = rsp->cause.data;
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_assert(cause);
|
|
|
|
|
|
|
|
cause_value = cause->value;
|
|
|
|
if (cause_value == OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
2020-11-07 22:27:12 +00:00
|
|
|
if (rsp->bearer_contexts.cause.presence) {
|
|
|
|
cause = rsp->bearer_contexts.cause.data;
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_assert(cause);
|
|
|
|
|
|
|
|
cause_value = cause->value;
|
|
|
|
} else {
|
|
|
|
ogs_error("No Cause");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
2020-11-07 22:27:12 +00:00
|
|
|
} else {
|
|
|
|
ogs_warn("GTP Failed [CAUSE:%d]", cause_value);
|
2020-08-13 00:31:22 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ogs_error("No Cause");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cause_value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
ogs_gtp_send_error_message(s5c_xact, sess ? sess->pgw_s5c_teid : 0,
|
|
|
|
OGS_GTP_UPDATE_BEARER_RESPONSE_TYPE, cause_value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
ogs_debug(" SGW_S5C_TEID[0x%x] PGW_S5C_TEID[0x%x]",
|
|
|
|
sess->sgw_s5c_teid, sess->pgw_s5c_teid);
|
|
|
|
|
|
|
|
message->h.type = OGS_GTP_UPDATE_BEARER_RESPONSE_TYPE;
|
|
|
|
message->h.teid = sess->pgw_s5c_teid;
|
|
|
|
|
|
|
|
pkbuf = ogs_gtp_build_msg(message);
|
|
|
|
ogs_expect_or_return(pkbuf);
|
|
|
|
|
|
|
|
rv = ogs_gtp_xact_update_tx(s5c_xact, &message->h, pkbuf);
|
|
|
|
ogs_expect_or_return(rv == OGS_OK);
|
|
|
|
|
|
|
|
rv = ogs_gtp_xact_commit(s5c_xact);
|
|
|
|
ogs_expect(rv == OGS_OK);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_delete_bearer_response(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
uint8_t cause_value;
|
|
|
|
ogs_gtp_xact_t *s5c_xact = NULL;
|
|
|
|
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
sgwc_bearer_t *bearer = NULL;
|
2020-11-07 22:27:12 +00:00
|
|
|
ogs_gtp_delete_bearer_response_t *rsp = NULL;
|
2020-08-13 00:31:22 +00:00
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
s5c_xact = s11_xact->assoc_xact;
|
|
|
|
ogs_assert(s5c_xact);
|
|
|
|
ogs_assert(message);
|
2020-11-07 22:27:12 +00:00
|
|
|
rsp = &message->delete_bearer_response;
|
|
|
|
ogs_assert(rsp);
|
2020-08-13 00:31:22 +00:00
|
|
|
|
|
|
|
ogs_debug("Delete Bearer Response");
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
cause_value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
|
|
|
rv = ogs_gtp_xact_commit(s11_xact);
|
|
|
|
ogs_expect(rv == OGS_OK);
|
|
|
|
|
|
|
|
if (rsp->bearer_contexts.presence == 0) {
|
|
|
|
ogs_error("No Bearer");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (rsp->bearer_contexts.eps_bearer_id.presence == 0) {
|
|
|
|
ogs_error("No EPS Bearer ID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
2020-08-13 00:31:22 +00:00
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (s11_xact->xid & OGS_GTP_CMD_XACT_ID)
|
|
|
|
/* MME received Bearer Resource Modification Request */
|
|
|
|
bearer = s5c_xact->data;
|
|
|
|
else
|
|
|
|
bearer = s11_xact->data;
|
|
|
|
|
|
|
|
ogs_assert(bearer);
|
|
|
|
sess = bearer->sess;
|
|
|
|
ogs_assert(sess);
|
|
|
|
|
|
|
|
if (!sgwc_ue) {
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_warn("No Context in TEID");
|
2020-11-07 22:27:12 +00:00
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
sgwc_ue = sess->sgwc_ue;
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
cause_value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
2020-08-13 00:31:22 +00:00
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (rsp->cause.presence) {
|
|
|
|
ogs_gtp_cause_t *cause = rsp->cause.data;
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_assert(cause);
|
|
|
|
|
|
|
|
cause_value = cause->value;
|
|
|
|
if (cause_value == OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
2020-11-07 22:27:12 +00:00
|
|
|
if (rsp->bearer_contexts.cause.presence) {
|
|
|
|
cause = rsp->bearer_contexts.cause.data;
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_assert(cause);
|
|
|
|
|
|
|
|
cause_value = cause->value;
|
|
|
|
} else {
|
|
|
|
ogs_error("No Cause");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
2020-11-07 22:27:12 +00:00
|
|
|
} else {
|
|
|
|
ogs_warn("GTP Failed [CAUSE:%d]", cause_value);
|
2020-08-13 00:31:22 +00:00
|
|
|
}
|
|
|
|
} else {
|
|
|
|
ogs_error("No Cause");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
|
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
ogs_debug(" SGW_S5C_TEID[0x%x] PGW_S5C_TEID[0x%x]",
|
|
|
|
sess->sgw_s5c_teid, sess->pgw_s5c_teid);
|
|
|
|
|
|
|
|
sgwc_pfcp_send_bearer_modification_request(
|
|
|
|
bearer, s5c_xact, gtpbuf, OGS_PFCP_MODIFY_REMOVE);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_release_access_bearers_request(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
|
|
|
|
ogs_gtp_release_access_bearers_request_t *req = NULL;
|
|
|
|
ogs_gtp_cause_t cause;
|
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
ogs_assert(message);
|
|
|
|
req = &message->release_access_bearers_request;
|
|
|
|
ogs_assert(req);
|
|
|
|
|
|
|
|
ogs_debug("Release Access Bearers Request");
|
|
|
|
|
|
|
|
memset(&cause, 0, sizeof(cause));
|
|
|
|
cause.value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
|
|
|
if (!sgwc_ue) {
|
|
|
|
ogs_warn("No Context");
|
|
|
|
cause.value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cause.value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_RELEASE_ACCESS_BEARERS_RESPONSE_TYPE, cause.value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
|
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
|
|
|
|
ogs_list_for_each(&sgwc_ue->sess_list, sess) {
|
|
|
|
|
|
|
|
sess->state.release_access_bearers = false;
|
|
|
|
sgwc_pfcp_send_sess_modification_request(
|
|
|
|
sess, s11_xact, gtpbuf,
|
|
|
|
OGS_PFCP_MODIFY_DL_ONLY|OGS_PFCP_MODIFY_DEACTIVATE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_downlink_data_notification_ack(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
uint8_t cause_value;
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
sgwc_bearer_t *bearer = NULL;
|
2020-08-13 00:31:22 +00:00
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
|
|
|
|
ogs_gtp_downlink_data_notification_acknowledge_t *ack = NULL;
|
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
ogs_assert(message);
|
|
|
|
ack = &message->downlink_data_notification_acknowledge;
|
|
|
|
ogs_assert(ack);
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
bearer = s11_xact->data;
|
|
|
|
ogs_assert(bearer);
|
|
|
|
sess = bearer->sess;
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_assert(sess);
|
|
|
|
sgwc_ue = sess->sgwc_ue;
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
cause_value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
rv = ogs_gtp_xact_commit(s11_xact);
|
|
|
|
ogs_expect(rv == OGS_OK);
|
|
|
|
|
|
|
|
if (ack->cause.presence) {
|
|
|
|
ogs_gtp_cause_t *cause = ack->cause.data;
|
|
|
|
ogs_assert(cause);
|
|
|
|
|
|
|
|
cause_value = cause->value;
|
2020-10-21 00:00:02 +00:00
|
|
|
if (cause_value != OGS_GTP_CAUSE_REQUEST_ACCEPTED)
|
|
|
|
ogs_warn("GTP Failed [CAUSE:%d] - PFCP_CAUSE[%d]",
|
|
|
|
cause_value, pfcp_cause_from_gtp(cause_value));
|
2020-08-13 00:31:22 +00:00
|
|
|
} else {
|
|
|
|
ogs_error("No Cause");
|
|
|
|
}
|
|
|
|
|
|
|
|
ogs_debug("Downlink Data Notification Acknowledge");
|
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_create_indirect_data_forwarding_tunnel_request(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
int rv, i;
|
|
|
|
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
sgwc_bearer_t *bearer = NULL;
|
|
|
|
sgwc_tunnel_t *tunnel = NULL;
|
|
|
|
ogs_pfcp_far_t *far = NULL;
|
|
|
|
|
|
|
|
ogs_gtp_create_indirect_data_forwarding_tunnel_request_t *req = NULL;
|
|
|
|
ogs_gtp_cause_t cause;
|
|
|
|
ogs_gtp_f_teid_t *req_teid = NULL;
|
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
ogs_assert(message);
|
|
|
|
req = &message->create_indirect_data_forwarding_tunnel_request;
|
|
|
|
ogs_assert(req);
|
|
|
|
|
|
|
|
ogs_debug("Create Indirect Data Forwarding Tunnel Request");
|
|
|
|
|
|
|
|
memset(&cause, 0, sizeof(cause));
|
|
|
|
cause.value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
|
|
|
if (!sgwc_ue) {
|
|
|
|
ogs_warn("No Context");
|
|
|
|
cause.value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cause.value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_CREATE_INDIRECT_DATA_FORWARDING_TUNNEL_RESPONSE_TYPE,
|
|
|
|
cause.value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
|
|
|
|
for (i = 0; req->bearer_contexts[i].presence; i++) {
|
|
|
|
if (req->bearer_contexts[i].eps_bearer_id.presence == 0) {
|
|
|
|
ogs_error("No EBI");
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_CREATE_INDIRECT_DATA_FORWARDING_TUNNEL_RESPONSE_TYPE,
|
|
|
|
OGS_GTP_CAUSE_MANDATORY_IE_MISSING);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
bearer = sgwc_bearer_find_by_ue_ebi(sgwc_ue,
|
|
|
|
req->bearer_contexts[i].eps_bearer_id.u8);
|
|
|
|
ogs_assert(bearer);
|
|
|
|
|
|
|
|
if (req->bearer_contexts[i].s1_u_enodeb_f_teid.presence) {
|
|
|
|
req_teid = req->bearer_contexts[i].s1_u_enodeb_f_teid.data;
|
|
|
|
ogs_assert(req_teid);
|
|
|
|
|
|
|
|
tunnel = sgwc_tunnel_add(bearer,
|
|
|
|
OGS_GTP_F_TEID_SGW_GTP_U_FOR_DL_DATA_FORWARDING);
|
|
|
|
ogs_assert(tunnel);
|
|
|
|
|
|
|
|
tunnel->remote_teid = be32toh(req_teid->teid);
|
|
|
|
|
|
|
|
rv = ogs_gtp_f_teid_to_ip(req_teid, &tunnel->remote_ip);
|
|
|
|
if (rv != OGS_OK) {
|
|
|
|
ogs_gtp_send_error_message(s11_xact,
|
|
|
|
sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_CREATE_INDIRECT_DATA_FORWARDING_TUNNEL_RESPONSE_TYPE,
|
|
|
|
OGS_GTP_CAUSE_MANDATORY_IE_MISSING);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
far = tunnel->far;
|
|
|
|
ogs_assert(far);
|
|
|
|
|
2020-12-03 06:16:57 +00:00
|
|
|
far->apply_action = OGS_PFCP_APPLY_ACTION_FORW;
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_pfcp_ip_to_outer_header_creation(&tunnel->remote_ip,
|
|
|
|
&far->outer_header_creation, &far->outer_header_creation_len);
|
|
|
|
far->outer_header_creation.teid = tunnel->remote_teid;
|
|
|
|
|
|
|
|
ogs_debug(" SGW_DL_TEID[%d] ENB_DL_TEID[%d]",
|
|
|
|
tunnel->local_teid, tunnel->remote_teid);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (req->bearer_contexts[i].s12_rnc_f_teid.presence) {
|
|
|
|
req_teid = req->bearer_contexts[i].s12_rnc_f_teid.data;
|
|
|
|
ogs_assert(req_teid);
|
|
|
|
|
|
|
|
tunnel = sgwc_tunnel_add(bearer,
|
|
|
|
OGS_GTP_F_TEID_SGW_GTP_U_FOR_UL_DATA_FORWARDING);
|
|
|
|
ogs_assert(tunnel);
|
|
|
|
|
|
|
|
tunnel->remote_teid = be32toh(req_teid->teid);
|
|
|
|
|
|
|
|
rv = ogs_gtp_f_teid_to_ip(req_teid, &tunnel->remote_ip);
|
|
|
|
if (rv != OGS_OK) {
|
|
|
|
ogs_gtp_send_error_message(s11_xact,
|
|
|
|
sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_CREATE_INDIRECT_DATA_FORWARDING_TUNNEL_RESPONSE_TYPE,
|
|
|
|
OGS_GTP_CAUSE_MANDATORY_IE_MISSING);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
far = tunnel->far;
|
|
|
|
ogs_assert(far);
|
|
|
|
|
2020-12-03 06:16:57 +00:00
|
|
|
far->apply_action = OGS_PFCP_APPLY_ACTION_FORW;
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_pfcp_ip_to_outer_header_creation(&tunnel->remote_ip,
|
|
|
|
&far->outer_header_creation, &far->outer_header_creation_len);
|
|
|
|
far->outer_header_creation.teid = tunnel->remote_teid;
|
|
|
|
|
|
|
|
ogs_debug(" SGW_UL_TEID[%d] ENB_UL_TEID[%d]",
|
|
|
|
tunnel->local_teid, tunnel->remote_teid);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
ogs_list_for_each(&sgwc_ue->sess_list, sess) {
|
|
|
|
|
|
|
|
sess->state.create_indirect_tunnel = false;
|
|
|
|
sgwc_pfcp_send_sess_modification_request(
|
|
|
|
sess, s11_xact, gtpbuf,
|
|
|
|
OGS_PFCP_MODIFY_INDIRECT|OGS_PFCP_MODIFY_CREATE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_delete_indirect_data_forwarding_tunnel_request(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *recv_message)
|
|
|
|
{
|
|
|
|
sgwc_sess_t *sess = NULL;
|
|
|
|
|
|
|
|
ogs_gtp_cause_t cause;
|
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
|
|
|
|
ogs_debug("Delete Indirect Data Forwarding Tunnel Request");
|
|
|
|
|
|
|
|
memset(&cause, 0, sizeof(cause));
|
|
|
|
cause.value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
|
|
|
if (!sgwc_ue) {
|
|
|
|
ogs_warn("No Context");
|
|
|
|
cause.value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (cause.value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_DELETE_INDIRECT_DATA_FORWARDING_TUNNEL_RESPONSE_TYPE,
|
|
|
|
cause.value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
ogs_assert(sgwc_ue);
|
|
|
|
|
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
|
|
|
|
ogs_list_for_each(&sgwc_ue->sess_list, sess) {
|
|
|
|
|
|
|
|
sess->state.delete_indirect_tunnel = false;
|
|
|
|
sgwc_pfcp_send_sess_modification_request(
|
|
|
|
sess, s11_xact, gtpbuf,
|
|
|
|
OGS_PFCP_MODIFY_SESSION|
|
|
|
|
OGS_PFCP_MODIFY_INDIRECT|
|
|
|
|
OGS_PFCP_MODIFY_REMOVE);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgwc_s11_handle_bearer_resource_command(
|
|
|
|
sgwc_ue_t *sgwc_ue, ogs_gtp_xact_t *s11_xact,
|
|
|
|
ogs_pkbuf_t *gtpbuf, ogs_gtp_message_t *message)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
ogs_pkbuf_t *pkbuf = NULL;
|
|
|
|
ogs_gtp_bearer_resource_command_t *cmd = NULL;
|
|
|
|
|
|
|
|
uint8_t cause_value = 0;
|
|
|
|
ogs_gtp_xact_t *s5c_xact = NULL;
|
|
|
|
|
|
|
|
sgwc_sess_t *sess = NULL;
|
2020-11-07 22:27:12 +00:00
|
|
|
sgwc_bearer_t *bearer = NULL;
|
2020-08-13 00:31:22 +00:00
|
|
|
|
|
|
|
ogs_assert(s11_xact);
|
|
|
|
ogs_assert(message);
|
|
|
|
|
|
|
|
ogs_debug("Bearer Resource Command");
|
|
|
|
|
|
|
|
cmd = &message->bearer_resource_command;
|
|
|
|
cause_value = OGS_GTP_CAUSE_REQUEST_ACCEPTED;
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (cmd->procedure_transaction_id.presence == 0) {
|
|
|
|
ogs_error("No PTI");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (cmd->traffic_aggregate_description.presence == 0) {
|
|
|
|
ogs_error("No Traffic aggregate description(TAD)");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
if (cmd->linked_eps_bearer_id.presence == 0) {
|
|
|
|
ogs_error("No Linked EPS Bearer ID");
|
|
|
|
cause_value = OGS_GTP_CAUSE_MANDATORY_IE_MISSING;
|
|
|
|
}
|
|
|
|
|
2020-08-13 00:31:22 +00:00
|
|
|
if (!sgwc_ue) {
|
|
|
|
ogs_warn("No Context");
|
|
|
|
cause_value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
|
|
|
}
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (cause_value == OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
bearer = sgwc_bearer_find_by_ue_ebi(
|
|
|
|
sgwc_ue, cmd->linked_eps_bearer_id.u8);
|
|
|
|
if (!bearer)
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_error("No Context for Linked EPS Bearer ID[%d]",
|
|
|
|
cmd->linked_eps_bearer_id.u8);
|
|
|
|
}
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
if (!bearer) {
|
|
|
|
ogs_error("No context");
|
|
|
|
cause_value = OGS_GTP_CAUSE_CONTEXT_NOT_FOUND;
|
2020-08-13 00:31:22 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
if (cause_value != OGS_GTP_CAUSE_REQUEST_ACCEPTED) {
|
|
|
|
ogs_gtp_send_error_message(
|
|
|
|
s11_xact, sgwc_ue ? sgwc_ue->mme_s11_teid : 0,
|
|
|
|
OGS_GTP_BEARER_RESOURCE_FAILURE_INDICATION_TYPE, cause_value);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-11-07 22:27:12 +00:00
|
|
|
ogs_assert(bearer);
|
|
|
|
sess = bearer->sess;
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_assert(sess);
|
2020-09-22 18:03:45 +00:00
|
|
|
ogs_assert(sess->gnode);
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_debug(" MME_S11_TEID[%d] SGW_S11_TEID[%d]",
|
|
|
|
sgwc_ue->mme_s11_teid, sgwc_ue->sgw_s11_teid);
|
|
|
|
ogs_debug(" SGW_S5C_TEID[0x%x] PGW_S5C_TEID[0x%x]",
|
|
|
|
sess->sgw_s5c_teid, sess->pgw_s5c_teid);
|
|
|
|
|
|
|
|
message->h.type = OGS_GTP_BEARER_RESOURCE_COMMAND_TYPE;
|
|
|
|
message->h.teid = sess->pgw_s5c_teid;
|
|
|
|
|
|
|
|
pkbuf = ogs_gtp_build_msg(message);
|
|
|
|
ogs_expect_or_return(pkbuf);
|
|
|
|
|
|
|
|
s5c_xact = ogs_gtp_xact_local_create(
|
2020-11-07 22:27:12 +00:00
|
|
|
sess->gnode, &message->h, pkbuf, bearer_timeout, bearer);
|
2020-08-13 00:31:22 +00:00
|
|
|
ogs_expect_or_return(s5c_xact);
|
|
|
|
|
|
|
|
ogs_gtp_xact_associate(s11_xact, s5c_xact);
|
|
|
|
|
|
|
|
rv = ogs_gtp_xact_commit(s5c_xact);
|
|
|
|
ogs_expect(rv == OGS_OK);
|
|
|
|
}
|