blob: 6adaf4b8e9987841e7161b7435fe039185cf4a69 [file] [log] [blame]
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +02001#pragma once
2
3#include <stdint.h>
Philipp Maier1dc6be62017-10-05 18:25:37 +02004#include <arpa/inet.h>
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +02005
Neels Hofmeyrd95ab1e2017-09-22 00:52:54 +02006#include <osmocom/mgcp_client/mgcp_common.h>
7
Philipp Maieraf8e00f2018-07-27 16:04:41 +02008/* See also: RFC 3435, chapter 3.5 Transmission over UDP */
Pau Espin Pedrolee2f33b2020-08-31 19:36:31 +02009#define MGCP_CLIENT_LOCAL_ADDR_DEFAULT NULL /* INADDR(6)_ANY */
Pau Espin Pedrol8e74c632022-10-17 19:20:45 +020010#define MGCP_CLIENT_LOCAL_PORT_DEFAULT 0
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020011#define MGCP_CLIENT_REMOTE_ADDR_DEFAULT "127.0.0.1"
12#define MGCP_CLIENT_REMOTE_PORT_DEFAULT 2427
13
Neels Hofmeyre6d8e912018-08-23 16:36:48 +020014#define MGCP_CLIENT_MGW_STR "Configure MGCP connection to Media Gateway\n"
15
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020016struct msgb;
17struct vty;
18struct mgcp_client;
19
20struct mgcp_client_conf {
21 const char *local_addr;
22 int local_port;
23 const char *remote_addr;
24 int remote_port;
Neels Hofmeyrac69ea92018-12-19 00:27:50 +010025
26 /* By default, we are always addressing the MGW with e.g. 'rtpbridge/123@mgw'.
27 * If this is nonempty, the contained name will be used instead of 'mgw'. */
28 char endpoint_domain_name[MGCP_ENDPOINT_MAXLEN];
Philipp Maier3f2c15f2021-07-22 11:53:07 +020029
30 /* The user may configure certain endpoint names that are reset via DLCX
31 * on startup. Usually this will be one wildcarded endpoint e.g.
32 * 'rtpbridge/(wildcard)' or a number of specific E1 like e.g.
33 * 'ds/e1-0/s-3/su16-4' */
34 struct llist_head reset_epnames;
Philipp Maierdf9192e2021-09-03 17:50:51 +020035
36 /* human readable name / description */
37 char *description;
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020038};
39
40typedef unsigned int mgcp_trans_id_t;
41
Philipp Maier704c4f02018-06-07 18:51:31 +020042/*! Enumeration of the codec types that mgcp_client is able to handle. */
43enum mgcp_codecs {
44 CODEC_PCMU_8000_1 = 0,
45 CODEC_GSM_8000_1 = 3,
46 CODEC_PCMA_8000_1 = 8,
47 CODEC_G729_8000_1 = 18,
Philipp Maier14da3a32023-05-23 12:03:16 +020048 CODEC_GSMEFR_8000_1 = 110, /* 3GPP TS 48.103 table 5.4.2.2.1 */
49 CODEC_GSMHR_8000_1 = 111, /* 3GPP TS 48.103 table 5.4.2.2.1 */
50 CODEC_AMR_8000_1 = 112, /* 3GPP TS 48.103 table 5.4.2.2.1 */
51 CODEC_AMRWB_16000_1 = 113, /* 3GPP TS 48.103 table 5.4.2.2.1 */
Philipp Maier1de5ed62021-12-21 14:38:14 +010052 CODEC_IUFP = 96,
Philipp Maier14da3a32023-05-23 12:03:16 +020053 CODEC_CLEARMODE = 120, /* 3GPP TS 48.103 table 5.4.2.2.1 */
Philipp Maier704c4f02018-06-07 18:51:31 +020054};
55/* Note: when new codec types are added, the corresponding value strings
56 * in mgcp_client.c (codec_table) must be updated as well. Enumerations
57 * in enum mgcp_codecs must correspond to a valid payload type. However,
58 * this is an internal assumption that is made to avoid lookup tables.
59 * The API-User should not rely on this coincidence! */
60
Neels Hofmeyr47642f22019-02-27 05:56:53 +010061extern const struct value_string osmo_mgcpc_codec_names[];
62static inline const char *osmo_mgcpc_codec_name(enum mgcp_codecs val)
63{ return get_value_string(osmo_mgcpc_codec_names, val); }
64
Philipp Maier704c4f02018-06-07 18:51:31 +020065/*! Structure to build a payload type map to allow the defiition custom payload
66 * types. */
67struct ptmap {
Neels Hofmeyr8838c622018-06-26 00:05:53 +020068 /*! codec for which a payload type number should be defined */
Philipp Maier704c4f02018-06-07 18:51:31 +020069 enum mgcp_codecs codec;
70
Neels Hofmeyr8838c622018-06-26 00:05:53 +020071 /*! payload type number (96-127) */
Philipp Maier704c4f02018-06-07 18:51:31 +020072 unsigned int pt;
73};
74
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020075struct mgcp_response_head {
Philipp Maieread2f602017-11-27 12:06:29 +010076 int response_code;
77 mgcp_trans_id_t trans_id;
Philipp Maierabe8c892018-01-20 00:15:12 +010078 char comment[MGCP_COMMENT_MAXLEN];
Neels Hofmeyr55e0dcf2018-09-03 21:36:56 +020079 char conn_id[MGCP_CONN_ID_MAXLEN];
Philipp Maier55295f72018-01-15 14:00:28 +010080 char endpoint[MGCP_ENDPOINT_MAXLEN];
Pau Espin Pedrol91088c32019-04-24 21:02:40 +020081 bool x_osmo_osmux_use;
82 uint8_t x_osmo_osmux_cid;
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020083};
84
85struct mgcp_response {
86 char *body;
87 struct mgcp_response_head head;
88 uint16_t audio_port;
Pau Espin Pedrol8667d512020-08-28 19:37:08 +020089 char audio_ip[INET6_ADDRSTRLEN];
Philipp Maier704c4f02018-06-07 18:51:31 +020090 unsigned int ptime;
91 enum mgcp_codecs codecs[MGCP_MAX_CODECS];
92 unsigned int codecs_len;
93 struct ptmap ptmap[MGCP_MAX_CODECS];
Philipp Maier228e5912019-03-05 13:56:59 +010094 unsigned int ptmap_len;
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020095};
96
Philipp Maier1dc6be62017-10-05 18:25:37 +020097enum mgcp_verb {
98 MGCP_VERB_CRCX,
99 MGCP_VERB_MDCX,
100 MGCP_VERB_DLCX,
101 MGCP_VERB_AUEP,
102 MGCP_VERB_RSIP,
103};
104
105#define MGCP_MSG_PRESENCE_ENDPOINT 0x0001
106#define MGCP_MSG_PRESENCE_CALL_ID 0x0002
107#define MGCP_MSG_PRESENCE_CONN_ID 0x0004
108#define MGCP_MSG_PRESENCE_AUDIO_IP 0x0008
109#define MGCP_MSG_PRESENCE_AUDIO_PORT 0x0010
110#define MGCP_MSG_PRESENCE_CONN_MODE 0x0020
Pau Espin Pedrol900cd652019-04-24 22:06:22 +0200111#define MGCP_MSG_PRESENCE_X_OSMO_OSMUX_CID 0x4000
Neels Hofmeyre6d8e912018-08-23 16:36:48 +0200112#define MGCP_MSG_PRESENCE_X_OSMO_IGN 0x8000
Philipp Maier1dc6be62017-10-05 18:25:37 +0200113
Philipp Maier1dc6be62017-10-05 18:25:37 +0200114struct mgcp_msg {
115 enum mgcp_verb verb;
116 /* See MGCP_MSG_PRESENCE_* constants */
117 uint32_t presence;
118 char endpoint[MGCP_ENDPOINT_MAXLEN];
119 unsigned int call_id;
Philipp Maier01d24a32017-11-21 17:26:09 +0100120 char *conn_id;
Harald Welte9bf7c532017-11-17 14:14:31 +0100121 uint16_t audio_port;
122 char *audio_ip;
Philipp Maier1dc6be62017-10-05 18:25:37 +0200123 enum mgcp_connection_mode conn_mode;
Philipp Maier704c4f02018-06-07 18:51:31 +0200124 unsigned int ptime;
125 enum mgcp_codecs codecs[MGCP_MAX_CODECS];
126 unsigned int codecs_len;
127 struct ptmap ptmap[MGCP_MAX_CODECS];
128 unsigned int ptmap_len;
Neels Hofmeyre6d8e912018-08-23 16:36:48 +0200129 uint32_t x_osmo_ign;
Pau Espin Pedrol900cd652019-04-24 22:06:22 +0200130 bool x_osmo_osmux_use;
131 int x_osmo_osmux_cid; /* -1 is wildcard */
Philipp Maier228e5912019-03-05 13:56:59 +0100132 bool param_present;
133 struct mgcp_codec_param param;
Philipp Maier1dc6be62017-10-05 18:25:37 +0200134};
135
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200136void mgcp_client_conf_init(struct mgcp_client_conf *conf);
137void mgcp_client_vty_init(void *talloc_ctx, int node, struct mgcp_client_conf *conf);
138int mgcp_client_config_write(struct vty *vty, const char *indent);
139struct mgcp_client_conf *mgcp_client_conf_actual(struct mgcp_client *mgcp);
140
141struct mgcp_client *mgcp_client_init(void *ctx,
142 struct mgcp_client_conf *conf);
143int mgcp_client_connect(struct mgcp_client *mgcp);
Pau Espin Pedrol8e74c632022-10-17 19:20:45 +0200144int mgcp_client_connect2(struct mgcp_client *mgcp, unsigned int retry_n_ports) OSMO_DEPRECATED("Use mgcp_client_connect() instead");
Philipp Maier3f4a4cb2021-07-26 13:20:05 +0200145void mgcp_client_disconnect(struct mgcp_client *mgcp);
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200146
147const char *mgcp_client_remote_addr_str(struct mgcp_client *mgcp);
148uint16_t mgcp_client_remote_port(struct mgcp_client *mgcp);
Pau Espin Pedrol74d0e5c2020-09-02 17:19:20 +0200149uint32_t mgcp_client_remote_addr_n(struct mgcp_client *mgcp) OSMO_DEPRECATED("deprecated, returns 0");
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200150
Neels Hofmeyrac69ea92018-12-19 00:27:50 +0100151const char *mgcp_client_endpoint_domain(const struct mgcp_client *mgcp);
152const char *mgcp_client_rtpbridge_wildcard(const struct mgcp_client *mgcp);
Philipp Maier48635912020-06-25 20:16:22 +0200153const char *mgcp_client_e1_epname(void *ctx, const struct mgcp_client *mgcp, uint8_t trunk_id, uint8_t ts,
154 uint8_t rate, uint8_t offset);
Neels Hofmeyrac69ea92018-12-19 00:27:50 +0100155
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200156/* Invoked when an MGCP response is received or sending failed. When the
157 * response is passed as NULL, this indicates failure during transmission. */
158typedef void (* mgcp_response_cb_t )(struct mgcp_response *response, void *priv);
159int mgcp_response_parse_params(struct mgcp_response *r);
160
161int mgcp_client_tx(struct mgcp_client *mgcp, struct msgb *msg,
162 mgcp_response_cb_t response_cb, void *priv);
Neels Hofmeyrc8f37cb2017-11-30 13:43:11 +0100163int mgcp_client_cancel(struct mgcp_client *mgcp, mgcp_trans_id_t trans_id);
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200164
165enum mgcp_connection_mode;
166
Philipp Maier1dc6be62017-10-05 18:25:37 +0200167struct msgb *mgcp_msg_gen(struct mgcp_client *mgcp, struct mgcp_msg *mgcp_msg);
Neels Hofmeyrc8f37cb2017-11-30 13:43:11 +0100168mgcp_trans_id_t mgcp_msg_trans_id(struct msgb *msg);
Neels Hofmeyrd95ab1e2017-09-22 00:52:54 +0200169
170extern const struct value_string mgcp_client_connection_mode_strs[];
171static inline const char *mgcp_client_cmode_name(enum mgcp_connection_mode mode)
172{
173 return get_value_string(mgcp_client_connection_mode_strs, mode);
174}
Philipp Maier704c4f02018-06-07 18:51:31 +0200175
176enum mgcp_codecs map_str_to_codec(const char *str);
Neels Hofmeyr84274e42019-04-27 19:08:36 +0200177unsigned int map_codec_to_pt(const struct ptmap *ptmap, unsigned int ptmap_len,
Philipp Maier704c4f02018-06-07 18:51:31 +0200178 enum mgcp_codecs codec);
179enum mgcp_codecs map_pt_to_codec(struct ptmap *ptmap, unsigned int ptmap_len,
180 unsigned int pt);
Philipp Maierdf9192e2021-09-03 17:50:51 +0200181
182const char *mgcp_client_name(const struct mgcp_client *mgcp);