blob: e9fe0aecf40fcd963983d0cfe4df458fd2c8173e [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 */
Philipp Maieraf8e00f2018-07-27 16:04:41 +020010#define MGCP_CLIENT_LOCAL_PORT_DEFAULT 2727
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;
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020035};
36
37typedef unsigned int mgcp_trans_id_t;
38
Philipp Maier704c4f02018-06-07 18:51:31 +020039/*! Enumeration of the codec types that mgcp_client is able to handle. */
40enum mgcp_codecs {
41 CODEC_PCMU_8000_1 = 0,
42 CODEC_GSM_8000_1 = 3,
43 CODEC_PCMA_8000_1 = 8,
44 CODEC_G729_8000_1 = 18,
45 CODEC_GSMEFR_8000_1 = 110,
Philipp Maierdbe09dd2019-03-07 13:48:12 +010046 CODEC_GSMHR_8000_1 = 111,
Philipp Maier704c4f02018-06-07 18:51:31 +020047 CODEC_AMR_8000_1 = 112,
48 CODEC_AMRWB_16000_1 = 113,
49};
50/* Note: when new codec types are added, the corresponding value strings
51 * in mgcp_client.c (codec_table) must be updated as well. Enumerations
52 * in enum mgcp_codecs must correspond to a valid payload type. However,
53 * this is an internal assumption that is made to avoid lookup tables.
54 * The API-User should not rely on this coincidence! */
55
Neels Hofmeyr47642f22019-02-27 05:56:53 +010056extern const struct value_string osmo_mgcpc_codec_names[];
57static inline const char *osmo_mgcpc_codec_name(enum mgcp_codecs val)
58{ return get_value_string(osmo_mgcpc_codec_names, val); }
59
Philipp Maier704c4f02018-06-07 18:51:31 +020060/*! Structure to build a payload type map to allow the defiition custom payload
61 * types. */
62struct ptmap {
Neels Hofmeyr8838c622018-06-26 00:05:53 +020063 /*! codec for which a payload type number should be defined */
Philipp Maier704c4f02018-06-07 18:51:31 +020064 enum mgcp_codecs codec;
65
Neels Hofmeyr8838c622018-06-26 00:05:53 +020066 /*! payload type number (96-127) */
Philipp Maier704c4f02018-06-07 18:51:31 +020067 unsigned int pt;
68};
69
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020070struct mgcp_response_head {
Philipp Maieread2f602017-11-27 12:06:29 +010071 int response_code;
72 mgcp_trans_id_t trans_id;
Philipp Maierabe8c892018-01-20 00:15:12 +010073 char comment[MGCP_COMMENT_MAXLEN];
Neels Hofmeyr55e0dcf2018-09-03 21:36:56 +020074 char conn_id[MGCP_CONN_ID_MAXLEN];
Philipp Maier55295f72018-01-15 14:00:28 +010075 char endpoint[MGCP_ENDPOINT_MAXLEN];
Pau Espin Pedrol91088c32019-04-24 21:02:40 +020076 bool x_osmo_osmux_use;
77 uint8_t x_osmo_osmux_cid;
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020078};
79
80struct mgcp_response {
81 char *body;
82 struct mgcp_response_head head;
83 uint16_t audio_port;
Pau Espin Pedrol8667d512020-08-28 19:37:08 +020084 char audio_ip[INET6_ADDRSTRLEN];
Philipp Maier704c4f02018-06-07 18:51:31 +020085 unsigned int ptime;
86 enum mgcp_codecs codecs[MGCP_MAX_CODECS];
87 unsigned int codecs_len;
88 struct ptmap ptmap[MGCP_MAX_CODECS];
Philipp Maier228e5912019-03-05 13:56:59 +010089 unsigned int ptmap_len;
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +020090};
91
Philipp Maier1dc6be62017-10-05 18:25:37 +020092enum mgcp_verb {
93 MGCP_VERB_CRCX,
94 MGCP_VERB_MDCX,
95 MGCP_VERB_DLCX,
96 MGCP_VERB_AUEP,
97 MGCP_VERB_RSIP,
98};
99
100#define MGCP_MSG_PRESENCE_ENDPOINT 0x0001
101#define MGCP_MSG_PRESENCE_CALL_ID 0x0002
102#define MGCP_MSG_PRESENCE_CONN_ID 0x0004
103#define MGCP_MSG_PRESENCE_AUDIO_IP 0x0008
104#define MGCP_MSG_PRESENCE_AUDIO_PORT 0x0010
105#define MGCP_MSG_PRESENCE_CONN_MODE 0x0020
Pau Espin Pedrol900cd652019-04-24 22:06:22 +0200106#define MGCP_MSG_PRESENCE_X_OSMO_OSMUX_CID 0x4000
Neels Hofmeyre6d8e912018-08-23 16:36:48 +0200107#define MGCP_MSG_PRESENCE_X_OSMO_IGN 0x8000
Philipp Maier1dc6be62017-10-05 18:25:37 +0200108
Philipp Maier1dc6be62017-10-05 18:25:37 +0200109struct mgcp_msg {
110 enum mgcp_verb verb;
111 /* See MGCP_MSG_PRESENCE_* constants */
112 uint32_t presence;
113 char endpoint[MGCP_ENDPOINT_MAXLEN];
114 unsigned int call_id;
Philipp Maier01d24a32017-11-21 17:26:09 +0100115 char *conn_id;
Harald Welte9bf7c532017-11-17 14:14:31 +0100116 uint16_t audio_port;
117 char *audio_ip;
Philipp Maier1dc6be62017-10-05 18:25:37 +0200118 enum mgcp_connection_mode conn_mode;
Philipp Maier704c4f02018-06-07 18:51:31 +0200119 unsigned int ptime;
120 enum mgcp_codecs codecs[MGCP_MAX_CODECS];
121 unsigned int codecs_len;
122 struct ptmap ptmap[MGCP_MAX_CODECS];
123 unsigned int ptmap_len;
Neels Hofmeyre6d8e912018-08-23 16:36:48 +0200124 uint32_t x_osmo_ign;
Pau Espin Pedrol900cd652019-04-24 22:06:22 +0200125 bool x_osmo_osmux_use;
126 int x_osmo_osmux_cid; /* -1 is wildcard */
Philipp Maier228e5912019-03-05 13:56:59 +0100127 bool param_present;
128 struct mgcp_codec_param param;
Philipp Maier1dc6be62017-10-05 18:25:37 +0200129};
130
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200131void mgcp_client_conf_init(struct mgcp_client_conf *conf);
132void mgcp_client_vty_init(void *talloc_ctx, int node, struct mgcp_client_conf *conf);
133int mgcp_client_config_write(struct vty *vty, const char *indent);
134struct mgcp_client_conf *mgcp_client_conf_actual(struct mgcp_client *mgcp);
135
136struct mgcp_client *mgcp_client_init(void *ctx,
137 struct mgcp_client_conf *conf);
138int mgcp_client_connect(struct mgcp_client *mgcp);
139
140const char *mgcp_client_remote_addr_str(struct mgcp_client *mgcp);
141uint16_t mgcp_client_remote_port(struct mgcp_client *mgcp);
Pau Espin Pedrol74d0e5c2020-09-02 17:19:20 +0200142uint32_t mgcp_client_remote_addr_n(struct mgcp_client *mgcp) OSMO_DEPRECATED("deprecated, returns 0");
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200143
Neels Hofmeyrac69ea92018-12-19 00:27:50 +0100144const char *mgcp_client_endpoint_domain(const struct mgcp_client *mgcp);
145const char *mgcp_client_rtpbridge_wildcard(const struct mgcp_client *mgcp);
Philipp Maier48635912020-06-25 20:16:22 +0200146const char *mgcp_client_e1_epname(void *ctx, const struct mgcp_client *mgcp, uint8_t trunk_id, uint8_t ts,
147 uint8_t rate, uint8_t offset);
Neels Hofmeyrac69ea92018-12-19 00:27:50 +0100148
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200149/* Invoked when an MGCP response is received or sending failed. When the
150 * response is passed as NULL, this indicates failure during transmission. */
151typedef void (* mgcp_response_cb_t )(struct mgcp_response *response, void *priv);
152int mgcp_response_parse_params(struct mgcp_response *r);
153
154int mgcp_client_tx(struct mgcp_client *mgcp, struct msgb *msg,
155 mgcp_response_cb_t response_cb, void *priv);
Neels Hofmeyrc8f37cb2017-11-30 13:43:11 +0100156int mgcp_client_cancel(struct mgcp_client *mgcp, mgcp_trans_id_t trans_id);
Neels Hofmeyr3a8e7232017-09-04 01:02:56 +0200157
158enum mgcp_connection_mode;
159
Philipp Maier1dc6be62017-10-05 18:25:37 +0200160struct msgb *mgcp_msg_gen(struct mgcp_client *mgcp, struct mgcp_msg *mgcp_msg);
Neels Hofmeyrc8f37cb2017-11-30 13:43:11 +0100161mgcp_trans_id_t mgcp_msg_trans_id(struct msgb *msg);
Neels Hofmeyrd95ab1e2017-09-22 00:52:54 +0200162
163extern const struct value_string mgcp_client_connection_mode_strs[];
164static inline const char *mgcp_client_cmode_name(enum mgcp_connection_mode mode)
165{
166 return get_value_string(mgcp_client_connection_mode_strs, mode);
167}
Philipp Maier704c4f02018-06-07 18:51:31 +0200168
169enum mgcp_codecs map_str_to_codec(const char *str);
Neels Hofmeyr84274e42019-04-27 19:08:36 +0200170unsigned int map_codec_to_pt(const struct ptmap *ptmap, unsigned int ptmap_len,
Philipp Maier704c4f02018-06-07 18:51:31 +0200171 enum mgcp_codecs codec);
172enum mgcp_codecs map_pt_to_codec(struct ptmap *ptmap, unsigned int ptmap_len,
173 unsigned int pt);