blob: ab36e478914d3d60a0578dad758ed2b258007e03 [file] [log] [blame]
Holger Hans Peter Freythercacbc732010-06-30 14:59:23 +08001/* Osmo BSC VTY Configuration */
Holger Hans Peter Freyther98258db2014-02-22 10:30:32 +01002/* (C) 2009-2014 by Holger Hans Peter Freyther
3 * (C) 2009-2014 by On-Waves
Holger Hans Peter Freythercacbc732010-06-30 14:59:23 +08004 * All Rights Reserved
5 *
6 * This program is free software; you can redistribute it and/or modify
Harald Welte9af6ddf2011-01-01 15:25:50 +01007 * it under the terms of the GNU Affero General Public License as published by
8 * the Free Software Foundation; either version 3 of the License, or
Holger Hans Peter Freythercacbc732010-06-30 14:59:23 +08009 * (at your option) any later version.
10 *
11 * This program is distributed in the hope that it will be useful,
12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Harald Welte9af6ddf2011-01-01 15:25:50 +010014 * GNU Affero General Public License for more details.
Holger Hans Peter Freythercacbc732010-06-30 14:59:23 +080015 *
Harald Welte9af6ddf2011-01-01 15:25:50 +010016 * You should have received a copy of the GNU Affero General Public License
17 * along with this program. If not, see <http://www.gnu.org/licenses/>.
Holger Hans Peter Freythercacbc732010-06-30 14:59:23 +080018 *
19 */
20
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080021#include <openbsc/gsm_data.h>
Holger Hans Peter Freyther98258db2014-02-22 10:30:32 +010022#include <openbsc/osmo_bsc.h>
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080023#include <openbsc/osmo_msc_data.h>
24#include <openbsc/vty.h>
Holger Hans Peter Freyther6995f242014-12-28 18:54:32 +010025#include <openbsc/gsm_subscriber.h>
26#include <openbsc/debug.h>
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080027
Pablo Neira Ayuso136f4532011-03-22 16:47:59 +010028#include <osmocom/core/talloc.h>
Holger Hans Peter Freyther6995f242014-12-28 18:54:32 +010029#include <osmocom/vty/logging.h>
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080030
Daniel Willmann7d109832012-05-14 18:43:23 +020031#include <time.h>
32
Holger Hans Peter Freytherfe166222010-11-03 13:32:48 +010033
34#define IPA_STR "IP.ACCESS specific\n"
35
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080036extern struct gsm_network *bsc_gsmnet;
37
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +020038static struct osmo_bsc_data *osmo_bsc_data(struct vty *vty)
39{
40 return bsc_gsmnet->bsc_data;
41}
42
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080043static struct osmo_msc_data *osmo_msc_data(struct vty *vty)
44{
Holger Hans Peter Freyther20fea242011-06-04 19:58:26 +020045 return osmo_msc_data_find(bsc_gsmnet, (int) vty->index);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080046}
47
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +020048static struct cmd_node bsc_node = {
49 BSC_NODE,
Jacob Erlbeck0b4f1b92013-08-30 18:33:58 +020050 "%s(config-bsc)# ",
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +020051 1,
52};
53
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080054static struct cmd_node msc_node = {
55 MSC_NODE,
Harald Welte570ce242012-08-17 13:16:10 +020056 "%s(config-msc)# ",
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080057 1,
58};
59
60DEFUN(cfg_net_msc, cfg_net_msc_cmd,
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +020061 "msc [<0-1000>]", "Configure MSC details\n" "MSC connection to configure\n")
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080062{
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +020063 int index = argc == 1 ? atoi(argv[0]) : 0;
Holger Hans Peter Freyther20fea242011-06-04 19:58:26 +020064 struct osmo_msc_data *msc;
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080065
Holger Hans Peter Freyther20fea242011-06-04 19:58:26 +020066 msc = osmo_msc_data_alloc(bsc_gsmnet, index);
67 if (!msc) {
68 vty_out(vty, "%%Failed to allocate MSC data.%s", VTY_NEWLINE);
69 return CMD_WARNING;
70 }
71
72 vty->index = (void *) index;
73 vty->node = MSC_NODE;
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +080074 return CMD_SUCCESS;
75}
76
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +020077DEFUN(cfg_net_bsc, cfg_net_bsc_cmd,
78 "bsc", "Configure BSC\n")
79{
80 vty->node = BSC_NODE;
81 return CMD_SUCCESS;
82}
83
Holger Hans Peter Freyther75077952011-08-06 08:31:51 +020084static void write_msc_amr_options(struct vty *vty, struct osmo_msc_data *msc)
85{
86#define WRITE_AMR(vty, msc, name, var) \
87 vty_out(vty, " amr-config %s %s%s", \
88 name, msc->amr_conf.var ? "allowed" : "forbidden", \
89 VTY_NEWLINE);
90
91 WRITE_AMR(vty, msc, "12_2k", m12_2);
92 WRITE_AMR(vty, msc, "10_2k", m10_2);
93 WRITE_AMR(vty, msc, "7_95k", m7_95);
94 WRITE_AMR(vty, msc, "7_40k", m7_40);
95 WRITE_AMR(vty, msc, "6_70k", m6_70);
96 WRITE_AMR(vty, msc, "5_90k", m5_90);
97 WRITE_AMR(vty, msc, "5_15k", m5_15);
98 WRITE_AMR(vty, msc, "4_75k", m4_75);
99#undef WRITE_AMR
100}
101
Holger Hans Peter Freyther20fea242011-06-04 19:58:26 +0200102static void write_msc(struct vty *vty, struct osmo_msc_data *msc)
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800103{
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200104 struct bsc_msc_dest *dest;
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800105
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200106 vty_out(vty, "msc %d%s", msc->nr, VTY_NEWLINE);
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200107 if (msc->bsc_token)
108 vty_out(vty, " token %s%s", msc->bsc_token, VTY_NEWLINE);
109 if (msc->core_ncc != -1)
Holger Hans Peter Freyther06f4fc72011-03-29 17:46:14 +0200110 vty_out(vty, " core-mobile-network-code %d%s",
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200111 msc->core_ncc, VTY_NEWLINE);
112 if (msc->core_mcc != -1)
Holger Hans Peter Freyther06f4fc72011-03-29 17:46:14 +0200113 vty_out(vty, " core-mobile-country-code %d%s",
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200114 msc->core_mcc, VTY_NEWLINE);
115 vty_out(vty, " ip.access rtp-base %d%s", msc->rtp_base, VTY_NEWLINE);
Holger Hans Peter Freytherdb64f2e2014-10-29 10:06:15 +0100116
117 if (msc->ping_timeout == -1)
118 vty_out(vty, " no timeout-ping%s", VTY_NEWLINE);
119 else {
120 vty_out(vty, " timeout-ping %d%s", msc->ping_timeout, VTY_NEWLINE);
121 vty_out(vty, " timeout-pong %d%s", msc->pong_timeout, VTY_NEWLINE);
122 if (msc->advanced_ping)
123 vty_out(vty, " timeout-ping advanced%s", VTY_NEWLINE);
124 else
125 vty_out(vty, " no timeout-ping advanced%s", VTY_NEWLINE);
126 }
Jacob Erlbeck97e139f2013-08-28 10:16:55 +0200127
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200128 if (msc->ussd_welcome_txt)
129 vty_out(vty, " bsc-welcome-text %s%s", msc->ussd_welcome_txt, VTY_NEWLINE);
Jacob Erlbeck97e139f2013-08-28 10:16:55 +0200130 else
131 vty_out(vty, " no bsc-welcome-text%s", VTY_NEWLINE);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800132
Jacob Erlbeck1b894022013-08-28 10:16:54 +0200133 if (msc->ussd_msc_lost_txt && msc->ussd_msc_lost_txt[0])
134 vty_out(vty, " bsc-msc-lost-text %s%s", msc->ussd_msc_lost_txt, VTY_NEWLINE);
135 else
136 vty_out(vty, " no bsc-msc-lost-text%s", VTY_NEWLINE);
137
Jacob Erlbeck56595f82013-09-11 10:46:55 +0200138 if (msc->ussd_grace_txt && msc->ussd_grace_txt[0])
139 vty_out(vty, " bsc-grace-text %s%s", msc->ussd_grace_txt, VTY_NEWLINE);
140 else
141 vty_out(vty, " no bsc-grace-text%s", VTY_NEWLINE);
142
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200143 if (msc->audio_length != 0) {
Holger Hans Peter Freyther7bf66c52010-11-03 13:55:49 +0100144 int i;
145
Holger Hans Peter Freyther06f4fc72011-03-29 17:46:14 +0200146 vty_out(vty, " codec-list ");
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200147 for (i = 0; i < msc->audio_length; ++i) {
Holger Hans Peter Freyther7bf66c52010-11-03 13:55:49 +0100148 if (i != 0)
Harald Welte22ce5982013-06-19 15:32:27 +0200149 vty_out(vty, " ");
Holger Hans Peter Freyther7bf66c52010-11-03 13:55:49 +0100150
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200151 if (msc->audio_support[i]->hr)
152 vty_out(vty, "hr%.1u", msc->audio_support[i]->ver);
Holger Hans Peter Freyther7bf66c52010-11-03 13:55:49 +0100153 else
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200154 vty_out(vty, "fr%.1u", msc->audio_support[i]->ver);
Holger Hans Peter Freyther7bf66c52010-11-03 13:55:49 +0100155 }
156 vty_out(vty, "%s", VTY_NEWLINE);
157
158 }
159
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200160 llist_for_each_entry(dest, &msc->dests, list)
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200161 vty_out(vty, " dest %s %d %d%s", dest->ip, dest->port,
162 dest->dscp, VTY_NEWLINE);
Holger Hans Peter Freythercbaa8802011-06-08 16:28:04 +0200163
164 vty_out(vty, " type %s%s", msc->type == MSC_CON_TYPE_NORMAL ?
165 "normal" : "local", VTY_NEWLINE);
Holger Hans Peter Freyther31b245b2011-06-08 19:27:15 +0200166 vty_out(vty, " allow-emergency %s%s", msc->allow_emerg ?
167 "allow" : "deny", VTY_NEWLINE);
Holger Hans Peter Freytherd5edc4f2011-06-09 21:54:08 +0200168
169 if (msc->local_pref)
170 vty_out(vty, " local-prefix %s%s", msc->local_pref, VTY_NEWLINE);
Holger Hans Peter Freyther75077952011-08-06 08:31:51 +0200171
172 /* write amr options */
173 write_msc_amr_options(vty, msc);
Holger Hans Peter Freyther20fea242011-06-04 19:58:26 +0200174}
175
176static int config_write_msc(struct vty *vty)
177{
178 struct osmo_msc_data *msc;
179 struct osmo_bsc_data *bsc = osmo_bsc_data(vty);
180
181 llist_for_each_entry(msc, &bsc->mscs, entry)
182 write_msc(vty, msc);
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200183
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200184 return CMD_SUCCESS;
185}
186
187static int config_write_bsc(struct vty *vty)
188{
189 struct osmo_bsc_data *bsc = osmo_bsc_data(vty);
190
191 vty_out(vty, "bsc%s", VTY_NEWLINE);
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200192 if (bsc->mid_call_txt)
193 vty_out(vty, " mid-call-text %s%s", bsc->mid_call_txt, VTY_NEWLINE);
194 vty_out(vty, " mid-call-timeout %d%s", bsc->mid_call_timeout, VTY_NEWLINE);
195 if (bsc->rf_ctrl_name)
196 vty_out(vty, " bsc-rf-socket %s%s",
197 bsc->rf_ctrl_name, VTY_NEWLINE);
198
Holger Hans Peter Freyther2a896072011-08-16 19:47:39 +0200199 if (bsc->auto_off_timeout != -1)
200 vty_out(vty, " bsc-auto-rf-off %d%s",
201 bsc->auto_off_timeout, VTY_NEWLINE);
202
Jacob Erlbeck56595f82013-09-11 10:46:55 +0200203 if (bsc->ussd_no_msc_txt && bsc->ussd_no_msc_txt[0])
204 vty_out(vty, " missing-msc-text %s%s", bsc->ussd_no_msc_txt, VTY_NEWLINE);
205 else
206 vty_out(vty, " no missing-msc-text%s", VTY_NEWLINE);
207
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800208 return CMD_SUCCESS;
209}
210
Holger Hans Peter Freyther5b848f32010-11-03 13:11:14 +0100211DEFUN(cfg_net_bsc_token,
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800212 cfg_net_bsc_token_cmd,
213 "token TOKEN",
Holger Hans Peter Freyther63b0e442013-03-03 09:32:08 +0100214 "A token for the BSC to be sent to the MSC\n" "A token\n")
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800215{
216 struct osmo_msc_data *data = osmo_msc_data(vty);
217
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200218 bsc_replace_string(osmo_bsc_data(vty), &data->bsc_token, argv[0]);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800219 return CMD_SUCCESS;
220}
221
Holger Hans Peter Freyther4de11162010-11-03 13:12:18 +0100222DEFUN(cfg_net_bsc_ncc,
223 cfg_net_bsc_ncc_cmd,
Holger Hans Peter Freyther6e1a6762011-02-10 11:37:13 +0100224 "core-mobile-network-code <1-999>",
Holger Hans Peter Freyther768580b2014-07-08 12:48:49 +0200225 "Use this network code for the core network\n" "NCC value\n")
Holger Hans Peter Freyther4de11162010-11-03 13:12:18 +0100226{
227 struct osmo_msc_data *data = osmo_msc_data(vty);
228 data->core_ncc = atoi(argv[0]);
229 return CMD_SUCCESS;
230}
231
Holger Hans Peter Freyther2a8675e2010-11-05 19:43:07 +0100232DEFUN(cfg_net_bsc_mcc,
233 cfg_net_bsc_mcc_cmd,
Holger Hans Peter Freyther6e1a6762011-02-10 11:37:13 +0100234 "core-mobile-country-code <1-999>",
Holger Hans Peter Freyther768580b2014-07-08 12:48:49 +0200235 "Use this country code for the core network\n" "MCC value\n")
Holger Hans Peter Freyther2a8675e2010-11-05 19:43:07 +0100236{
237 struct osmo_msc_data *data = osmo_msc_data(vty);
238 data->core_mcc = atoi(argv[0]);
239 return CMD_SUCCESS;
240}
241
Holger Hans Peter Freytherfe166222010-11-03 13:32:48 +0100242DEFUN(cfg_net_bsc_rtp_base,
243 cfg_net_bsc_rtp_base_cmd,
244 "ip.access rtp-base <1-65000>",
245 IPA_STR
246 "Set the rtp-base port for the RTP stream\n"
247 "Port number\n")
248{
249 struct osmo_msc_data *data = osmo_msc_data(vty);
250 data->rtp_base = atoi(argv[0]);
251 return CMD_SUCCESS;
252}
253
Holger Hans Peter Freyther7bf66c52010-11-03 13:55:49 +0100254DEFUN(cfg_net_bsc_codec_list,
255 cfg_net_bsc_codec_list_cmd,
256 "codec-list .LIST",
257 "Set the allowed audio codecs\n"
258 "List of audio codecs\n")
259{
260 struct osmo_msc_data *data = osmo_msc_data(vty);
261 int saw_fr, saw_hr;
262 int i;
263
264 saw_fr = saw_hr = 0;
265
266 /* free the old list... if it exists */
267 if (data->audio_support) {
268 talloc_free(data->audio_support);
269 data->audio_support = NULL;
270 data->audio_length = 0;
271 }
272
273 /* create a new array */
274 data->audio_support =
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200275 talloc_zero_array(osmo_bsc_data(vty), struct gsm_audio_support *, argc);
Holger Hans Peter Freyther7bf66c52010-11-03 13:55:49 +0100276 data->audio_length = argc;
277
278 for (i = 0; i < argc; ++i) {
279 /* check for hrX or frX */
280 if (strlen(argv[i]) != 3
281 || argv[i][1] != 'r'
282 || (argv[i][0] != 'h' && argv[i][0] != 'f')
283 || argv[i][2] < 0x30
284 || argv[i][2] > 0x39)
285 goto error;
286
287 data->audio_support[i] = talloc_zero(data->audio_support,
288 struct gsm_audio_support);
289 data->audio_support[i]->ver = atoi(argv[i] + 2);
290
291 if (strncmp("hr", argv[i], 2) == 0) {
292 data->audio_support[i]->hr = 1;
293 saw_hr = 1;
294 } else if (strncmp("fr", argv[i], 2) == 0) {
295 data->audio_support[i]->hr = 0;
296 saw_fr = 1;
297 }
298
299 if (saw_hr && saw_fr) {
300 vty_out(vty, "Can not have full-rate and half-rate codec.%s",
301 VTY_NEWLINE);
302 return CMD_ERR_INCOMPLETE;
303 }
304 }
305
306 return CMD_SUCCESS;
307
308error:
309 vty_out(vty, "Codec name must be hrX or frX. Was '%s'%s",
310 argv[i], VTY_NEWLINE);
311 return CMD_ERR_INCOMPLETE;
312}
313
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200314DEFUN(cfg_net_msc_dest,
315 cfg_net_msc_dest_cmd,
316 "dest A.B.C.D <1-65000> <0-255>",
317 "Add a destination to a MUX/MSC\n"
318 "IP Address\n" "Port\n" "DSCP\n")
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800319{
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200320 struct bsc_msc_dest *dest;
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800321 struct osmo_msc_data *data = osmo_msc_data(vty);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800322
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200323 dest = talloc_zero(osmo_bsc_data(vty), struct bsc_msc_dest);
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200324 if (!dest) {
325 vty_out(vty, "%%Failed to create structure.%s", VTY_NEWLINE);
326 return CMD_WARNING;
327 }
328
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200329 dest->ip = talloc_strdup(dest, argv[0]);
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200330 if (!dest->ip) {
331 vty_out(vty, "%%Failed to copy dest ip.%s", VTY_NEWLINE);
332 talloc_free(dest);
333 return CMD_WARNING;
334 }
335
336 dest->port = atoi(argv[1]);
337 dest->dscp = atoi(argv[2]);
338 llist_add_tail(&dest->list, &data->dests);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800339 return CMD_SUCCESS;
340}
341
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200342DEFUN(cfg_net_msc_no_dest,
343 cfg_net_msc_no_dest_cmd,
344 "no dest A.B.C.D <1-65000> <0-255>",
345 NO_STR "Remove a destination to a MUX/MSC\n"
346 "IP Address\n" "Port\n" "DSCP\n")
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800347{
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200348 struct bsc_msc_dest *dest, *tmp;
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800349 struct osmo_msc_data *data = osmo_msc_data(vty);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800350
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200351 int port = atoi(argv[1]);
352 int dscp = atoi(argv[2]);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800353
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200354 llist_for_each_entry_safe(dest, tmp, &data->dests, list) {
355 if (port != dest->port || dscp != dest->dscp
356 || strcmp(dest->ip, argv[0]) != 0)
357 continue;
358
359 llist_del(&dest->list);
360 talloc_free(dest);
361 }
362
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800363 return CMD_SUCCESS;
364}
365
Holger Hans Peter Freytherdb64f2e2014-10-29 10:06:15 +0100366DEFUN(cfg_net_msc_no_ping_time,
367 cfg_net_msc_no_ping_time_cmd,
368 "no timeout-ping",
369 NO_STR "Disable the ping/pong handling on A-link\n")
370{
371 struct osmo_msc_data *data = osmo_msc_data(vty);
372 data->ping_timeout = -1;
373 return CMD_SUCCESS;
374}
375
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800376DEFUN(cfg_net_msc_ping_time,
377 cfg_net_msc_ping_time_cmd,
Holger Hans Peter Freyther47c624b2014-09-30 16:43:30 +0200378 "timeout-ping <1-2147483647>",
Holger Hans Peter Freyther63b0e442013-03-03 09:32:08 +0100379 "Set the PING interval, negative for not sending PING\n"
380 "Timeout in seconds\n")
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800381{
382 struct osmo_msc_data *data = osmo_msc_data(vty);
383 data->ping_timeout = atoi(argv[0]);
384 return CMD_SUCCESS;
385}
386
387DEFUN(cfg_net_msc_pong_time,
388 cfg_net_msc_pong_time_cmd,
Holger Hans Peter Freyther47c624b2014-09-30 16:43:30 +0200389 "timeout-pong <1-2147483647>",
Holger Hans Peter Freyther63b0e442013-03-03 09:32:08 +0100390 "Set the time to wait for a PONG\n" "Timeout in seconds\n")
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800391{
392 struct osmo_msc_data *data = osmo_msc_data(vty);
393 data->pong_timeout = atoi(argv[0]);
394 return CMD_SUCCESS;
395}
396
Holger Hans Peter Freyther56cb7292014-09-02 17:28:40 +0200397DEFUN(cfg_net_msc_advanced_ping,
398 cfg_net_msc_advanced_ping_cmd,
399 "timeout-ping advanced",
400 "Ping timeout handling\nEnable advanced mode during SCCP\n")
401{
402 struct osmo_msc_data *data = osmo_msc_data(vty);
Holger Hans Peter Freytherdb64f2e2014-10-29 10:06:15 +0100403
404 if (data->ping_timeout == -1) {
405 vty_out(vty, "%%ping handling is disabled. Enable it first.%s",
406 VTY_NEWLINE);
407 return CMD_WARNING;
408 }
409
Holger Hans Peter Freyther56cb7292014-09-02 17:28:40 +0200410 data->advanced_ping = 1;
411 return CMD_SUCCESS;
412}
413
414DEFUN(cfg_no_net_msc_advanced_ping,
415 cfg_no_net_msc_advanced_ping_cmd,
416 "no timeout-ping advanced",
417 NO_STR "Ping timeout handling\nEnable advanced mode during SCCP\n")
418{
419 struct osmo_msc_data *data = osmo_msc_data(vty);
420 data->advanced_ping = 0;
421 return CMD_SUCCESS;
422}
423
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200424DEFUN(cfg_net_msc_welcome_ussd,
425 cfg_net_msc_welcome_ussd_cmd,
426 "bsc-welcome-text .TEXT",
Jacob Erlbeck97e139f2013-08-28 10:16:55 +0200427 "Set the USSD notification to be sent\n" "Text to be sent\n")
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200428{
429 struct osmo_msc_data *data = osmo_msc_data(vty);
430 char *str = argv_concat(argv, argc, 0);
431 if (!str)
432 return CMD_WARNING;
433
434 bsc_replace_string(osmo_bsc_data(vty), &data->ussd_welcome_txt, str);
435 talloc_free(str);
436 return CMD_SUCCESS;
437}
438
Jacob Erlbeck97e139f2013-08-28 10:16:55 +0200439DEFUN(cfg_net_msc_no_welcome_ussd,
440 cfg_net_msc_no_welcome_ussd_cmd,
441 "no bsc-welcome-text",
442 NO_STR "Clear the USSD notification to be sent\n")
443{
444 struct osmo_msc_data *data = osmo_msc_data(vty);
445
446 talloc_free(data->ussd_welcome_txt);
Jacob Erlbeck56595f82013-09-11 10:46:55 +0200447 data->ussd_welcome_txt = NULL;
Jacob Erlbeck97e139f2013-08-28 10:16:55 +0200448
449 return CMD_SUCCESS;
450}
451
Jacob Erlbeck1b894022013-08-28 10:16:54 +0200452DEFUN(cfg_net_msc_lost_ussd,
453 cfg_net_msc_lost_ussd_cmd,
454 "bsc-msc-lost-text .TEXT",
455 "Set the USSD notification to be sent on MSC connection loss\n" "Text to be sent\n")
456{
457 struct osmo_msc_data *data = osmo_msc_data(vty);
458 char *str = argv_concat(argv, argc, 0);
459 if (!str)
460 return CMD_WARNING;
461
462 bsc_replace_string(osmo_bsc_data(vty), &data->ussd_msc_lost_txt, str);
463 talloc_free(str);
464 return CMD_SUCCESS;
465}
466
467DEFUN(cfg_net_msc_no_lost_ussd,
468 cfg_net_msc_no_lost_ussd_cmd,
469 "no bsc-msc-lost-text",
470 NO_STR "Clear the USSD notification to be sent on MSC connection loss\n")
471{
472 struct osmo_msc_data *data = osmo_msc_data(vty);
473
474 talloc_free(data->ussd_msc_lost_txt);
475 data->ussd_msc_lost_txt = 0;
476
477 return CMD_SUCCESS;
478}
479
Jacob Erlbeck56595f82013-09-11 10:46:55 +0200480DEFUN(cfg_net_msc_grace_ussd,
481 cfg_net_msc_grace_ussd_cmd,
482 "bsc-grace-text .TEXT",
483 "Set the USSD notification to be sent when the MSC has entered the grace period\n" "Text to be sent\n")
484{
485 struct osmo_msc_data *data = osmo_msc_data(vty);
486 char *str = argv_concat(argv, argc, 0);
487 if (!str)
488 return CMD_WARNING;
489
490 bsc_replace_string(osmo_bsc_data(vty), &data->ussd_grace_txt, str);
491 talloc_free(str);
492 return CMD_SUCCESS;
493}
494
495DEFUN(cfg_net_msc_no_grace_ussd,
496 cfg_net_msc_no_grace_ussd_cmd,
497 "no bsc-grace-text",
498 NO_STR "Clear the USSD notification to be sent when the MSC has entered the grace period\n")
499{
500 struct osmo_msc_data *data = osmo_msc_data(vty);
501
502 talloc_free(data->ussd_grace_txt);
503 data->ussd_grace_txt = NULL;
504
505 return CMD_SUCCESS;
506}
507
508DEFUN(cfg_net_bsc_missing_msc_ussd,
509 cfg_net_bsc_missing_msc_ussd_cmd,
510 "missing-msc-text .TEXT",
511 "Set the USSD notification to be send when a MSC has not been found.\n" "Text to be sent\n")
512{
513 struct osmo_bsc_data *data = osmo_bsc_data(vty);
514 char *txt = argv_concat(argv, argc, 0);
515 if (!txt)
516 return CMD_WARNING;
517
518 bsc_replace_string(data, &data->ussd_no_msc_txt, txt);
519 talloc_free(txt);
520 return CMD_SUCCESS;
521}
522
523DEFUN(cfg_net_bsc_no_missing_msc_text,
524 cfg_net_bsc_no_missing_msc_text_cmd,
525 "no missing-msc-text",
526 NO_STR "Clear the USSD notification to be send when a MSC has not been found.\n")
527{
528 struct osmo_bsc_data *data = osmo_bsc_data(vty);
529
530 talloc_free(data->ussd_no_msc_txt);
531 data->ussd_no_msc_txt = 0;
532
533 return CMD_SUCCESS;
534}
535
536
Holger Hans Peter Freythercbaa8802011-06-08 16:28:04 +0200537DEFUN(cfg_net_msc_type,
538 cfg_net_msc_type_cmd,
539 "type (normal|local)",
540 "Select the MSC type\n"
541 "Plain GSM MSC\n" "Special MSC for local call routing\n")
542{
543 struct osmo_msc_data *data = osmo_msc_data(vty);
544
545 if (strcmp(argv[0], "normal") == 0)
546 data->type = MSC_CON_TYPE_NORMAL;
547 else if (strcmp(argv[0], "local") == 0)
548 data->type = MSC_CON_TYPE_LOCAL;
549
550 return CMD_SUCCESS;
551}
552
Holger Hans Peter Freyther31b245b2011-06-08 19:27:15 +0200553DEFUN(cfg_net_msc_emerg,
554 cfg_net_msc_emerg_cmd,
555 "allow-emergency (allow|deny)",
556 "Allow CM ServiceRequests with type emergency\n"
557 "Allow\n" "Deny\n")
558{
559 struct osmo_msc_data *data = osmo_msc_data(vty);
560 data->allow_emerg = strcmp("allow", argv[0]) == 0;
561 return CMD_SUCCESS;
562}
563
Holger Hans Peter Freytherd5edc4f2011-06-09 21:54:08 +0200564DEFUN(cfg_net_msc_local_prefix,
565 cfg_net_msc_local_prefix_cmd,
566 "local-prefix REGEXP",
567 "Prefix for local numbers\n" "REGEXP used\n")
568{
569 struct osmo_msc_data *msc = osmo_msc_data(vty);
570
571 if (gsm_parse_reg(msc, &msc->local_pref_reg, &msc->local_pref, argc, argv) != 0) {
572 vty_out(vty, "%%Failed to parse the regexp: '%s'%s",
573 argv[0], VTY_NEWLINE);
574 return CMD_WARNING;
575 }
576
577 return CMD_SUCCESS;
578}
579
Holger Hans Peter Freyther75077952011-08-06 08:31:51 +0200580#define AMR_CONF_STR "AMR Multirate Configuration\n"
581#define AMR_COMMAND(name) \
582 DEFUN(cfg_net_msc_amr_##name, \
583 cfg_net_msc_amr_##name##_cmd, \
584 "amr-config " #name "k (allowed|forbidden)", \
585 AMR_CONF_STR "Bitrate\n" "Allowed\n" "Forbidden\n") \
586{ \
587 struct osmo_msc_data *msc = osmo_msc_data(vty); \
588 \
589 msc->amr_conf.m##name = strcmp(argv[0], "allowed") == 0; \
590 return CMD_SUCCESS; \
591}
592
593AMR_COMMAND(12_2)
594AMR_COMMAND(10_2)
595AMR_COMMAND(7_95)
596AMR_COMMAND(7_40)
597AMR_COMMAND(6_70)
598AMR_COMMAND(5_90)
599AMR_COMMAND(5_15)
600AMR_COMMAND(4_75)
601
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200602DEFUN(cfg_net_bsc_mid_call_text,
603 cfg_net_bsc_mid_call_text_cmd,
Holger Hans Peter Freytherbb62b3f2010-11-22 18:30:21 +0100604 "mid-call-text .TEXT",
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800605 "Set the USSD notifcation to be send.\n" "Text to be sent\n")
606{
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200607 struct osmo_bsc_data *data = osmo_bsc_data(vty);
Holger Hans Peter Freyther414bc4a2010-11-22 22:27:39 +0100608 char *txt = argv_concat(argv, argc, 0);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800609 if (!txt)
610 return CMD_WARNING;
611
Holger Hans Peter Freytherbb62b3f2010-11-22 18:30:21 +0100612 bsc_replace_string(data, &data->mid_call_txt, txt);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800613 talloc_free(txt);
614 return CMD_SUCCESS;
615}
Holger Hans Peter Freythercacbc732010-06-30 14:59:23 +0800616
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200617DEFUN(cfg_net_bsc_mid_call_timeout,
618 cfg_net_bsc_mid_call_timeout_cmd,
Holger Hans Peter Freytherbb62b3f2010-11-22 18:30:21 +0100619 "mid-call-timeout NR",
Holger Hans Peter Freyther625b6e42010-11-22 18:25:02 +0100620 "Switch from Grace to Off in NR seconds.\n" "Timeout in seconds\n")
621{
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200622 struct osmo_bsc_data *data = osmo_bsc_data(vty);
Holger Hans Peter Freytherbb62b3f2010-11-22 18:30:21 +0100623 data->mid_call_timeout = atoi(argv[0]);
Holger Hans Peter Freyther625b6e42010-11-22 18:25:02 +0100624 return CMD_SUCCESS;
625}
626
Holger Hans Peter Freyther55ef5fb2011-04-07 23:23:27 +0200627DEFUN(cfg_net_rf_socket,
628 cfg_net_rf_socket_cmd,
629 "bsc-rf-socket PATH",
630 "Set the filename for the RF control interface.\n" "RF Control path\n")
631{
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200632 struct osmo_bsc_data *data = osmo_bsc_data(vty);
Holger Hans Peter Freyther55ef5fb2011-04-07 23:23:27 +0200633
634 bsc_replace_string(data, &data->rf_ctrl_name, argv[0]);
635 return CMD_SUCCESS;
636}
637
Holger Hans Peter Freyther2a896072011-08-16 19:47:39 +0200638DEFUN(cfg_net_rf_off_time,
639 cfg_net_rf_off_time_cmd,
640 "bsc-auto-rf-off <1-65000>",
641 "Disable RF on MSC Connection\n" "Timeout\n")
642{
643 struct osmo_bsc_data *data = osmo_bsc_data(vty);
644 data->auto_off_timeout = atoi(argv[0]);
645 return CMD_SUCCESS;
646}
647
648DEFUN(cfg_net_no_rf_off_time,
649 cfg_net_no_rf_off_time_cmd,
650 "no bsc-auto-rf-off",
651 NO_STR "Disable RF on MSC Connection\n")
652{
653 struct osmo_bsc_data *data = osmo_bsc_data(vty);
654 data->auto_off_timeout = -1;
655 return CMD_SUCCESS;
656}
657
Holger Hans Peter Freyther286ba0e2011-05-03 18:12:39 +0200658DEFUN(show_statistics,
659 show_statistics_cmd,
660 "show statistics",
661 SHOW_STR "Statistics about the BSC\n")
662{
663 openbsc_vty_print_statistics(vty, bsc_gsmnet);
664 return CMD_SUCCESS;
665}
666
Holger Hans Peter Freytherc50e04a2011-10-20 11:06:31 +0200667DEFUN(show_mscs,
668 show_mscs_cmd,
669 "show mscs",
670 SHOW_STR "MSC Connections and State\n")
671{
672 struct osmo_msc_data *msc;
673 llist_for_each_entry(msc, &bsc_gsmnet->bsc_data->mscs, entry) {
674 vty_out(vty, "MSC Nr: %d is connected: %d auth: %d.%s",
675 msc->nr,
676 msc->msc_con ? msc->msc_con->is_connected : -1,
677 msc->msc_con ? msc->msc_con->is_authenticated : -1,
678 VTY_NEWLINE);
679 }
680
681 return CMD_SUCCESS;
682}
683
Daniel Willmann7d109832012-05-14 18:43:23 +0200684DEFUN(show_pos,
685 show_pos_cmd,
686 "show position",
687 SHOW_STR "Position information of the BTS\n")
688{
689 struct gsm_bts *bts;
690 struct bts_location *curloc;
691 struct tm time;
692 char timestr[50];
693
694 llist_for_each_entry(bts, &bsc_gsmnet->bts_list, list) {
695 if (llist_empty(&bts->loc_list)) {
696 vty_out(vty, "BTS Nr: %d position invalid%s", bts->nr,
697 VTY_NEWLINE);
698 continue;
699 }
700 curloc = llist_entry(bts->loc_list.next, struct bts_location, list);
701 if (gmtime_r(&curloc->tstamp, &time) == NULL) {
702 vty_out(vty, "Time conversion failed for BTS %d%s", bts->nr,
703 VTY_NEWLINE);
704 continue;
705 }
706 if (asctime_r(&time, timestr) == NULL) {
707 vty_out(vty, "Time conversion failed for BTS %d%s", bts->nr,
708 VTY_NEWLINE);
709 continue;
710 }
711 /* Last character in asctime is \n */
712 timestr[strlen(timestr)-1] = 0;
713
714 vty_out(vty, "BTS Nr: %d position: %s time: %s%s", bts->nr,
715 get_value_string(bts_loc_fix_names, curloc->valid), timestr,
716 VTY_NEWLINE);
717 vty_out(vty, " lat: %f lon: %f height: %f%s", curloc->lat, curloc->lon,
718 curloc->height, VTY_NEWLINE);
719 }
720 return CMD_SUCCESS;
721}
722
Holger Hans Peter Freyther98258db2014-02-22 10:30:32 +0100723DEFUN(gen_position_trap,
724 gen_position_trap_cmd,
725 "generate-location-state-trap <0-255>",
726 "Generate location state report\n"
727 "BTS to report\n")
728{
729 int bts_nr;
730 struct gsm_bts *bts;
731 struct gsm_network *net = bsc_gsmnet;
732
733 bts_nr = atoi(argv[0]);
734 if (bts_nr >= net->num_bts) {
735 vty_out(vty, "%% can't find BTS '%s'%s", argv[0],
736 VTY_NEWLINE);
737 return CMD_WARNING;
738 }
739
740 bts = gsm_bts_num(net, bts_nr);
741 bsc_gen_location_state_trap(bts);
742 return CMD_SUCCESS;
743}
744
Holger Hans Peter Freyther6995f242014-12-28 18:54:32 +0100745DEFUN(logging_fltr_imsi,
746 logging_fltr_imsi_cmd,
747 "logging filter imsi IMSI",
748 LOGGING_STR FILTER_STR
749 "Filter log messages by IMSI\n" "IMSI to be used as filter\n")
750{
751 struct gsm_subscriber *subscr;
752 struct log_target *tgt = osmo_log_vty2tgt(vty);
753
754 if (!tgt)
755 return CMD_WARNING;
756
757 subscr = subscr_get_or_create(bsc_gsmnet->subscr_group, argv[0]);
758 if (!subscr) {
759 vty_out(vty, "%%no subscriber with IMSI(%s)%s",
760 argv[0], VTY_NEWLINE);
761 return CMD_WARNING;
762 }
763
764 log_set_imsi_filter(tgt, subscr);
765 return CMD_SUCCESS;
766}
767
Holger Hans Peter Freythercacbc732010-06-30 14:59:23 +0800768int bsc_vty_init_extra(void)
769{
Holger Hans Peter Freyther06f4fc72011-03-29 17:46:14 +0200770 install_element(CONFIG_NODE, &cfg_net_msc_cmd);
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200771 install_element(CONFIG_NODE, &cfg_net_bsc_cmd);
772
773 install_node(&bsc_node, config_write_bsc);
Jacob Erlbeck36722e12013-10-29 09:30:30 +0100774 vty_install_default(BSC_NODE);
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200775 install_element(BSC_NODE, &cfg_net_bsc_mid_call_text_cmd);
776 install_element(BSC_NODE, &cfg_net_bsc_mid_call_timeout_cmd);
777 install_element(BSC_NODE, &cfg_net_rf_socket_cmd);
Holger Hans Peter Freyther2a896072011-08-16 19:47:39 +0200778 install_element(BSC_NODE, &cfg_net_rf_off_time_cmd);
779 install_element(BSC_NODE, &cfg_net_no_rf_off_time_cmd);
Jacob Erlbeck56595f82013-09-11 10:46:55 +0200780 install_element(BSC_NODE, &cfg_net_bsc_missing_msc_ussd_cmd);
781 install_element(BSC_NODE, &cfg_net_bsc_no_missing_msc_text_cmd);
Holger Hans Peter Freyther8b902d72011-06-04 20:22:49 +0200782
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800783 install_node(&msc_node, config_write_msc);
Jacob Erlbeck36722e12013-10-29 09:30:30 +0100784 vty_install_default(MSC_NODE);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800785 install_element(MSC_NODE, &cfg_net_bsc_token_cmd);
Holger Hans Peter Freyther4de11162010-11-03 13:12:18 +0100786 install_element(MSC_NODE, &cfg_net_bsc_ncc_cmd);
Holger Hans Peter Freyther2a8675e2010-11-05 19:43:07 +0100787 install_element(MSC_NODE, &cfg_net_bsc_mcc_cmd);
Holger Hans Peter Freytherfe166222010-11-03 13:32:48 +0100788 install_element(MSC_NODE, &cfg_net_bsc_rtp_base_cmd);
Holger Hans Peter Freyther7bf66c52010-11-03 13:55:49 +0100789 install_element(MSC_NODE, &cfg_net_bsc_codec_list_cmd);
Holger Hans Peter Freythere18801052011-04-23 23:31:31 +0200790 install_element(MSC_NODE, &cfg_net_msc_dest_cmd);
791 install_element(MSC_NODE, &cfg_net_msc_no_dest_cmd);
Holger Hans Peter Freytherdb64f2e2014-10-29 10:06:15 +0100792 install_element(MSC_NODE, &cfg_net_msc_no_ping_time_cmd);
Holger Hans Peter Freyther47b26012010-09-15 23:28:49 +0800793 install_element(MSC_NODE, &cfg_net_msc_ping_time_cmd);
794 install_element(MSC_NODE, &cfg_net_msc_pong_time_cmd);
Holger Hans Peter Freyther56cb7292014-09-02 17:28:40 +0200795 install_element(MSC_NODE, &cfg_net_msc_advanced_ping_cmd);
796 install_element(MSC_NODE, &cfg_no_net_msc_advanced_ping_cmd);
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200797 install_element(MSC_NODE, &cfg_net_msc_welcome_ussd_cmd);
Jacob Erlbeck97e139f2013-08-28 10:16:55 +0200798 install_element(MSC_NODE, &cfg_net_msc_no_welcome_ussd_cmd);
Jacob Erlbeck1b894022013-08-28 10:16:54 +0200799 install_element(MSC_NODE, &cfg_net_msc_lost_ussd_cmd);
800 install_element(MSC_NODE, &cfg_net_msc_no_lost_ussd_cmd);
Jacob Erlbeck56595f82013-09-11 10:46:55 +0200801 install_element(MSC_NODE, &cfg_net_msc_grace_ussd_cmd);
802 install_element(MSC_NODE, &cfg_net_msc_no_grace_ussd_cmd);
Holger Hans Peter Freythercbaa8802011-06-08 16:28:04 +0200803 install_element(MSC_NODE, &cfg_net_msc_type_cmd);
Holger Hans Peter Freyther31b245b2011-06-08 19:27:15 +0200804 install_element(MSC_NODE, &cfg_net_msc_emerg_cmd);
Holger Hans Peter Freytherd5edc4f2011-06-09 21:54:08 +0200805 install_element(MSC_NODE, &cfg_net_msc_local_prefix_cmd);
Holger Hans Peter Freyther75077952011-08-06 08:31:51 +0200806 install_element(MSC_NODE, &cfg_net_msc_amr_12_2_cmd);
807 install_element(MSC_NODE, &cfg_net_msc_amr_10_2_cmd);
808 install_element(MSC_NODE, &cfg_net_msc_amr_7_95_cmd);
809 install_element(MSC_NODE, &cfg_net_msc_amr_7_40_cmd);
810 install_element(MSC_NODE, &cfg_net_msc_amr_6_70_cmd);
811 install_element(MSC_NODE, &cfg_net_msc_amr_5_90_cmd);
812 install_element(MSC_NODE, &cfg_net_msc_amr_5_15_cmd);
813 install_element(MSC_NODE, &cfg_net_msc_amr_4_75_cmd);
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200814
Holger Hans Peter Freyther286ba0e2011-05-03 18:12:39 +0200815 install_element_ve(&show_statistics_cmd);
Holger Hans Peter Freytherc50e04a2011-10-20 11:06:31 +0200816 install_element_ve(&show_mscs_cmd);
Daniel Willmann7d109832012-05-14 18:43:23 +0200817 install_element_ve(&show_pos_cmd);
Holger Hans Peter Freyther6995f242014-12-28 18:54:32 +0100818 install_element_ve(&logging_fltr_imsi_cmd);
Holger Hans Peter Freyther286ba0e2011-05-03 18:12:39 +0200819
Holger Hans Peter Freyther98258db2014-02-22 10:30:32 +0100820 install_element(ENABLE_NODE, &gen_position_trap_cmd);
821
Holger Hans Peter Freyther6995f242014-12-28 18:54:32 +0100822 install_element(CFG_LOG_NODE, &logging_fltr_imsi_cmd);
823
Holger Hans Peter Freythercacbc732010-06-30 14:59:23 +0800824 return 0;
825}