2019-06-07 02:56:37 +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-09-13 12:07:47 +00:00
|
|
|
#include "ogs-app.h"
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
static ogs_app_context_t self;
|
2019-06-07 23:44:22 +00:00
|
|
|
|
2019-09-13 12:07:47 +00:00
|
|
|
static int initialized = 0;
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
int ogs_app_context_init(void)
|
2019-04-27 14:54:30 +00:00
|
|
|
{
|
2019-09-13 12:07:47 +00:00
|
|
|
ogs_assert(initialized == 0);
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
memset(&self, 0, sizeof(ogs_app_context_t));
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2019-09-13 12:07:47 +00:00
|
|
|
initialized = 1;
|
2019-04-27 14:54:30 +00:00
|
|
|
|
|
|
|
return OGS_OK;
|
|
|
|
}
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
void ogs_app_context_final(void)
|
2019-04-27 14:54:30 +00:00
|
|
|
{
|
2019-09-13 12:07:47 +00:00
|
|
|
ogs_assert(initialized == 1);
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2019-09-13 12:07:47 +00:00
|
|
|
if (self.document) {
|
|
|
|
yaml_document_delete(self.document);
|
|
|
|
free(self.document);
|
2019-04-27 14:54:30 +00:00
|
|
|
}
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
if (self.pollset)
|
|
|
|
ogs_pollset_destroy(self.pollset);
|
|
|
|
if (self.timer_mgr)
|
|
|
|
ogs_timer_mgr_destroy(self.timer_mgr);
|
|
|
|
if (self.queue)
|
|
|
|
ogs_queue_destroy(self.queue);
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
initialized = 0;
|
2019-04-27 14:54:30 +00:00
|
|
|
}
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
ogs_app_context_t *ogs_app()
|
2019-04-27 14:54:30 +00:00
|
|
|
{
|
|
|
|
return &self;
|
|
|
|
}
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
static void recalculate_pool_size(void)
|
2019-04-27 14:54:30 +00:00
|
|
|
{
|
2020-08-26 03:05:01 +00:00
|
|
|
#define MAX_NUM_OF_BEARER 4 /* Num of Bearer per Session */
|
|
|
|
#define MAX_NUM_OF_TUNNEL 3 /* Num of Tunnel per Bearer */
|
|
|
|
#define MAX_NUM_OF_PF 16 /* Num of PacketFilter per Bearer */
|
|
|
|
self.pool.sess = self.max.ue * OGS_MAX_NUM_OF_SESS;
|
|
|
|
self.pool.bearer = self.pool.sess * MAX_NUM_OF_BEARER;
|
|
|
|
self.pool.tunnel = self.pool.bearer * MAX_NUM_OF_TUNNEL;
|
|
|
|
self.pool.pf = self.pool.bearer * MAX_NUM_OF_PF;
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
#define MAX_NUM_OF_TIMER 16
|
|
|
|
self.pool.timer = self.max.ue * MAX_NUM_OF_TIMER;
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
self.pool.nf = self.max.gnb;
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
#define MAX_NUM_OF_SOCKET 4 /* Num of socket per NF */
|
|
|
|
self.pool.socket = self.pool.nf * MAX_NUM_OF_SOCKET;
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
#define MAX_GTP_XACT_POOL 512
|
|
|
|
self.pool.gtp_xact = MAX_GTP_XACT_POOL;
|
|
|
|
self.pool.gtp_node = self.pool.nf;
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
#define MAX_PFCP_XACT_POOL 512
|
|
|
|
self.pool.pfcp_xact = MAX_PFCP_XACT_POOL;
|
|
|
|
self.pool.pfcp_node = self.pool.nf;
|
2019-04-27 14:54:30 +00:00
|
|
|
|
2020-06-04 18:12:05 +00:00
|
|
|
#define MAX_NUM_OF_NF_SERVICE 16 /* Num of NF Service per NF Instance */
|
|
|
|
#define MAX_NUM_OF_SBI_MESSAGE 8 /* Num of HTTP(s) Request/Response per NF */
|
|
|
|
#define MAX_NUM_OF_NF_SUBSCRIPTION 4 /* Num of Subscription per NF */
|
2020-08-26 03:05:01 +00:00
|
|
|
self.pool.nf_service = self.pool.nf * MAX_NUM_OF_NF_SERVICE;
|
|
|
|
self.pool.sbi_message = self.pool.nf * MAX_NUM_OF_SBI_MESSAGE;
|
|
|
|
self.pool.nf_subscription = self.pool.nf * MAX_NUM_OF_NF_SUBSCRIPTION;
|
2019-09-13 12:07:47 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
#define MAX_EVENT_POOL 32
|
|
|
|
self.pool.event = MAX_EVENT_POOL;
|
|
|
|
|
|
|
|
#define MAX_CSMAP_POOL 128
|
|
|
|
self.pool.csmap = MAX_CSMAP_POOL; /* Num of TAI-LAI Mapping Table */
|
2019-06-07 23:44:22 +00:00
|
|
|
}
|
|
|
|
|
2020-07-27 01:02:40 +00:00
|
|
|
static void regenerate_all_timer_duration(void)
|
|
|
|
{
|
|
|
|
ogs_assert(self.time.message.duration);
|
|
|
|
|
|
|
|
self.time.message.sbi.client_wait_duration = self.time.message.duration;
|
2020-07-27 04:20:01 +00:00
|
|
|
self.time.message.sbi.connection_deadline =
|
2020-07-27 01:02:40 +00:00
|
|
|
self.time.message.sbi.client_wait_duration + ogs_time_from_sec(1);
|
|
|
|
self.time.message.sbi.nf_register_interval =
|
|
|
|
ogs_max(ogs_time_from_sec(3),
|
|
|
|
self.time.message.sbi.client_wait_duration + ogs_time_from_sec(1));
|
|
|
|
self.time.message.sbi.nf_register_interval_in_exception =
|
|
|
|
ogs_time_from_msec(300);
|
|
|
|
|
|
|
|
#define PFCP_N1_RESPONSE_RETRY_COUNT 3
|
|
|
|
self.time.message.pfcp.n1_response_rcount = PFCP_N1_RESPONSE_RETRY_COUNT;
|
|
|
|
self.time.message.pfcp.t1_response_duration =
|
|
|
|
(self.time.message.duration /
|
|
|
|
(self.time.message.pfcp.n1_response_rcount + 1));
|
|
|
|
ogs_assert(self.time.message.pfcp.t1_response_duration);
|
|
|
|
|
|
|
|
#define PFCP_N1_HOLDING_RETRY_COUNT 1
|
|
|
|
self.time.message.pfcp.n1_holding_rcount = PFCP_N1_HOLDING_RETRY_COUNT;
|
|
|
|
self.time.message.pfcp.t1_holding_duration =
|
|
|
|
self.time.message.pfcp.n1_response_rcount *
|
|
|
|
self.time.message.pfcp.t1_response_duration;
|
|
|
|
ogs_assert(self.time.message.pfcp.t1_holding_duration);
|
|
|
|
|
|
|
|
self.time.message.pfcp.association_interval =
|
|
|
|
ogs_max(ogs_time_from_sec(3),
|
|
|
|
self.time.message.sbi.client_wait_duration + ogs_time_from_sec(1));
|
|
|
|
|
|
|
|
self.time.message.pfcp.no_heartbeat_duration =
|
|
|
|
ogs_max(ogs_time_from_sec(10),
|
|
|
|
self.time.message.sbi.client_wait_duration + ogs_time_from_sec(1));
|
|
|
|
|
|
|
|
#define GTP_N3_RESPONSE_RETRY_COUNT 3
|
|
|
|
self.time.message.gtp.n3_response_rcount = GTP_N3_RESPONSE_RETRY_COUNT;
|
|
|
|
self.time.message.gtp.t3_response_duration =
|
|
|
|
(self.time.message.duration /
|
|
|
|
(self.time.message.gtp.n3_response_rcount + 1));
|
|
|
|
ogs_assert(self.time.message.gtp.t3_response_duration);
|
|
|
|
|
|
|
|
#define GTP_N3_HOLDING_RETRY_COUNT 1
|
|
|
|
self.time.message.gtp.n3_holding_rcount = GTP_N3_HOLDING_RETRY_COUNT;
|
|
|
|
self.time.message.gtp.t3_holding_duration =
|
|
|
|
self.time.message.gtp.n3_response_rcount *
|
|
|
|
self.time.message.gtp.t3_response_duration;
|
|
|
|
ogs_assert(self.time.message.gtp.t3_holding_duration);
|
|
|
|
|
|
|
|
#if 0
|
|
|
|
ogs_trace("%lld, %lld, %lld, %d, %lld, %d %lld, %d, %lld, %d, %lld",
|
|
|
|
(long long)self.time.message.duration,
|
|
|
|
(long long)self.time.message.sbi.client_wait_duration,
|
2020-07-27 04:20:01 +00:00
|
|
|
(long long)self.time.message.sbi.connection_deadline,
|
2020-07-27 01:02:40 +00:00
|
|
|
self.time.message.pfcp.n1_response_rcount,
|
|
|
|
(long long)self.time.message.pfcp.t1_response_duration,
|
|
|
|
self.time.message.pfcp.n1_holding_rcount,
|
|
|
|
(long long)self.time.message.pfcp.t1_holding_duration,
|
|
|
|
self.time.message.gtp.n3_response_rcount,
|
|
|
|
(long long)self.time.message.gtp.t3_response_duration,
|
|
|
|
self.time.message.gtp.n3_holding_rcount,
|
|
|
|
(long long)self.time.message.gtp.t3_holding_duration);
|
|
|
|
ogs_trace("%lld, %lld, %lld",
|
|
|
|
(long long)self.time.message.sbi.nf_register_interval,
|
|
|
|
(long long)self.time.message.pfcp.association_interval,
|
|
|
|
(long long)self.time.message.pfcp.no_heartbeat_duration);
|
|
|
|
#endif
|
|
|
|
}
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
static int app_context_prepare(void)
|
2019-04-27 14:54:30 +00:00
|
|
|
{
|
2019-06-07 02:56:37 +00:00
|
|
|
#define USRSCTP_LOCAL_UDP_PORT 9899
|
2019-09-13 12:07:47 +00:00
|
|
|
self.usrsctp.udp_port = USRSCTP_LOCAL_UDP_PORT;
|
2019-06-07 02:56:37 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
#define MAX_NUM_OF_UE 4096 /* Num of UE per AMF/MME */
|
|
|
|
#define MAX_NUM_OF_GNB 32 /* Num of gNB per AMF/MME */
|
2020-05-25 16:15:22 +00:00
|
|
|
|
|
|
|
self.max.gnb = MAX_NUM_OF_GNB;
|
2019-09-13 12:07:47 +00:00
|
|
|
self.max.ue = MAX_NUM_OF_UE;
|
2019-06-07 06:19:09 +00:00
|
|
|
|
2019-06-07 23:44:22 +00:00
|
|
|
#define MAX_NUM_OF_PACKET_POOL 65536
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.packet = MAX_NUM_OF_PACKET_POOL;
|
2019-08-09 14:28:58 +00:00
|
|
|
|
2019-09-13 12:07:47 +00:00
|
|
|
ogs_pkbuf_default_init(&self.pool.defconfig);
|
2019-06-07 23:44:22 +00:00
|
|
|
|
2019-09-13 12:07:47 +00:00
|
|
|
recalculate_pool_size();
|
2019-06-07 02:56:37 +00:00
|
|
|
|
2020-07-27 01:02:40 +00:00
|
|
|
/* 10 second */
|
|
|
|
self.time.nf_instance.heartbeat_interval = 10;
|
|
|
|
self.time.nf_instance.no_heartbeat_margin = 1;
|
|
|
|
|
|
|
|
/* 3600 seconds = 1 hour */
|
|
|
|
self.time.nf_instance.validity_duration = 3600;
|
|
|
|
|
|
|
|
/* 86400 seconds = 1 day */
|
|
|
|
self.time.subscription.validity_duration = 86400;
|
|
|
|
|
2020-07-27 04:20:01 +00:00
|
|
|
/* Message Wait Duration : 2 seconds */
|
|
|
|
self.time.message.duration = ogs_time_from_sec(2);
|
2020-07-27 01:02:40 +00:00
|
|
|
|
|
|
|
regenerate_all_timer_duration();
|
2020-05-18 21:00:37 +00:00
|
|
|
|
2019-04-27 14:54:30 +00:00
|
|
|
return OGS_OK;
|
|
|
|
}
|
2020-07-27 01:02:40 +00:00
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
static int app_context_validation(void)
|
2019-04-27 14:54:30 +00:00
|
|
|
{
|
2019-09-13 12:07:47 +00:00
|
|
|
if (self.parameter.no_ipv4 == 1 &&
|
|
|
|
self.parameter.no_ipv6 == 1) {
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_error("Both `no_ipv4` and `no_ipv6` set to `true` in `%s`",
|
2019-09-13 12:07:47 +00:00
|
|
|
self.file);
|
2019-04-27 14:54:30 +00:00
|
|
|
return OGS_ERROR;
|
|
|
|
}
|
|
|
|
|
2020-07-27 01:02:40 +00:00
|
|
|
if (self.time.nf_instance.validity_duration == 0) {
|
2020-05-18 21:00:37 +00:00
|
|
|
ogs_error("NF Instance validity-time should not 0");
|
|
|
|
ogs_error("time:");
|
|
|
|
ogs_error(" nf_instance:");
|
|
|
|
ogs_error(" validity: 0");
|
|
|
|
|
|
|
|
return OGS_ERROR;
|
|
|
|
}
|
|
|
|
|
2019-04-27 14:54:30 +00:00
|
|
|
return OGS_OK;
|
|
|
|
}
|
2020-08-26 03:05:01 +00:00
|
|
|
|
|
|
|
int ogs_app_context_parse_config(void)
|
2019-04-27 14:54:30 +00:00
|
|
|
{
|
|
|
|
int rv;
|
|
|
|
yaml_document_t *document = NULL;
|
|
|
|
ogs_yaml_iter_t root_iter;
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
document = self.document;
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_assert(document);
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
rv = app_context_prepare();
|
2019-04-27 14:54:30 +00:00
|
|
|
if (rv != OGS_OK) return rv;
|
|
|
|
|
|
|
|
ogs_yaml_iter_init(&root_iter, document);
|
2019-05-31 02:20:30 +00:00
|
|
|
while (ogs_yaml_iter_next(&root_iter)) {
|
2019-04-27 14:54:30 +00:00
|
|
|
const char *root_key = ogs_yaml_iter_key(&root_iter);
|
|
|
|
ogs_assert(root_key);
|
2019-05-31 02:20:30 +00:00
|
|
|
if (!strcmp(root_key, "db_uri")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.db_uri = ogs_yaml_iter_value(&root_iter);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(root_key, "logger")) {
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_t logger_iter;
|
|
|
|
ogs_yaml_iter_recurse(&root_iter, &logger_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
while (ogs_yaml_iter_next(&logger_iter)) {
|
2019-04-27 14:54:30 +00:00
|
|
|
const char *logger_key = ogs_yaml_iter_key(&logger_iter);
|
|
|
|
ogs_assert(logger_key);
|
2019-05-31 02:20:30 +00:00
|
|
|
if (!strcmp(logger_key, "file")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.logger.file = ogs_yaml_iter_value(&logger_iter);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(logger_key, "level")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.logger.level =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_value(&logger_iter);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(logger_key, "domain")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.logger.domain =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_value(&logger_iter);
|
|
|
|
}
|
|
|
|
}
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(root_key, "parameter")) {
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_t parameter_iter;
|
|
|
|
ogs_yaml_iter_recurse(&root_iter, ¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
while (ogs_yaml_iter_next(¶meter_iter)) {
|
2019-04-27 14:54:30 +00:00
|
|
|
const char *parameter_key = ogs_yaml_iter_key(¶meter_iter);
|
|
|
|
ogs_assert(parameter_key);
|
2019-05-31 07:33:09 +00:00
|
|
|
if (!strcmp(parameter_key, "no_hss")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.no_hss =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2020-08-13 00:31:22 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_mme")) {
|
|
|
|
self.parameter.no_mme =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
|
|
|
} else if (!strcmp(parameter_key, "no_sgwu")) {
|
|
|
|
self.parameter.no_sgwu =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
|
|
|
} else if (!strcmp(parameter_key, "no_sgwc")) {
|
|
|
|
self.parameter.no_sgwc =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_sgw")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.no_sgw =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_pgw")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.no_pgw =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_pcrf")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.no_pcrf =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2020-07-04 03:14:48 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_nrf")) {
|
|
|
|
self.parameter.no_nrf =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
|
|
|
} else if (!strcmp(parameter_key, "no_amf")) {
|
|
|
|
self.parameter.no_amf =
|
2020-06-04 18:12:05 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
|
|
|
} else if (!strcmp(parameter_key, "no_smf")) {
|
|
|
|
self.parameter.no_smf =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2020-07-04 03:14:48 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_upf")) {
|
|
|
|
self.parameter.no_upf =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2020-06-04 18:12:05 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_ausf")) {
|
|
|
|
self.parameter.no_ausf =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
|
|
|
} else if (!strcmp(parameter_key, "no_udm")) {
|
|
|
|
self.parameter.no_udm =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
|
|
|
} else if (!strcmp(parameter_key, "no_udr")) {
|
|
|
|
self.parameter.no_udr =
|
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_ipv4")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.no_ipv4 =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_ipv6")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.no_ipv6 =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else if (!strcmp(parameter_key, "prefer_ipv4")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.prefer_ipv4 =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else if (!strcmp(parameter_key, "multicast")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.multicast =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else if (!strcmp(parameter_key, "no_slaac")) {
|
2019-09-13 12:07:47 +00:00
|
|
|
self.parameter.no_slaac =
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_yaml_iter_bool(¶meter_iter);
|
2019-05-31 02:20:30 +00:00
|
|
|
} else
|
2019-04-27 14:54:30 +00:00
|
|
|
ogs_warn("unknown key `%s`", parameter_key);
|
|
|
|
}
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(root_key, "sctp")) {
|
|
|
|
ogs_yaml_iter_t sctp_iter;
|
|
|
|
ogs_yaml_iter_recurse(&root_iter, &sctp_iter);
|
|
|
|
while (ogs_yaml_iter_next(&sctp_iter)) {
|
|
|
|
const char *sctp_key = ogs_yaml_iter_key(&sctp_iter);
|
|
|
|
ogs_assert(sctp_key);
|
|
|
|
if (!strcmp(sctp_key, "heartbit_interval")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
2019-09-13 12:07:47 +00:00
|
|
|
if (v) self.sockopt.sctp.heartbit_interval = atoi(v);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(sctp_key, "rto_initial")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
2019-09-13 12:07:47 +00:00
|
|
|
if (v) self.sockopt.sctp.rto_initial = atoi(v);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(sctp_key, "rto_min")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
2019-09-13 12:07:47 +00:00
|
|
|
if (v) self.sockopt.sctp.rto_min = atoi(v);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(sctp_key, "rto_max")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
2019-09-13 12:07:47 +00:00
|
|
|
if (v) self.sockopt.sctp.rto_max = atoi(v);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(sctp_key, "max_num_of_ostreams")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.sockopt.sctp.max_num_of_ostreams = atoi(v);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(sctp_key, "max_num_of_istreams")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.sockopt.sctp.max_num_of_istreams = atoi(v);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(sctp_key, "max_attempts")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
2019-09-13 12:07:47 +00:00
|
|
|
if (v) self.sockopt.sctp.max_attempts = atoi(v);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else if (!strcmp(sctp_key, "max_initial_timeout")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.sockopt.sctp.max_initial_timeout = atoi(v);
|
2019-06-01 12:30:13 +00:00
|
|
|
} else if (!strcmp(sctp_key, "usrsctp_udp_port")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sctp_iter);
|
2019-09-13 12:07:47 +00:00
|
|
|
if (v) self.usrsctp.udp_port = atoi(v);
|
2019-05-31 07:33:09 +00:00
|
|
|
} else
|
|
|
|
ogs_warn("unknown key `%s`", sctp_key);
|
|
|
|
}
|
2019-06-07 02:56:37 +00:00
|
|
|
} else if (!strcmp(root_key, "max")) {
|
|
|
|
ogs_yaml_iter_t max_iter;
|
|
|
|
ogs_yaml_iter_recurse(&root_iter, &max_iter);
|
|
|
|
while (ogs_yaml_iter_next(&max_iter)) {
|
|
|
|
const char *max_key = ogs_yaml_iter_key(&max_iter);
|
|
|
|
ogs_assert(max_key);
|
|
|
|
if (!strcmp(max_key, "ue")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&max_iter);
|
2019-09-13 12:07:47 +00:00
|
|
|
if (v) self.max.ue = atoi(v);
|
2020-05-25 16:15:22 +00:00
|
|
|
} else if (!strcmp(max_key, "gnb") ||
|
|
|
|
!strcmp(max_key, "enb")) {
|
2019-06-07 02:56:37 +00:00
|
|
|
const char *v = ogs_yaml_iter_value(&max_iter);
|
2020-05-25 16:15:22 +00:00
|
|
|
if (v) self.max.gnb = atoi(v);
|
2019-06-07 02:56:37 +00:00
|
|
|
} else
|
|
|
|
ogs_warn("unknown key `%s`", max_key);
|
|
|
|
}
|
2019-06-07 23:44:22 +00:00
|
|
|
|
2019-09-13 12:07:47 +00:00
|
|
|
recalculate_pool_size();
|
2019-08-09 14:28:58 +00:00
|
|
|
} else if (!strcmp(root_key, "pool")) {
|
|
|
|
ogs_yaml_iter_t pool_iter;
|
|
|
|
ogs_yaml_iter_recurse(&root_iter, &pool_iter);
|
|
|
|
while (ogs_yaml_iter_next(&pool_iter)) {
|
|
|
|
const char *pool_key = ogs_yaml_iter_key(&pool_iter);
|
|
|
|
ogs_assert(pool_key);
|
|
|
|
if (!strcmp(pool_key, "128")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&pool_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.defconfig.cluster_128_pool = atoi(v);
|
2019-08-09 14:28:58 +00:00
|
|
|
} else if (!strcmp(pool_key, "256")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&pool_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.defconfig.cluster_256_pool = atoi(v);
|
2019-08-09 14:28:58 +00:00
|
|
|
} else if (!strcmp(pool_key, "512")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&pool_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.defconfig.cluster_512_pool = atoi(v);
|
2019-08-09 14:28:58 +00:00
|
|
|
} else if (!strcmp(pool_key, "1024")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&pool_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.defconfig.cluster_1024_pool = atoi(v);
|
2019-08-09 14:28:58 +00:00
|
|
|
} else if (!strcmp(pool_key, "2048")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&pool_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.defconfig.cluster_2048_pool = atoi(v);
|
2019-08-09 14:28:58 +00:00
|
|
|
} else if (!strcmp(pool_key, "8192")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&pool_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.defconfig.cluster_8192_pool = atoi(v);
|
2019-08-09 14:28:58 +00:00
|
|
|
} else if (!strcmp(pool_key, "big")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&pool_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.defconfig.cluster_big_pool = atoi(v);
|
2019-08-09 14:28:58 +00:00
|
|
|
} else if (!strcmp(pool_key, "packet")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&pool_iter);
|
|
|
|
if (v)
|
2019-09-13 12:07:47 +00:00
|
|
|
self.pool.packet = atoi(v);
|
2019-08-09 14:28:58 +00:00
|
|
|
} else
|
|
|
|
ogs_warn("unknown key `%s`", pool_key);
|
|
|
|
}
|
2020-05-18 21:00:37 +00:00
|
|
|
} else if (!strcmp(root_key, "time")) {
|
|
|
|
ogs_yaml_iter_t time_iter;
|
|
|
|
ogs_yaml_iter_recurse(&root_iter, &time_iter);
|
|
|
|
while (ogs_yaml_iter_next(&time_iter)) {
|
|
|
|
const char *time_key = ogs_yaml_iter_key(&time_iter);
|
|
|
|
ogs_assert(time_key);
|
|
|
|
if (!strcmp(time_key, "nf_instance")) {
|
|
|
|
ogs_yaml_iter_t sbi_iter;
|
|
|
|
ogs_yaml_iter_recurse(&time_iter, &sbi_iter);
|
|
|
|
|
|
|
|
while (ogs_yaml_iter_next(&sbi_iter)) {
|
|
|
|
const char *sbi_key =
|
|
|
|
ogs_yaml_iter_key(&sbi_iter);
|
|
|
|
ogs_assert(sbi_key);
|
|
|
|
|
|
|
|
if (!strcmp(sbi_key, "heartbeat")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sbi_iter);
|
2020-07-27 01:02:40 +00:00
|
|
|
if (v) self.time.nf_instance.heartbeat_interval =
|
|
|
|
atoi(v);
|
2020-05-18 21:00:37 +00:00
|
|
|
} else if (!strcmp(sbi_key, "validity")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sbi_iter);
|
2020-07-27 01:02:40 +00:00
|
|
|
if (v) self.time.nf_instance.validity_duration =
|
|
|
|
atoi(v);
|
2020-05-18 21:00:37 +00:00
|
|
|
} else
|
|
|
|
ogs_warn("unknown key `%s`", sbi_key);
|
|
|
|
}
|
|
|
|
} else if (!strcmp(time_key, "subscription")) {
|
|
|
|
ogs_yaml_iter_t sbi_iter;
|
|
|
|
ogs_yaml_iter_recurse(&time_iter, &sbi_iter);
|
|
|
|
|
|
|
|
while (ogs_yaml_iter_next(&sbi_iter)) {
|
|
|
|
const char *sbi_key =
|
|
|
|
ogs_yaml_iter_key(&sbi_iter);
|
|
|
|
ogs_assert(sbi_key);
|
|
|
|
|
|
|
|
if (!strcmp(sbi_key, "validity")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&sbi_iter);
|
2020-07-27 01:02:40 +00:00
|
|
|
if (v) self.time.subscription.validity_duration =
|
|
|
|
atoi(v);
|
2020-05-18 21:00:37 +00:00
|
|
|
} else
|
|
|
|
ogs_warn("unknown key `%s`", sbi_key);
|
|
|
|
}
|
2020-07-27 01:02:40 +00:00
|
|
|
} else if (!strcmp(time_key, "message")) {
|
|
|
|
ogs_yaml_iter_t msg_iter;
|
|
|
|
ogs_yaml_iter_recurse(&time_iter, &msg_iter);
|
|
|
|
|
|
|
|
while (ogs_yaml_iter_next(&msg_iter)) {
|
|
|
|
const char *msg_key =
|
|
|
|
ogs_yaml_iter_key(&msg_iter);
|
|
|
|
ogs_assert(msg_key);
|
|
|
|
|
|
|
|
if (!strcmp(msg_key, "duration")) {
|
|
|
|
const char *v = ogs_yaml_iter_value(&msg_iter);
|
|
|
|
if (v) {
|
|
|
|
self.time.message.duration =
|
|
|
|
ogs_time_from_msec(atoll(v));
|
|
|
|
regenerate_all_timer_duration();
|
|
|
|
}
|
|
|
|
} else
|
|
|
|
ogs_warn("unknown key `%s`", msg_key);
|
|
|
|
}
|
2020-05-18 21:00:37 +00:00
|
|
|
} else
|
|
|
|
ogs_warn("unknown key `%s`", time_key);
|
|
|
|
}
|
2019-04-27 14:54:30 +00:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2020-08-26 03:05:01 +00:00
|
|
|
rv = app_context_validation();
|
2019-04-27 14:54:30 +00:00
|
|
|
if (rv != OGS_OK) return rv;
|
|
|
|
|
|
|
|
return OGS_OK;
|
|
|
|
}
|