blob: b40923dfecd0c88df3cb99a14d4a4d92939a105b [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,
48 CODEC_GSMEFR_8000_1 = 110,
Philipp Maierdbe09dd2019-03-07 13:48:12 +010049 CODEC_GSMHR_8000_1 = 111,
Philipp Maier704c4f02018-06-07 18:51:31 +020050 CODEC_AMR_8000_1 = 112,
51 CODEC_AMRWB_16000_1 = 113,
Philipp Maier1de5ed62021-12-21 14:38:14 +010052 CODEC_IUFP = 96,
Philipp Maier704c4f02018-06-07 18:51:31 +020053};
54/* Note: when new codec types are added, the corresponding value strings
55 * in mgcp_client.c (codec_table) must be updated as well. Enumerations
56 * in enum mgcp_codecs must correspond to a valid payload type. However,
57 * this is an internal assumption that is made to avoid lookup tables.
58 * The API-User should not rely on this coincidence! */
59
Neels Hofmeyr47642f22019-02-27 05:56:53 +010060extern const struct value_string osmo_mgcpc_codec_names[];
61static inline const char *osmo_mgcpc_codec_name(enum mgcp_codecs val)
62{ return get_value_string(osmo_mgcpc_codec_names, val); }
63
Philipp Maier704c4f02018-06-07 18:51:31 +020064/*! Structure to build a payload type map to allow the defiition custom payload
65 * types. */
66struct ptmap {
Neels Hofmeyr8838c622018-06-26 00:05:53 +020067 /*! codec for which a payload type number should be defined */
Philipp Maier704c4f02018-06-07 18:51:31 +020068 enum mgcp_codecs codec;
69
Neels Hofmeyr8838c622018-06-26 00:05:53 +020070 /*! payload type number (96-127) */
Philipp Maier704c4f02018-06-07 18:51:31 +020071 unsigned int pt;
72};
73
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020074struct mgcp_response_head {
Philipp Maieread2f602017-11-27 12:06:29 +010075 int response_code;
76 mgcp_trans_id_t trans_id;
Philipp Maierabe8c892018-01-20 00:15:12 +010077 char comment[MGCP_COMMENT_MAXLEN];
Neels Hofmeyr55e0dcf2018-09-03 21:36:56 +020078 char conn_id[MGCP_CONN_ID_MAXLEN];
Philipp Maier55295f72018-01-15 14:00:28 +010079 char endpoint[MGCP_ENDPOINT_MAXLEN];
Pau Espin Pedrol91088c32019-04-24 21:02:40 +020080 bool x_osmo_osmux_use;
81 uint8_t x_osmo_osmux_cid;
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020082};
83
84struct mgcp_response {
85 char *body;
86 struct mgcp_response_head head;
87 uint16_t audio_port;
Pau Espin Pedrol8667d512020-08-28 19:37:08 +020088 char audio_ip[INET6_ADDRSTRLEN];
Philipp Maier704c4f02018-06-07 18:51:31 +020089 unsigned int ptime;
90 enum mgcp_codecs codecs[MGCP_MAX_CODECS];
91 unsigned int codecs_len;
92 struct ptmap ptmap[MGCP_MAX_CODECS];
Philipp Maier228e5912019-03-05 13:56:59 +010093 unsigned int ptmap_len;
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020094};
95
Philipp Maier1dc6be62017-10-05 18:25:37 +020096enum mgcp_verb {
97 MGCP_VERB_CRCX,
98 MGCP_VERB_MDCX,
99 MGCP_VERB_DLCX,
100 MGCP_VERB_AUEP,
101 MGCP_VERB_RSIP,
102};
103
104#define MGCP_MSG_PRESENCE_ENDPOINT 0x0001
105#define MGCP_MSG_PRESENCE_CALL_ID 0x0002
106#define MGCP_MSG_PRESENCE_CONN_ID 0x0004
107#define MGCP_MSG_PRESENCE_AUDIO_IP 0x0008
108#define MGCP_MSG_PRESENCE_AUDIO_PORT 0x0010
109#define MGCP_MSG_PRESENCE_CONN_MODE 0x0020
Pau Espin Pedrol900cd652019-04-24 22:06:22 +0200110#define MGCP_MSG_PRESENCE_X_OSMO_OSMUX_CID 0x4000
Neels Hofmeyre6d8e912018-08-23 16:36:48 +0200111#define MGCP_MSG_PRESENCE_X_OSMO_IGN 0x8000
Philipp Maier1dc6be62017-10-05 18:25:37 +0200112
Philipp Maier1dc6be62017-10-05 18:25:37 +0200113struct mgcp_msg {
114 enum mgcp_verb verb;
115 /* See MGCP_MSG_PRESENCE_* constants */
116 uint32_t presence;
117 char endpoint[MGCP_ENDPOINT_MAXLEN];
118 unsigned int call_id;
Philipp Maier01d24a32017-11-21 17:26:09 +0100119 char *conn_id;
Harald Welte9bf7c532017-11-17 14:14:31 +0100120 uint16_t audio_port;
121 char *audio_ip;
Philipp Maier1dc6be62017-10-05 18:25:37 +0200122 enum mgcp_connection_mode conn_mode;
Philipp Maier704c4f02018-06-07 18:51:31 +0200123 unsigned int ptime;
124 enum mgcp_codecs codecs[MGCP_MAX_CODECS];
125 unsigned int codecs_len;
126 struct ptmap ptmap[MGCP_MAX_CODECS];
127 unsigned int ptmap_len;
Neels Hofmeyre6d8e912018-08-23 16:36:48 +0200128 uint32_t x_osmo_ign;
Pau Espin Pedrol900cd652019-04-24 22:06:22 +0200129 bool x_osmo_osmux_use;
130 int x_osmo_osmux_cid; /* -1 is wildcard */
Philipp Maier228e5912019-03-05 13:56:59 +0100131 bool param_present;
132 struct mgcp_codec_param param;
Philipp Maier1dc6be62017-10-05 18:25:37 +0200133};
134
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200135void mgcp_client_conf_init(struct mgcp_client_conf *conf);
136void mgcp_client_vty_init(void *talloc_ctx, int node, struct mgcp_client_conf *conf);
137int mgcp_client_config_write(struct vty *vty, const char *indent);
138struct mgcp_client_conf *mgcp_client_conf_actual(struct mgcp_client *mgcp);
139
140struct mgcp_client *mgcp_client_init(void *ctx,
141 struct mgcp_client_conf *conf);
142int mgcp_client_connect(struct mgcp_client *mgcp);
Pau Espin Pedrol8e74c632022-10-17 19:20:45 +0200143int 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 +0200144void mgcp_client_disconnect(struct mgcp_client *mgcp);
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200145
146const char *mgcp_client_remote_addr_str(struct mgcp_client *mgcp);
147uint16_t mgcp_client_remote_port(struct mgcp_client *mgcp);
Pau Espin Pedrol74d0e5c2020-09-02 17:19:20 +0200148uint32_t mgcp_client_remote_addr_n(struct mgcp_client *mgcp) OSMO_DEPRECATED("deprecated, returns 0");
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200149
Neels Hofmeyrac69ea92018-12-19 00:27:50 +0100150const char *mgcp_client_endpoint_domain(const struct mgcp_client *mgcp);
151const char *mgcp_client_rtpbridge_wildcard(const struct mgcp_client *mgcp);
Philipp Maier48635912020-06-25 20:16:22 +0200152const char *mgcp_client_e1_epname(void *ctx, const struct mgcp_client *mgcp, uint8_t trunk_id, uint8_t ts,
153 uint8_t rate, uint8_t offset);
Neels Hofmeyrac69ea92018-12-19 00:27:50 +0100154
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200155/* Invoked when an MGCP response is received or sending failed. When the
156 * response is passed as NULL, this indicates failure during transmission. */
157typedef void (* mgcp_response_cb_t )(struct mgcp_response *response, void *priv);
158int mgcp_response_parse_params(struct mgcp_response *r);
159
160int mgcp_client_tx(struct mgcp_client *mgcp, struct msgb *msg,
161 mgcp_response_cb_t response_cb, void *priv);
Neels Hofmeyrc8f37cb2017-11-30 13:43:11 +0100162int mgcp_client_cancel(struct mgcp_client *mgcp, mgcp_trans_id_t trans_id);
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200163
164enum mgcp_connection_mode;
165
Philipp Maier1dc6be62017-10-05 18:25:37 +0200166struct msgb *mgcp_msg_gen(struct mgcp_client *mgcp, struct mgcp_msg *mgcp_msg);
Neels Hofmeyrc8f37cb2017-11-30 13:43:11 +0100167mgcp_trans_id_t mgcp_msg_trans_id(struct msgb *msg);
Neels Hofmeyrd95ab1e2017-09-22 00:52:54 +0200168
169extern const struct value_string mgcp_client_connection_mode_strs[];
170static inline const char *mgcp_client_cmode_name(enum mgcp_connection_mode mode)
171{
172 return get_value_string(mgcp_client_connection_mode_strs, mode);
173}
Philipp Maier704c4f02018-06-07 18:51:31 +0200174
175enum mgcp_codecs map_str_to_codec(const char *str);
Neels Hofmeyr84274e42019-04-27 19:08:36 +0200176unsigned int map_codec_to_pt(const struct ptmap *ptmap, unsigned int ptmap_len,
Philipp Maier704c4f02018-06-07 18:51:31 +0200177 enum mgcp_codecs codec);
178enum mgcp_codecs map_pt_to_codec(struct ptmap *ptmap, unsigned int ptmap_len,
179 unsigned int pt);
Philipp Maierdf9192e2021-09-03 17:50:51 +0200180
181const char *mgcp_client_name(const struct mgcp_client *mgcp);