2020-04-26 19:36:05 +00:00
|
|
|
/*
|
2022-08-12 05:03:53 +00:00
|
|
|
* Copyright (C) 2019-2022 by Sukchan Lee <acetcom@gmail.com>
|
2020-04-26 19:36:05 +00:00
|
|
|
*
|
|
|
|
* 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 "context.h"
|
|
|
|
|
2022-08-12 05:03:53 +00:00
|
|
|
const char *smf_timer_get_name(int timer_id)
|
2020-04-26 19:36:05 +00:00
|
|
|
{
|
2022-08-12 05:03:53 +00:00
|
|
|
switch (timer_id) {
|
|
|
|
case OGS_TIMER_NF_INSTANCE_REGISTRATION_INTERVAL:
|
|
|
|
return OGS_TIMER_NAME_NF_INSTANCE_REGISTRATION_INTERVAL;
|
|
|
|
case OGS_TIMER_NF_INSTANCE_HEARTBEAT_INTERVAL:
|
|
|
|
return OGS_TIMER_NAME_NF_INSTANCE_HEARTBEAT_INTERVAL;
|
|
|
|
case OGS_TIMER_NF_INSTANCE_NO_HEARTBEAT:
|
|
|
|
return OGS_TIMER_NAME_NF_INSTANCE_NO_HEARTBEAT;
|
|
|
|
case OGS_TIMER_NF_INSTANCE_VALIDITY:
|
|
|
|
return OGS_TIMER_NAME_NF_INSTANCE_VALIDITY;
|
|
|
|
case OGS_TIMER_SUBSCRIPTION_VALIDITY:
|
|
|
|
return OGS_TIMER_NAME_SUBSCRIPTION_VALIDITY;
|
2023-03-12 13:06:19 +00:00
|
|
|
case OGS_TIMER_SUBSCRIPTION_PATCH:
|
|
|
|
return OGS_TIMER_NAME_SUBSCRIPTION_PATCH;
|
2022-08-12 05:03:53 +00:00
|
|
|
case OGS_TIMER_SBI_CLIENT_WAIT:
|
|
|
|
return OGS_TIMER_NAME_SBI_CLIENT_WAIT;
|
2020-05-18 21:00:37 +00:00
|
|
|
case SMF_TIMER_PFCP_ASSOCIATION:
|
|
|
|
return "SMF_TIMER_PFCP_ASSOCIATION";
|
2020-07-27 01:02:40 +00:00
|
|
|
case SMF_TIMER_PFCP_NO_HEARTBEAT:
|
|
|
|
return "SMF_TIMER_PFCP_NO_HEARTBEAT";
|
2023-07-10 12:13:28 +00:00
|
|
|
case SMF_TIMER_PFCP_NO_ESTABLISHMENT_RESPONSE:
|
|
|
|
return "SMF_TIMER_PFCP_NO_ESTABLISHMENT_RESPONSE";
|
2020-04-26 19:36:05 +00:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2022-08-12 05:03:53 +00:00
|
|
|
ogs_error("Unknown Timer[%d]", timer_id);
|
2020-04-26 19:36:05 +00:00
|
|
|
return "UNKNOWN_TIMER";
|
|
|
|
}
|
|
|
|
|
|
|
|
static void timer_send_event(int timer_id, void *data)
|
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
smf_event_t *e = NULL;
|
|
|
|
ogs_assert(data);
|
|
|
|
|
2020-05-18 21:00:37 +00:00
|
|
|
switch (timer_id) {
|
|
|
|
case SMF_TIMER_PFCP_ASSOCIATION:
|
2020-07-27 01:02:40 +00:00
|
|
|
case SMF_TIMER_PFCP_NO_HEARTBEAT:
|
2020-05-18 21:00:37 +00:00
|
|
|
e = smf_event_new(SMF_EVT_N4_TIMER);
|
|
|
|
ogs_assert(e);
|
2022-08-12 05:03:53 +00:00
|
|
|
e->h.timer_id = timer_id;
|
2020-05-18 21:00:37 +00:00
|
|
|
e->pfcp_node = data;
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
ogs_fatal("Unknown timer id[%d]", timer_id);
|
|
|
|
ogs_assert_if_reached();
|
|
|
|
break;
|
|
|
|
}
|
2020-04-26 19:36:05 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
rv = ogs_queue_push(ogs_app()->queue, e);
|
2020-04-26 19:36:05 +00:00
|
|
|
if (rv != OGS_OK) {
|
2022-07-16 04:27:18 +00:00
|
|
|
ogs_error("ogs_queue_push() failed [%d] in %s",
|
2022-08-12 05:03:53 +00:00
|
|
|
(int)rv, smf_timer_get_name(timer_id));
|
|
|
|
ogs_event_free(e);
|
2020-04-26 19:36:05 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-05-18 21:00:37 +00:00
|
|
|
void smf_timer_pfcp_association(void *data)
|
|
|
|
{
|
|
|
|
timer_send_event(SMF_TIMER_PFCP_ASSOCIATION, data);
|
|
|
|
}
|
|
|
|
|
2020-07-27 01:02:40 +00:00
|
|
|
void smf_timer_pfcp_no_heartbeat(void *data)
|
2020-05-18 21:00:37 +00:00
|
|
|
{
|
2020-07-27 01:02:40 +00:00
|
|
|
timer_send_event(SMF_TIMER_PFCP_NO_HEARTBEAT, data);
|
2020-05-18 21:00:37 +00:00
|
|
|
}
|