mirror of
				https://github.com/open5gs/open5gs.git
				synced 2025-11-03 21:43:25 +00:00 
			
		
		
		
	o GTP-C Option (Default)
  - so_bindtodevice : NULL
  gtpc:
    addr: 127.0.0.7
    option:
      so_bindtodevice: vrf-blue
o GTP-U Option (Default)
  - so_bindtodevice : NULL
  gtpu:
    addr: 127.0.0.7
    option:
      so_bindtodevice: vrf-blue
o PFCP Option (Default)
  - so_bindtodevice : NULL
  pfcp:
    addr: 127.0.0.7
    option:
      so_bindtodevice: vrf-blue
o SBI Option (Default)
  - tcp_nodelay : true
  - so_linger.l_onoff : false
  sbi:
    addr: 127.0.0.10
    option:
      tcp_nodelay: false
      so_linger:
        l_onoff: true
        l_linger: 10
o NGAP Option (Default)
  - sctp_nodelay : true
  - so_linger.l_onoff : false
ngap:
  addr: 127.0.0.5
  option:
    stcp_nodelay: false
    so_linger:
      l_onoff: true
      l_linger: 10
o NGAP SCTP Option (Default)
  - spp_hbinterval : 5000 (5secs)
  - spp_sackdelay : 200 (200ms)
  - srto_initial : 3000 (3secs)
  - srto_min : 1000 (1sec)
  - srto_max : 5000 (5secs)
  - sinit_num_ostreams : 30
  - sinit_max_instreams : 65535
  - sinit_max_attempts : 4
  - sinit_max_init_timeo : 8000(8secs)
ngap:
  addr: 127.0.0.5
  option:
    sctp:
      spp_hbinterval : 5000
      spp_sackdelay : 200
      srto_initial : 3000
      srto_min : 1000
      srto_max : 5000
      sinit_num_ostreams : 30
      sinit_max_instreams : 65535
      sinit_max_attempts : 4
      sinit_max_init_timeo : 8000
		
	
		
			
				
	
	
		
			146 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			146 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
/*
 | 
						|
 * 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 "ogs-core.h"
 | 
						|
 | 
						|
#undef OGS_LOG_DOMAIN
 | 
						|
#define OGS_LOG_DOMAIN __ogs_sock_domain
 | 
						|
 | 
						|
ogs_sock_t *ogs_udp_server(
 | 
						|
        ogs_sockaddr_t *sa_list, ogs_sockopt_t *socket_option)
 | 
						|
{
 | 
						|
    char buf[OGS_ADDRSTRLEN];
 | 
						|
 | 
						|
    ogs_sock_t *new = NULL;
 | 
						|
    ogs_sockaddr_t *addr;
 | 
						|
    ogs_sockopt_t option;
 | 
						|
 | 
						|
    ogs_assert(sa_list);
 | 
						|
 | 
						|
    ogs_sockopt_init(&option);
 | 
						|
    if (socket_option)
 | 
						|
        memcpy(&option, socket_option, sizeof option);
 | 
						|
 | 
						|
    addr = sa_list;
 | 
						|
    while (addr) {
 | 
						|
        new = ogs_sock_socket(addr->ogs_sa_family, SOCK_DGRAM, IPPROTO_UDP);
 | 
						|
        if (!new) {
 | 
						|
            addr = addr->next;
 | 
						|
            continue;
 | 
						|
        }
 | 
						|
        if (ogs_sock_bind(new, addr) != OGS_OK) {
 | 
						|
            ogs_sock_destroy(new);
 | 
						|
            addr = addr->next;
 | 
						|
            continue;
 | 
						|
        }
 | 
						|
        ogs_debug("udp_server() [%s]:%d", OGS_ADDR(addr, buf), OGS_PORT(addr));
 | 
						|
        if (option.so_bindtodevice) {
 | 
						|
            if (ogs_bind_to_device(new->fd, option.so_bindtodevice) != OGS_OK) {
 | 
						|
                ogs_sock_destroy(new);
 | 
						|
                addr = addr->next;
 | 
						|
                continue;
 | 
						|
            }
 | 
						|
            ogs_info("udp_server() [%s]:%d bound to device `%s`",
 | 
						|
                    OGS_ADDR(addr, buf), OGS_PORT(addr),
 | 
						|
                    option.so_bindtodevice);
 | 
						|
        }
 | 
						|
        break;
 | 
						|
    }
 | 
						|
 | 
						|
    if (addr == NULL) {
 | 
						|
        ogs_log_message(OGS_LOG_ERROR, ogs_socket_errno,
 | 
						|
                "udp_server() [%s]:%d failed",
 | 
						|
                OGS_ADDR(sa_list, buf), OGS_PORT(sa_list));
 | 
						|
        return NULL;
 | 
						|
    }
 | 
						|
 | 
						|
    return new;
 | 
						|
}
 | 
						|
 | 
						|
ogs_sock_t *ogs_udp_client(
 | 
						|
        ogs_sockaddr_t *sa_list, ogs_sockopt_t *socket_option)
 | 
						|
{
 | 
						|
    char buf[OGS_ADDRSTRLEN];
 | 
						|
 | 
						|
    ogs_sock_t *new = NULL;
 | 
						|
    ogs_sockaddr_t *addr;
 | 
						|
 | 
						|
    ogs_sockopt_t option;
 | 
						|
 | 
						|
    ogs_assert(sa_list);
 | 
						|
 | 
						|
    ogs_sockopt_init(&option);
 | 
						|
    if (socket_option)
 | 
						|
        memcpy(&option, socket_option, sizeof option);
 | 
						|
 | 
						|
    addr = sa_list;
 | 
						|
    while (addr) {
 | 
						|
        new = ogs_sock_socket(addr->ogs_sa_family, SOCK_DGRAM, IPPROTO_UDP);
 | 
						|
        if (new) {
 | 
						|
            if (ogs_sock_connect(new, addr) == OGS_OK) {
 | 
						|
                ogs_debug("udp_client() [%s]:%d",
 | 
						|
                        OGS_ADDR(addr, buf), OGS_PORT(addr));
 | 
						|
                break;
 | 
						|
            }
 | 
						|
 | 
						|
            ogs_sock_destroy(new);
 | 
						|
        }
 | 
						|
 | 
						|
        addr = addr->next;
 | 
						|
    }
 | 
						|
 | 
						|
    if (addr == NULL) {
 | 
						|
        ogs_log_message(OGS_LOG_ERROR, ogs_socket_errno,
 | 
						|
                "udp_client() [%s]:%d failed",
 | 
						|
                OGS_ADDR(sa_list, buf), OGS_PORT(sa_list));
 | 
						|
        return NULL;;
 | 
						|
    }
 | 
						|
 | 
						|
    return new;
 | 
						|
}
 | 
						|
 | 
						|
int ogs_udp_connect(ogs_sock_t *sock, ogs_sockaddr_t *sa_list)
 | 
						|
{
 | 
						|
    ogs_sockaddr_t *addr;
 | 
						|
    char buf[OGS_ADDRSTRLEN];
 | 
						|
 | 
						|
    ogs_assert(sock);
 | 
						|
    ogs_assert(sa_list);
 | 
						|
 | 
						|
    addr = sa_list;
 | 
						|
    while (addr) {
 | 
						|
        if (ogs_sock_connect(sock, addr) == OGS_OK) {
 | 
						|
            ogs_debug("udp_connect() [%s]:%d",
 | 
						|
                    OGS_ADDR(addr, buf), OGS_PORT(addr));
 | 
						|
            break;
 | 
						|
        }
 | 
						|
 | 
						|
        addr = addr->next;
 | 
						|
    }
 | 
						|
 | 
						|
    if (addr == NULL) {
 | 
						|
        ogs_log_message(OGS_LOG_ERROR, ogs_socket_errno,
 | 
						|
                "udp_connect() [%s]:%d failed",
 | 
						|
                OGS_ADDR(sa_list, buf), OGS_PORT(sa_list));
 | 
						|
        return OGS_ERROR;
 | 
						|
    }
 | 
						|
 | 
						|
    return OGS_OK;
 | 
						|
}
 |