blob: db2a659e4f6f16f4dc566b14903f8ee6aed6f6e8 [file] [log] [blame]
Harald Welte52b1f982008-12-23 20:25:15 +00001/* GSM Network Management messages on the A-bis interface
2 * 3GPP TS 12.21 version 8.0.0 Release 1999 / ETSI TS 100 623 V8.0.0 */
3
Harald Welte4724f992009-01-18 18:01:49 +00004/* (C) 2008-2009 by Harald Welte <laforge@gnumonks.org>
Harald Welte52b1f982008-12-23 20:25:15 +00005 * All Rights Reserved
6 *
7 * This program is free software; you can redistribute it and/or modify
Harald Welte9af6ddf2011-01-01 15:25:50 +01008 * it under the terms of the GNU Affero General Public License as published by
9 * the Free Software Foundation; either version 3 of the License, or
Harald Welte52b1f982008-12-23 20:25:15 +000010 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
Harald Welte9af6ddf2011-01-01 15:25:50 +010015 * GNU Affero General Public License for more details.
Harald Welte52b1f982008-12-23 20:25:15 +000016 *
Harald Welte9af6ddf2011-01-01 15:25:50 +010017 * You should have received a copy of the GNU Affero General Public License
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
Harald Welte52b1f982008-12-23 20:25:15 +000019 *
20 */
21
22#ifndef _NM_H
23#define _NM_H
24
Pablo Neira Ayuso136f4532011-03-22 16:47:59 +010025#include <osmocom/gsm/tlv.h>
Harald Welte472e7e92011-06-05 11:24:08 +020026#include <osmocom/gsm/abis_nm.h>
Pablo Neira Ayuso136f4532011-03-22 16:47:59 +010027#include <osmocom/gsm/protocol/gsm_12_21.h>
Harald Welte0f255852009-11-12 14:48:42 +010028
Neels Hofmeyr2d521a02016-05-14 00:57:04 +020029#include <openbsc/gsm_data.h>
30
Max1ebf23b2017-05-10 12:21:17 +020031/* max number of attributes represented as 3GPP TS 52.021 ยง9.4.62 SW Description array */
32#define MAX_BTS_ATTR 5
33
Harald Welteb40a38f2009-11-13 11:56:05 +010034struct cell_global_id {
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020035 uint16_t mcc;
36 uint16_t mnc;
37 uint16_t lac;
38 uint16_t ci;
Harald Welteb40a38f2009-11-13 11:56:05 +010039};
40
Harald Welte0f255852009-11-12 14:48:42 +010041/* The BCCH info from an ip.access test, in host byte order
42 * and already parsed... */
43struct ipac_bcch_info {
Harald Welteb40a38f2009-11-13 11:56:05 +010044 struct llist_head list;
45
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020046 uint16_t info_type;
47 uint8_t freq_qual;
48 uint16_t arfcn;
49 uint8_t rx_lev;
50 uint8_t rx_qual;
Harald Welteaff237d2009-11-13 14:41:52 +010051 int16_t freq_err;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020052 uint16_t frame_offset;
53 uint32_t frame_nr_offset;
54 uint8_t bsic;
Harald Welteb40a38f2009-11-13 11:56:05 +010055 struct cell_global_id cgi;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020056 uint8_t ba_list_si2[16];
57 uint8_t ba_list_si2bis[16];
58 uint8_t ba_list_si2ter[16];
59 uint8_t ca_list_si1[16];
Harald Welte0f255852009-11-12 14:48:42 +010060};
61
Harald Welte52b1f982008-12-23 20:25:15 +000062/* PUBLIC */
63
64struct msgb;
65
66struct abis_nm_cfg {
67 /* callback for unidirectional reports */
68 int (*report_cb)(struct msgb *,
69 struct abis_om_fom_hdr *);
70 /* callback for software activate requests from BTS */
71 int (*sw_act_req)(struct msgb *);
72};
73
Harald Welte8470bf22008-12-25 23:28:35 +000074extern int abis_nm_rcvmsg(struct msgb *msg);
Harald Welte52b1f982008-12-23 20:25:15 +000075
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020076int abis_nm_tlv_parse(struct tlv_parsed *tp, struct gsm_bts *bts, const uint8_t *buf, int len);
Harald Welte52b1f982008-12-23 20:25:15 +000077int abis_nm_rx(struct msgb *msg);
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020078int abis_nm_opstart(struct gsm_bts *bts, uint8_t obj_class, uint8_t i0, uint8_t i1, uint8_t i2);
79int abis_nm_chg_adm_state(struct gsm_bts *bts, uint8_t obj_class, uint8_t i0,
80 uint8_t i1, uint8_t i2, enum abis_nm_adm_state adm_state);
81int abis_nm_establish_tei(struct gsm_bts *bts, uint8_t trx_nr,
82 uint8_t e1_port, uint8_t e1_timeslot, uint8_t e1_subslot,
83 uint8_t tei);
Harald Welte52b1f982008-12-23 20:25:15 +000084int abis_nm_conn_terr_sign(struct gsm_bts_trx *trx,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020085 uint8_t e1_port, uint8_t e1_timeslot, uint8_t e1_subslot);
Harald Welte52b1f982008-12-23 20:25:15 +000086int abis_nm_conn_terr_traf(struct gsm_bts_trx_ts *ts,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020087 uint8_t e1_port, uint8_t e1_timeslot,
88 uint8_t e1_subslot);
Harald Weltefe568f22012-08-14 19:15:57 +020089int abis_nm_get_attr(struct gsm_bts *bts, uint8_t obj_class,
90 uint8_t bts_nr, uint8_t trx_nr, uint8_t ts_nr,
Max1ebf23b2017-05-10 12:21:17 +020091 const uint8_t *attr, uint8_t attr_len);
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020092int abis_nm_set_bts_attr(struct gsm_bts *bts, uint8_t *attr, int attr_len);
93int abis_nm_set_radio_attr(struct gsm_bts_trx *trx, uint8_t *attr, int attr_len);
94int abis_nm_set_channel_attr(struct gsm_bts_trx_ts *ts, uint8_t chan_comb);
95int abis_nm_sw_act_req_ack(struct gsm_bts *bts, uint8_t obj_class, uint8_t i1,
96 uint8_t i2, uint8_t i3, int nack, uint8_t *attr, int att_len);
97int abis_nm_raw_msg(struct gsm_bts *bts, int len, uint8_t *msg);
Harald Welte52b1f982008-12-23 20:25:15 +000098int abis_nm_event_reports(struct gsm_bts *bts, int on);
99int abis_nm_reset_resource(struct gsm_bts *bts);
Holger Hans Peter Freyther64278ed2010-05-12 23:51:46 +0800100int abis_nm_software_load(struct gsm_bts *bts, int trx_nr, const char *fname,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200101 uint8_t win_size, int forced,
Harald Welte3ffd1372009-02-01 22:15:49 +0000102 gsm_cbfn *cbfn, void *cb_data);
103int abis_nm_software_load_status(struct gsm_bts *bts);
Harald Welte5e4d1b32009-02-01 13:36:56 +0000104int abis_nm_software_activate(struct gsm_bts *bts, const char *fname,
105 gsm_cbfn *cbfn, void *cb_data);
Harald Welte47d88ae2009-01-04 12:02:08 +0000106
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200107int abis_nm_conn_mdrop_link(struct gsm_bts *bts, uint8_t e1_port0, uint8_t ts0,
108 uint8_t e1_port1, uint8_t ts1);
Harald Welte1989c082009-08-06 17:58:31 +0200109
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200110int abis_nm_perform_test(struct gsm_bts *bts, uint8_t obj_class,
111 uint8_t bts_nr, uint8_t trx_nr, uint8_t ts_nr,
112 uint8_t test_nr, uint8_t auton_report, struct msgb *msg);
Harald Weltec7310382009-08-08 00:02:36 +0200113
Harald Welte47d88ae2009-01-04 12:02:08 +0000114/* Siemens / BS-11 specific */
Holger Freyther245c5342009-01-27 19:00:44 +0000115int abis_nm_bs11_reset_resource(struct gsm_bts *bts);
Harald Welte05188ee2009-01-18 11:39:08 +0000116int abis_nm_bs11_db_transmission(struct gsm_bts *bts, int begin);
117int abis_nm_bs11_create_object(struct gsm_bts *bts, enum abis_bs11_objtype type,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200118 uint8_t idx, uint8_t attr_len, const uint8_t *attr);
119int abis_nm_bs11_create_envaBTSE(struct gsm_bts *bts, uint8_t idx);
120int abis_nm_bs11_create_bport(struct gsm_bts *bts, uint8_t idx);
Harald Welte78fc0d42009-02-19 02:50:57 +0000121int abis_nm_bs11_delete_object(struct gsm_bts *bts,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200122 enum abis_bs11_objtype type, uint8_t idx);
123int abis_nm_bs11_delete_bport(struct gsm_bts *bts, uint8_t idx);
124int abis_nm_bs11_conn_oml_tei(struct gsm_bts *bts, uint8_t e1_port,
125 uint8_t e1_timeslot, uint8_t e1_subslot, uint8_t tei);
Harald Welte78fc0d42009-02-19 02:50:57 +0000126int abis_nm_bs11_get_oml_tei_ts(struct gsm_bts *bts);
127int abis_nm_bs11_get_serno(struct gsm_bts *bts);
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200128int abis_nm_bs11_set_trx_power(struct gsm_bts_trx *trx, uint8_t level);
Harald Welte78fc0d42009-02-19 02:50:57 +0000129int abis_nm_bs11_get_trx_power(struct gsm_bts_trx *trx);
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200130int abis_nm_bs11_logon(struct gsm_bts *bts, uint8_t level, const char *name, int on);
Harald Welte1bc09062009-01-18 14:17:52 +0000131int abis_nm_bs11_factory_logon(struct gsm_bts *bts, int on);
Daniel Willmann4b054c82010-01-07 00:46:26 +0100132int abis_nm_bs11_infield_logon(struct gsm_bts *bts, int on);
Harald Welte1bc09062009-01-18 14:17:52 +0000133int abis_nm_bs11_set_trx1_pw(struct gsm_bts *bts, const char *password);
Harald Weltee69f5fb2009-04-28 16:31:38 +0000134int abis_nm_bs11_set_pll_locked(struct gsm_bts *bts, int locked);
Harald Welteef061952009-05-17 12:43:42 +0000135int abis_nm_bs11_get_pll_mode(struct gsm_bts *bts);
Daniel Willmann7b1dd742010-01-07 00:54:01 +0100136int abis_nm_bs11_set_pll(struct gsm_bts *bts, int value);
Harald Welteef061952009-05-17 12:43:42 +0000137int abis_nm_bs11_get_cclk(struct gsm_bts *bts);
Harald Welte1bc09062009-01-18 14:17:52 +0000138int abis_nm_bs11_get_state(struct gsm_bts *bts);
Harald Welte5e4d1b32009-02-01 13:36:56 +0000139int abis_nm_bs11_load_swl(struct gsm_bts *bts, const char *fname,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200140 uint8_t win_size, int forced, gsm_cbfn *cbfn);
Harald Welte268bb402009-02-01 19:11:56 +0000141int abis_nm_bs11_set_ext_time(struct gsm_bts *bts);
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200142int abis_nm_bs11_get_bport_line_cfg(struct gsm_bts *bts, uint8_t bport);
143int abis_nm_bs11_set_bport_line_cfg(struct gsm_bts *bts, uint8_t bport, enum abis_bs11_line_cfg line_cfg);
Harald Welte3ffd1372009-02-01 22:15:49 +0000144int abis_nm_bs11_bsc_disconnect(struct gsm_bts *bts, int reconnect);
Harald Welte1fa60c82009-02-09 18:13:26 +0000145int abis_nm_bs11_restart(struct gsm_bts *bts);
Harald Welte52b1f982008-12-23 20:25:15 +0000146
Harald Welte5c1e4582009-02-15 11:57:29 +0000147/* ip.access nanoBTS specific commands */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200148int abis_nm_ipaccess_msg(struct gsm_bts *bts, uint8_t msg_type,
149 uint8_t obj_class, uint8_t bts_nr,
150 uint8_t trx_nr, uint8_t ts_nr,
151 uint8_t *attr, int attr_len);
152int abis_nm_ipaccess_set_nvattr(struct gsm_bts_trx *trx, uint8_t *attr,
Harald Welte193fefc2009-04-30 15:16:27 +0000153 int attr_len);
Holger Hans Peter Freyther52fd4e42010-05-12 23:34:51 +0800154int abis_nm_ipaccess_restart(struct gsm_bts_trx *trx);
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200155int abis_nm_ipaccess_set_attr(struct gsm_bts *bts, uint8_t obj_class,
156 uint8_t bts_nr, uint8_t trx_nr, uint8_t ts_nr,
157 uint8_t *attr, uint8_t attr_len);
Harald Welte746d6092009-10-19 22:11:11 +0200158int abis_nm_ipaccess_rsl_connect(struct gsm_bts_trx *trx,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200159 uint32_t ip, uint16_t port, uint8_t stream);
160void abis_nm_ipaccess_cgi(uint8_t *buf, struct gsm_bts *bts);
161int ipac_parse_bcch_info(struct ipac_bcch_info *binf, uint8_t *buf);
162const char *ipacc_testres_name(uint8_t res);
Harald Welte5c1e4582009-02-15 11:57:29 +0000163
Harald Weltee0590df2009-02-15 03:34:15 +0000164/* Functions calling into other code parts */
Sylvain Munaut1f6c11f2010-01-02 16:32:17 +0100165int nm_is_running(struct gsm_nm_state *s);
Harald Welte81c9b9c2010-05-31 16:40:40 +0200166
167int abis_nm_vty_init(void);
168
Holger Hans Peter Freyther6f615552010-11-15 20:50:42 +0100169void abis_nm_clear_queue(struct gsm_bts *bts);
170
Harald Welte15eae8d2011-09-26 23:43:23 +0200171int _abis_nm_sendmsg(struct msgb *msg);
Pablo Neira Ayusoed5cacb2011-08-17 22:44:07 +0200172
173void abis_nm_queue_send_next(struct gsm_bts *bts); /* for bs11_config. */
Holger Hans Peter Freyther6f615552010-11-15 20:50:42 +0100174
Maxfd2c1f92017-03-24 21:04:57 +0100175int abis_nm_select_newest_sw(const struct abis_nm_sw_desc *sw, const size_t len);
Holger Hans Peter Freytherbce56752012-11-22 14:59:46 +0100176
Holger Hans Peter Freyther8a158bb2014-03-26 14:24:42 +0100177/* Helper functions for updating attributes */
178int abis_nm_update_max_power_red(struct gsm_bts_trx *trx);
179
Harald Welte52b1f982008-12-23 20:25:15 +0000180#endif /* _NM_H */