2019-06-16 06:40:26 +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/>.
|
|
|
|
*/
|
|
|
|
|
2019-06-16 10:09:31 +00:00
|
|
|
#include "ogs-sctp.h"
|
|
|
|
|
2019-06-16 09:20:40 +00:00
|
|
|
#include "mme-context.h"
|
2019-06-16 06:40:26 +00:00
|
|
|
#include "mme-event.h"
|
2019-07-20 06:34:41 +00:00
|
|
|
#include "mme-timer.h"
|
2019-06-16 06:40:26 +00:00
|
|
|
#include "mme-sm.h"
|
|
|
|
|
2019-06-16 09:20:40 +00:00
|
|
|
#include "sgsap-path.h"
|
2019-06-21 15:28:21 +00:00
|
|
|
#include "sgsap-handler.h"
|
2019-06-16 09:20:40 +00:00
|
|
|
|
2019-06-16 06:40:26 +00:00
|
|
|
void sgsap_state_initial(ogs_fsm_t *s, mme_event_t *e)
|
|
|
|
{
|
2019-06-16 09:20:40 +00:00
|
|
|
mme_vlr_t *vlr = NULL;
|
2019-06-16 06:40:26 +00:00
|
|
|
ogs_assert(s);
|
2019-06-16 09:20:40 +00:00
|
|
|
ogs_assert(e);
|
2019-06-16 06:40:26 +00:00
|
|
|
|
|
|
|
mme_sm_debug(e);
|
|
|
|
|
2019-06-16 09:20:40 +00:00
|
|
|
vlr = e->vlr;
|
|
|
|
ogs_assert(vlr);
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
vlr->t_conn = ogs_timer_add(ogs_app()->timer_mgr,
|
2019-07-20 06:34:41 +00:00
|
|
|
mme_timer_sgs_cli_conn_to_srv, vlr);
|
2019-11-29 06:31:22 +00:00
|
|
|
ogs_expect_or_return(vlr->t_conn);
|
2019-06-16 09:20:40 +00:00
|
|
|
|
2019-06-16 06:40:26 +00:00
|
|
|
OGS_FSM_TRAN(s, &sgsap_state_will_connect);
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgsap_state_final(ogs_fsm_t *s, mme_event_t *e)
|
|
|
|
{
|
2019-06-16 09:20:40 +00:00
|
|
|
mme_vlr_t *vlr = NULL;
|
2019-06-16 06:40:26 +00:00
|
|
|
ogs_assert(s);
|
2019-06-16 09:20:40 +00:00
|
|
|
ogs_assert(e);
|
2019-06-16 06:40:26 +00:00
|
|
|
|
|
|
|
mme_sm_debug(e);
|
2019-06-16 09:20:40 +00:00
|
|
|
|
|
|
|
vlr = e->vlr;
|
|
|
|
ogs_assert(vlr);
|
|
|
|
|
|
|
|
ogs_timer_delete(vlr->t_conn);
|
2019-06-16 06:40:26 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
void sgsap_state_will_connect(ogs_fsm_t *s, mme_event_t *e)
|
|
|
|
{
|
2019-07-20 06:34:41 +00:00
|
|
|
char buf[OGS_ADDRSTRLEN];
|
|
|
|
|
2019-06-16 08:33:45 +00:00
|
|
|
mme_vlr_t *vlr = NULL;
|
2019-07-20 06:34:41 +00:00
|
|
|
ogs_sockaddr_t *addr = NULL;
|
2019-06-16 06:40:26 +00:00
|
|
|
ogs_assert(s);
|
|
|
|
ogs_assert(e);
|
|
|
|
|
|
|
|
mme_sm_debug(e);
|
|
|
|
|
2019-06-16 08:33:45 +00:00
|
|
|
vlr = e->vlr;
|
|
|
|
ogs_assert(vlr);
|
|
|
|
|
2019-06-16 10:09:31 +00:00
|
|
|
ogs_assert(vlr->t_conn);
|
|
|
|
|
2019-06-16 06:40:26 +00:00
|
|
|
switch (e->id) {
|
|
|
|
case OGS_FSM_ENTRY_SIG:
|
2019-07-20 07:25:09 +00:00
|
|
|
ogs_timer_start(vlr->t_conn,
|
|
|
|
mme_timer_cfg(MME_TIMER_SGS_CLI_CONN_TO_SRV)->duration);
|
2019-06-16 13:17:38 +00:00
|
|
|
sgsap_client(vlr);
|
2019-06-16 06:40:26 +00:00
|
|
|
break;
|
|
|
|
case OGS_FSM_EXIT_SIG:
|
2019-06-16 10:09:31 +00:00
|
|
|
ogs_timer_stop(vlr->t_conn);
|
2019-06-16 06:40:26 +00:00
|
|
|
break;
|
2019-07-20 06:34:41 +00:00
|
|
|
case MME_EVT_SGSAP_TIMER:
|
|
|
|
switch(e->timer_id) {
|
|
|
|
case MME_TIMER_SGS_CLI_CONN_TO_SRV:
|
|
|
|
vlr = e->vlr;
|
|
|
|
ogs_assert(vlr);
|
2020-11-04 20:58:16 +00:00
|
|
|
addr = vlr->sa_list;
|
2019-07-20 06:34:41 +00:00
|
|
|
ogs_assert(addr);
|
|
|
|
|
|
|
|
ogs_warn("[SGsAP] Connect to VLR [%s]:%d failed",
|
|
|
|
OGS_ADDR(addr, buf), OGS_PORT(addr));
|
|
|
|
|
|
|
|
ogs_assert(vlr->t_conn);
|
2019-07-20 07:25:09 +00:00
|
|
|
ogs_timer_start(vlr->t_conn,
|
|
|
|
mme_timer_cfg(MME_TIMER_SGS_CLI_CONN_TO_SRV)->duration);
|
2019-07-20 06:34:41 +00:00
|
|
|
|
2019-10-31 05:17:43 +00:00
|
|
|
mme_vlr_close(vlr);
|
2019-07-20 06:34:41 +00:00
|
|
|
sgsap_client(vlr);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ogs_error("Unknown timer[%s:%d]",
|
|
|
|
mme_timer_get_name(e->timer_id), e->timer_id);
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
break;
|
2019-06-16 13:17:38 +00:00
|
|
|
case MME_EVT_SGSAP_LO_SCTP_COMM_UP:
|
|
|
|
OGS_FSM_TRAN(s, sgsap_state_connected);
|
|
|
|
break;
|
2019-06-16 06:40:26 +00:00
|
|
|
default:
|
|
|
|
ogs_error("Unknown event %s", mme_event_get_name(e));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgsap_state_connected(ogs_fsm_t *s, mme_event_t *e)
|
|
|
|
{
|
2019-06-17 01:36:44 +00:00
|
|
|
mme_vlr_t *vlr = NULL;
|
2019-06-21 15:28:21 +00:00
|
|
|
ogs_pkbuf_t *pkbuf = NULL;
|
|
|
|
uint8_t type;
|
2019-06-16 06:40:26 +00:00
|
|
|
ogs_assert(s);
|
|
|
|
ogs_assert(e);
|
|
|
|
|
|
|
|
mme_sm_debug(e);
|
|
|
|
|
2019-06-17 01:36:44 +00:00
|
|
|
vlr = e->vlr;
|
|
|
|
ogs_assert(vlr);
|
|
|
|
|
2019-06-16 06:40:26 +00:00
|
|
|
switch (e->id) {
|
|
|
|
case OGS_FSM_ENTRY_SIG:
|
|
|
|
break;
|
|
|
|
case OGS_FSM_EXIT_SIG:
|
|
|
|
break;
|
2019-06-16 14:33:23 +00:00
|
|
|
case MME_EVT_SGSAP_LO_CONNREFUSED:
|
2019-10-31 05:17:43 +00:00
|
|
|
mme_vlr_close(vlr);
|
2019-06-16 14:33:23 +00:00
|
|
|
OGS_FSM_TRAN(s, sgsap_state_will_connect);
|
|
|
|
break;
|
2019-06-16 06:40:26 +00:00
|
|
|
case MME_EVT_SGSAP_MESSAGE:
|
2019-06-21 15:28:21 +00:00
|
|
|
pkbuf = e->pkbuf;
|
|
|
|
ogs_assert(pkbuf);
|
|
|
|
type = *(unsigned char *)(pkbuf->data);
|
|
|
|
switch (type) {
|
|
|
|
case SGSAP_LOCATION_UPDATE_ACCEPT:
|
2019-07-05 09:13:32 +00:00
|
|
|
sgsap_handle_location_update_accept(vlr, pkbuf);
|
2019-06-21 15:28:21 +00:00
|
|
|
break;
|
2019-07-05 06:55:07 +00:00
|
|
|
case SGSAP_LOCATION_UPDATE_REJECT:
|
2019-07-05 09:13:32 +00:00
|
|
|
sgsap_handle_location_update_reject(vlr, pkbuf);
|
|
|
|
break;
|
|
|
|
case SGSAP_EPS_DETACH_ACK:
|
|
|
|
case SGSAP_IMSI_DETACH_ACK:
|
|
|
|
sgsap_handle_detach_ack(vlr, pkbuf);
|
2019-07-05 06:55:07 +00:00
|
|
|
break;
|
2019-07-08 09:15:19 +00:00
|
|
|
case SGSAP_PAGING_REQUEST:
|
|
|
|
sgsap_handle_paging_request(vlr, pkbuf);
|
|
|
|
break;
|
2019-07-13 13:52:50 +00:00
|
|
|
case SGSAP_DOWNLINK_UNITDATA:
|
|
|
|
sgsap_handle_downlink_unitdata(vlr, pkbuf);
|
|
|
|
break;
|
2019-07-07 01:16:21 +00:00
|
|
|
case SGSAP_RESET_INDICATION:
|
|
|
|
sgsap_handle_reset_indication(vlr, pkbuf);
|
|
|
|
|
2019-10-31 05:17:43 +00:00
|
|
|
mme_vlr_close(vlr);
|
2019-07-07 01:16:21 +00:00
|
|
|
OGS_FSM_TRAN(s, sgsap_state_will_connect);
|
|
|
|
break;
|
2019-07-13 05:51:35 +00:00
|
|
|
case SGSAP_RELEASE_REQUEST:
|
|
|
|
sgsap_handle_release_request(vlr, pkbuf);
|
|
|
|
break;
|
2019-07-21 13:52:28 +00:00
|
|
|
case SGSAP_MM_INFORMATION_REQUEST:
|
|
|
|
sgsap_handle_mm_information_request(vlr, pkbuf);
|
|
|
|
break;
|
2019-06-21 15:28:21 +00:00
|
|
|
default:
|
2019-07-07 01:16:21 +00:00
|
|
|
ogs_warn("Unknown Message Type: [%d]", type);
|
2019-06-21 15:28:21 +00:00
|
|
|
break;
|
|
|
|
}
|
2019-06-16 06:40:26 +00:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ogs_error("Unknown event %s", mme_event_get_name(e));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void sgsap_state_exception(ogs_fsm_t *s, mme_event_t *e)
|
|
|
|
{
|
|
|
|
ogs_assert(s);
|
|
|
|
ogs_assert(e);
|
|
|
|
|
|
|
|
mme_sm_debug(e);
|
|
|
|
|
|
|
|
switch (e->id) {
|
|
|
|
case OGS_FSM_ENTRY_SIG:
|
|
|
|
break;
|
|
|
|
case OGS_FSM_EXIT_SIG:
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ogs_error("Unknown event %s", mme_event_get_name(e));
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|