blob: 9c0dc8cd8fd0c5602466f74f36396b0cc7f870aa [file] [log] [blame]
Philipp Maier87bd9be2017-08-22 16:35:41 +02001/* Endpoint types */
2
3/*
4 * (C) 2017 by sysmocom s.f.m.c. GmbH <info@sysmocom.de>
5 * All Rights Reserved
6 *
7 * Author: Philipp Maier
8 *
9 * This program is free software; you can redistribute it and/or modify
10 * it under the terms of the GNU Affero General Public License as published by
11 * the Free Software Foundation; either version 3 of the License, or
12 * (at your option) any later version.
13 *
14 * This program is distributed in the hope that it will be useful,
15 * but WITHOUT ANY WARRANTY; without even the implied warranty of
16 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
17 * GNU Affero General Public License for more details.
18 *
19 * You should have received a copy of the GNU Affero General Public License
20 * along with this program. If not, see <http://www.gnu.org/licenses/>.
21 *
22 */
23
24#pragma once
25
Neels Hofmeyrfbe05d82018-09-30 05:01:20 +020026#include <osmocom/core/msgb.h>
27
Philipp Maier87bd9be2017-08-22 16:35:41 +020028struct sockaddr_in;
29struct mgcp_conn;
Neels Hofmeyrfbe05d82018-09-30 05:01:20 +020030struct mgcp_conn_rtp;
Philipp Maieredc00f42018-01-24 11:58:56 +010031struct mgcp_endpoint;
Philipp Maier87bd9be2017-08-22 16:35:41 +020032
Neels Hofmeyrfbe05d82018-09-30 05:01:20 +020033struct osmo_rtp_msg_ctx {
34 int proto;
35 struct mgcp_conn_rtp *conn_src;
36 struct sockaddr_in *from_addr;
37};
38
39#define OSMO_RTP_MSG_CTX(MSGB) (*(struct osmo_rtp_msg_ctx**)&((MSGB)->dst))
40
41#define LOG_ENDP(endp, level, fmt, args...) \
42 LOGP(DRTP, level, "%x@ " fmt, ENDPOINT_NUMBER(endp), ## args)
43
44/* Callback type for RTP dispatcher functions (e.g mgcp_dispatch_rtp_bridge_cb, see below).
45 * The OSMO_RTP_MSG_CTX() should be set appropriately on the msg. */
46typedef int (*mgcp_dispatch_rtp_cb) (struct msgb *msg);
Philipp Maier87bd9be2017-08-22 16:35:41 +020047
Philipp Maierdf5d2192018-01-24 11:39:32 +010048/* Callback type for endpoint specific cleanup actions. This function
49 * is automatically executed when a connection is freed (see mgcp_conn_free()
50 * in mgcp_conn.c). Depending on the type of the endpoint there may be endpoint
51 * specific things to take care of once a connection has been removed. */
52typedef void (*mgcp_cleanup_cp) (struct mgcp_endpoint *endp,
53 struct mgcp_conn *conn);
54
Philipp Maier87bd9be2017-08-22 16:35:41 +020055/*! MGCP endpoint properties */
56struct mgcp_endpoint_type {
Neels Hofmeyr8838c622018-06-26 00:05:53 +020057 /*! maximum number of connections */
Philipp Maier87bd9be2017-08-22 16:35:41 +020058 int max_conns;
59
Neels Hofmeyr8838c622018-06-26 00:05:53 +020060 /*! callback that defines how to dispatch incoming RTP data */
Philipp Maier87bd9be2017-08-22 16:35:41 +020061 mgcp_dispatch_rtp_cb dispatch_rtp_cb;
Philipp Maierdf5d2192018-01-24 11:39:32 +010062
Neels Hofmeyr8838c622018-06-26 00:05:53 +020063 /*! callback that implements endpoint specific cleanup actions */
Philipp Maierdf5d2192018-01-24 11:39:32 +010064 mgcp_cleanup_cp cleanup_cb;
Philipp Maier87bd9be2017-08-22 16:35:41 +020065};
66
67/*! MGCP endpoint typeset */
68struct mgcp_endpoint_typeset {
69 struct mgcp_endpoint_type rtp;
70};
71
72/*! static MGCP endpoint typeset (pre-initalized, read-only) */
73extern const struct mgcp_endpoint_typeset ep_typeset;
Philipp Maieredc00f42018-01-24 11:58:56 +010074
Philipp Maierfdd603c2018-02-01 13:31:15 +010075/*! MGCP endpoint model */
76struct mgcp_endpoint {
77
Neels Hofmeyr8838c622018-06-26 00:05:53 +020078 /*! Call identifier string (as supplied by the call agant) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010079 char *callid;
80
Neels Hofmeyr8838c622018-06-26 00:05:53 +020081 /*! Local connection options (see mgcp_internal.h) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010082 struct mgcp_lco local_options;
83
Neels Hofmeyrf0504e82018-08-28 21:12:59 +020084 /*! List of struct mgcp_conn, of the connections active on this endpoint */
Philipp Maierfdd603c2018-02-01 13:31:15 +010085 struct llist_head conns;
86
Neels Hofmeyr8838c622018-06-26 00:05:53 +020087 /*! Backpointer to the MGW configuration */
Philipp Maierfdd603c2018-02-01 13:31:15 +010088 struct mgcp_config *cfg;
89
Neels Hofmeyr8838c622018-06-26 00:05:53 +020090 /*! Backpointer to the Trunk specific configuration */
Philipp Maierfdd603c2018-02-01 13:31:15 +010091 struct mgcp_trunk_config *tcfg;
92
Neels Hofmeyr8838c622018-06-26 00:05:53 +020093 /*! Endpoint properties (see above) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010094 const struct mgcp_endpoint_type *type;
95
Neels Hofmeyr8838c622018-06-26 00:05:53 +020096 /*! Last MGCP transmission (in case re-transmission is required) */
Philipp Maierfdd603c2018-02-01 13:31:15 +010097 char *last_trans;
98
Neels Hofmeyr8838c622018-06-26 00:05:53 +020099 /*! Last MGCP response (in case re-transmission is required) */
Philipp Maierfdd603c2018-02-01 13:31:15 +0100100 char *last_response;
101
Neels Hofmeyr8838c622018-06-26 00:05:53 +0200102 /*! Memorize if this endpoint was choosen by the MGW (wildcarded, true)
Philipp Maierfdd603c2018-02-01 13:31:15 +0100103 * or if the user has choosen the particular endpoint explicitly. */
Philipp Maier207ab512018-02-02 14:19:26 +0100104 bool wildcarded_req;
Neels Hofmeyre6d8e912018-08-23 16:36:48 +0200105
106 /*! MGCP_X_OSMO_IGN_* flags from 'X-Osmo-IGN:' header */
107 uint32_t x_osmo_ign;
Philipp Maierfdd603c2018-02-01 13:31:15 +0100108};
109
110/*! Extract endpoint number for a given endpoint */
111#define ENDPOINT_NUMBER(endp) abs((int)(endp - endp->tcfg->endpoints))
112
Philipp Maier1355d7e2018-02-01 14:30:06 +0100113void mgcp_endp_release(struct mgcp_endpoint *endp);