blob: ed2a95c1cc3f862fb84c6c651d1d9a72f22191ae [file] [log] [blame]
Harald Welte52b1f982008-12-23 20:25:15 +00001#ifndef _GSM_DATA_H
2#define _GSM_DATA_H
3
Harald Weltef142c972011-05-24 13:25:38 +02004#include <stdint.h>
Maxddee01f2016-05-24 14:23:27 +02005#include <regex.h>
6#include <sys/types.h>
Maxe6052c42016-06-30 10:25:49 +02007#include <stdbool.h>
Harald Weltef142c972011-05-24 13:25:38 +02008
9#include <osmocom/core/timer.h>
Alexander Couzens20423ea2016-07-12 15:42:02 +020010#include <osmocom/core/rate_ctr.h>
Harald Welte6be350c2011-05-25 13:10:08 +020011#include <osmocom/core/select.h>
Alexander Couzens20423ea2016-07-12 15:42:02 +020012#include <osmocom/core/stats.h>
13
Harald Welte121e9a42016-04-20 13:13:19 +020014#include <osmocom/crypt/auth.h>
Harald Weltef142c972011-05-24 13:25:38 +020015
Neels Hofmeyrc0164792017-09-04 15:15:32 +020016#include <osmocom/bsc/common.h>
17#include <osmocom/bsc/rest_octets.h>
18#include <osmocom/bsc/common_cs.h>
Harald Welteb96be392011-05-25 12:33:33 +020019
Harald Welte74b8cdb2018-01-15 19:26:06 +010020struct mgcp_client_conf;
21struct mgcp_client;
22struct mgcp_ctx;
Philipp Maier39f62bb2017-04-09 12:32:51 +020023
Holger Hans Peter Freytherd7b22c62013-04-29 09:11:02 +020024/** annotations for msgb ownership */
25#define __uses
26
Holger Hans Peter Freyther6f615552010-11-15 20:50:42 +010027#define OBSC_NM_W_ACK_CB(__msgb) (__msgb)->cb[3]
28
Neels Hofmeyr6d804b12017-02-18 22:20:46 +010029struct bsc_subscr;
Neels Hofmeyr7b656882017-07-09 22:09:18 +020030struct gprs_ra_id;
Holger Hans Peter Freyther694c82d2011-10-26 18:37:09 +020031
Holger Hans Peter Freyther9c595b72010-06-15 11:20:52 +080032#define OBSC_LINKID_CB(__msgb) (__msgb)->cb[3]
33
Neels Hofmeyr0e5d8072017-01-10 00:49:56 +010034#define tmsi_from_string(str) strtoul(str, NULL, 10)
35
Max70fdd242017-06-15 15:10:53 +020036/* 3-bit long values */
37#define EARFCN_PRIO_INVALID 8
38#define EARFCN_MEAS_BW_INVALID 8
39/* 5-bit long values */
40#define EARFCN_QRXLV_INVALID 32
41#define EARFCN_THRESH_LOW_INVALID 32
42
Harald Welte8e1e3ee2009-02-01 13:32:45 +000043struct msgb;
44typedef int gsm_cbfn(unsigned int hooknum,
45 unsigned int event,
46 struct msgb *msg,
47 void *data, void *param);
48
Harald Weltef7c28b02009-12-21 13:30:17 +010049/* Maximum number of neighbor cells whose average we track */
50#define MAX_NEIGH_MEAS 10
51/* Maximum size of the averaging window for neighbor cells */
52#define MAX_WIN_NEIGH_AVG 10
53
54/* processed neighbor measurements for one cell */
55struct neigh_meas_proc {
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020056 uint16_t arfcn;
57 uint8_t bsic;
58 uint8_t rxlev[MAX_WIN_NEIGH_AVG];
Harald Weltef7c28b02009-12-21 13:30:17 +010059 unsigned int rxlev_cnt;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020060 uint8_t last_seen_nr;
Harald Weltef7c28b02009-12-21 13:30:17 +010061};
62
Harald Weltea43e0b42016-06-19 18:06:02 +020063struct gsm_classmark {
64 bool classmark1_set;
65 struct gsm48_classmark1 classmark1;
66 uint8_t classmark2_len;
67 uint8_t classmark2[3];
68 uint8_t classmark3_len;
69 uint8_t classmark3[14]; /* if cm3 gets extended by spec, it will be truncated */
70};
71
Neels Hofmeyr378a4922016-05-09 21:07:43 +020072/* active radio connection of a mobile subscriber */
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +010073struct gsm_subscriber_connection {
Harald Weltea43e0b42016-06-19 18:06:02 +020074 /* global linked list of subscriber_connections */
Holger Hans Peter Freyther79f763f2010-09-16 00:53:37 +080075 struct llist_head entry;
76
Harald Weltea43e0b42016-06-19 18:06:02 +020077 /* libbsc subscriber information (if available) */
Neels Hofmeyr6d804b12017-02-18 22:20:46 +010078 struct bsc_subscr *bsub;
79
Harald Welte4a8ebc82017-12-18 18:34:41 +010080 /* SCCP connection associatd with this subscriber_connection */
81 struct osmo_bsc_sccp_con *sccp_con;
Holger Hans Peter Freyther2f9d1ef2010-09-16 20:14:01 +080082
Holger Hans Peter Freyther18b63f42010-03-23 07:52:17 +010083 /* back pointers */
Neels Hofmeyr5e0b0a62016-05-09 22:33:01 +020084 struct gsm_network *network;
85
Harald Welte4a8ebc82017-12-18 18:34:41 +010086 /* the primary / currently active lchan to the BTS/subscriber */
87 struct gsm_lchan *lchan;
88 /* the future/allocated but not yet used lchan during HANDOVER */
89 struct gsm_lchan *ho_lchan;
90 /* a short-hand pointer to the BTS currently serving the subscriber,
91 * points to gsm_subscriber_connection.lchan->ts->trx->bts */
92 struct gsm_bts *bts;
Holger Hans Peter Freyther77cd95d2010-11-14 16:19:48 +010093
Harald Welte4a8ebc82017-12-18 18:34:41 +010094 /* timer for assignment handling */
95 struct osmo_timer_list T10;
96 /* the future allocated but not yet used lchan during ASSIGNMENT */
97 struct gsm_lchan *secondary_lchan;
Holger Hans Peter Freyther77cd95d2010-11-14 16:19:48 +010098
Harald Welte4a8ebc82017-12-18 18:34:41 +010099 /* buffer/cache for classmark of the ME of the subscriber */
Harald Weltea43e0b42016-06-19 18:06:02 +0200100 struct gsm_classmark classmark;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100101};
102
Harald Welte148ee362017-12-18 18:44:25 +0100103static inline struct gsm_bts *conn_get_bts(struct gsm_subscriber_connection *conn) {
104 return conn->bts;
105}
106
Harald Weltef142c972011-05-24 13:25:38 +0200107
Harald Welte6be350c2011-05-25 13:10:08 +0200108#include "gsm_data_shared.h"
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100109
Harald Welted82101e2017-12-09 23:07:38 +0100110enum {
111 BTS_CTR_CHREQ_TOTAL,
112 BTS_CTR_CHREQ_NO_CHANNEL,
113 BTS_CTR_CHAN_RF_FAIL,
114 BTS_CTR_CHAN_RLL_ERR,
115 BTS_CTR_BTS_OML_FAIL,
116 BTS_CTR_BTS_RSL_FAIL,
117 BTS_CTR_CODEC_AMR_F,
118 BTS_CTR_CODEC_AMR_H,
119 BTS_CTR_CODEC_EFR,
120 BTS_CTR_CODEC_V1_FR,
121 BTS_CTR_CODEC_V1_HR,
Harald Weltecf9d4312017-12-13 23:17:16 +0100122 BTS_CTR_PAGING_ATTEMPTED,
123 BTS_CTR_PAGING_ALREADY,
124 BTS_CTR_PAGING_RESPONDED,
125 BTS_CTR_PAGING_EXPIRED,
Harald Welte4f598922017-12-14 13:47:02 +0100126 BTS_CTR_CHAN_ACT_TOTAL,
127 BTS_CTR_CHAN_ACT_NACK,
Harald Welte62d9cb02017-12-14 14:00:26 +0100128 BTS_CTR_RSL_UNKNOWN,
Harald Welte581398a2017-12-14 14:29:44 +0100129 BTS_CTR_RSL_IPA_NACK,
Harald Welte00d64fd2017-12-14 14:34:16 +0100130 BTS_CTR_MODE_MODIFY_NACK,
Harald Welted82101e2017-12-09 23:07:38 +0100131};
132
133static const struct rate_ctr_desc bts_ctr_description[] = {
Harald Welte1ef46d92017-12-09 23:10:46 +0100134 [BTS_CTR_CHREQ_TOTAL] = {"chreq:total", "Received channel requests."},
135 [BTS_CTR_CHREQ_NO_CHANNEL] = {"chreq:no_channel", "Sent to MS no channel available."},
136 [BTS_CTR_CHAN_RF_FAIL] = {"chan:rf_fail", "Received a RF failure indication from BTS."},
137 [BTS_CTR_CHAN_RLL_ERR] = {"chan:rll_err", "Received a RLL failure with T200 cause from BTS."},
Harald Welted82101e2017-12-09 23:07:38 +0100138 [BTS_CTR_BTS_OML_FAIL] = {"oml_fail", "Received a TEI down on a OML link."},
139 [BTS_CTR_BTS_RSL_FAIL] = {"rsl_fail", "Received a TEI down on a OML link."},
Harald Welte1ef46d92017-12-09 23:10:46 +0100140 [BTS_CTR_CODEC_AMR_F] = {"codec:amr_f", "Count the usage of AMR/F codec by channel mode requested."},
141 [BTS_CTR_CODEC_AMR_H] = {"codec:amr_h", "Count the usage of AMR/H codec by channel mode requested."},
142 [BTS_CTR_CODEC_EFR] = {"codec:efr", "Count the usage of EFR codec by channel mode requested."},
143 [BTS_CTR_CODEC_V1_FR] = {"codec:fr", "Count the usage of FR codec by channel mode requested."},
144 [BTS_CTR_CODEC_V1_HR] = {"codec:hr", "Count the usage of HR codec by channel mode requested."},
Harald Weltecf9d4312017-12-13 23:17:16 +0100145
146 [BTS_CTR_PAGING_ATTEMPTED] = {"paging:attempted", "Paging attempts for a subscriber."},
147 [BTS_CTR_PAGING_ALREADY] = {"paging:already", "Paging attempts ignored as subsciber was already being paged."},
148 [BTS_CTR_PAGING_RESPONDED] = {"paging:responded", "Paging attempts with successful paging response."},
149 [BTS_CTR_PAGING_EXPIRED] = {"paging:expired", "Paging Request expired because of timeout T3113."},
Harald Welte4f598922017-12-14 13:47:02 +0100150 [BTS_CTR_CHAN_ACT_TOTAL] = {"chan_act:total", "Total number of Channel Activations."},
151 [BTS_CTR_CHAN_ACT_NACK] = {"chan_act:nack", "Number of Channel Activations that the BTS NACKed"},
Harald Welte62d9cb02017-12-14 14:00:26 +0100152 [BTS_CTR_RSL_UNKNOWN] = {"rsl:unknown", "Number of unknown/unsupported RSL messages received from BTS"},
Harald Welte581398a2017-12-14 14:29:44 +0100153 [BTS_CTR_RSL_IPA_NACK] = {"rsl:ipa_nack", "Number of IPA (RTP/dyn-PDCH) related NACKs received from BTS"},
Harald Welte00d64fd2017-12-14 14:34:16 +0100154 [BTS_CTR_MODE_MODIFY_NACK] = {"chan:mode_modify_nack", "Number of Channel Mode Modify NACKs received from BTS"},
Harald Welted82101e2017-12-09 23:07:38 +0100155};
156
157static const struct rate_ctr_group_desc bts_ctrg_desc = {
158 "bts",
159 "base transceiver station",
160 OSMO_STATS_CLASS_GLOBAL,
161 ARRAY_SIZE(bts_ctr_description),
162 bts_ctr_description,
163};
Holger Hans Peter Freyther5ba6f482009-10-28 14:23:39 +0100164
Alexander Couzens20423ea2016-07-12 15:42:02 +0200165enum {
Alexander Couzensb847a212016-08-02 11:34:11 +0200166 BSC_CTR_HANDOVER_ATTEMPTED,
167 BSC_CTR_HANDOVER_NO_CHANNEL,
168 BSC_CTR_HANDOVER_TIMEOUT,
169 BSC_CTR_HANDOVER_COMPLETED,
170 BSC_CTR_HANDOVER_FAILED,
171 BSC_CTR_PAGING_ATTEMPTED,
172 BSC_CTR_PAGING_DETACHED,
Harald Weltecf9d4312017-12-13 23:17:16 +0100173 BSC_CTR_PAGING_RESPONDED,
Alexander Couzensb847a212016-08-02 11:34:11 +0200174};
175
176static const struct rate_ctr_desc bsc_ctr_description[] = {
Harald Welte1ef46d92017-12-09 23:10:46 +0100177 [BSC_CTR_HANDOVER_ATTEMPTED] = {"handover:attempted", "Received handover attempts."},
178 [BSC_CTR_HANDOVER_NO_CHANNEL] = {"handover:no_channel", "Sent no channel available responses."},
179 [BSC_CTR_HANDOVER_TIMEOUT] = {"handover:timeout", "Count the amount of timeouts of timer T3103."},
180 [BSC_CTR_HANDOVER_COMPLETED] = {"handover:completed", "Received handover completed."},
181 [BSC_CTR_HANDOVER_FAILED] = {"handover:failed", "Receive HO FAIL messages."},
Harald Weltecf9d4312017-12-13 23:17:16 +0100182
183 [BSC_CTR_PAGING_ATTEMPTED] = {"paging:attempted", "Paging attempts for a subscriber."},
Harald Welte1ef46d92017-12-09 23:10:46 +0100184 [BSC_CTR_PAGING_DETACHED] = {"paging:detached", "Counts the amount of paging attempts which couldn't sent out any paging request because no responsible bts found."},
Harald Weltecf9d4312017-12-13 23:17:16 +0100185 [BSC_CTR_PAGING_RESPONDED] = {"paging:responded", "Paging attempts with successful response."},
Alexander Couzensb847a212016-08-02 11:34:11 +0200186};
187
Alexander Couzensb847a212016-08-02 11:34:11 +0200188
189
190static const struct rate_ctr_group_desc bsc_ctrg_desc = {
191 "bsc",
192 "base station controller",
193 OSMO_STATS_CLASS_GLOBAL,
194 ARRAY_SIZE(bsc_ctr_description),
195 bsc_ctr_description,
Alexander Couzens20423ea2016-07-12 15:42:02 +0200196};
197
Harald Weltedea252d2017-12-10 19:55:18 +0100198#define GSM_T3101_DEFAULT 3 /* s */
Harald Weltea0d324b2017-07-20 01:47:39 +0200199#define GSM_T3103_DEFAULT 5 /* s */
200#define GSM_T3105_DEFAULT 100 /* ms */
201#define GSM_T3107_DEFAULT 5 /* s */
Harald Welteed23c1d2017-12-10 19:58:16 +0100202#define GSM_T3109_DEFAULT 5 /* s, must be 2s + radio_link_timeout*0.48 */
Harald Weltea0d324b2017-07-20 01:47:39 +0200203#define GSM_T3111_DEFAULT 2 /* s */
Harald Welte6e59ced2017-12-14 12:49:43 +0100204#define GSM_T3113_DEFAULT 10 /* s */
Harald Weltea0d324b2017-07-20 01:47:39 +0200205#define GSM_T3115_DEFAULT 10
206#define GSM_T3117_DEFAULT 10
207#define GSM_T3119_DEFAULT 10
Andreas Eversberg75e13a42013-02-07 11:51:16 +0100208#define GSM_T3122_DEFAULT 10
Harald Weltea0d324b2017-07-20 01:47:39 +0200209#define GSM_T3141_DEFAULT 10
Harald Welteb84ddfc2009-12-01 17:36:54 +0530210
Neels Hofmeyr73983952016-05-10 13:29:33 +0200211struct gsm_tz {
212 int override; /* if 0, use system's time zone instead. */
213 int hr; /* hour */
214 int mn; /* minute */
215 int dst; /* daylight savings */
216};
217
Harald Welte52b1f982008-12-23 20:25:15 +0000218struct gsm_network {
Neels Hofmeyrce4d88b2017-05-08 15:12:20 +0200219 /* TODO MSCSPLIT the gsm_network struct is basically a kitchen sink for
220 * global settings and variables, "madly" mixing BSC and MSC stuff. Split
221 * this in e.g. struct osmo_bsc and struct osmo_msc, with the things
222 * these have in common, like country and network code, put in yet
223 * separate structs and placed as members in osmo_bsc and osmo_msc. */
224
Harald Welte52b1f982008-12-23 20:25:15 +0000225 /* global parameters */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200226 uint16_t country_code;
227 uint16_t network_code;
Harald Welte4381cfe2009-08-30 15:47:06 +0900228 int a5_encryption;
Holger Hans Peter Freytherf7d752f2009-11-16 17:12:38 +0100229 int neci;
Harald Weltebc814502009-12-19 21:41:52 +0100230 struct {
231 int active;
Harald Weltef7c28b02009-12-21 13:30:17 +0100232 /* Window RXLEV averaging */
233 unsigned int win_rxlev_avg; /* number of SACCH frames */
234 /* Window RXQUAL averaging */
235 unsigned int win_rxqual_avg; /* number of SACCH frames */
236 /* Window RXLEV neighbouring cells averaging */
237 unsigned int win_rxlev_avg_neigh; /* number of SACCH frames */
238
239 /* how often should we check for power budget HO */
240 unsigned int pwr_interval; /* SACCH frames */
241 /* how much better does a neighbor cell have to be ? */
242 unsigned int pwr_hysteresis; /* dBm */
243 /* maximum distacne before we try a handover */
244 unsigned int max_distance; /* TA values */
Harald Weltebc814502009-12-19 21:41:52 +0100245 } handover;
Harald Welte52b1f982008-12-23 20:25:15 +0000246
Alexander Couzensb847a212016-08-02 11:34:11 +0200247 struct rate_ctr_group *bsc_ctrs;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100248
Neels Hofmeyrc29505e2016-05-20 21:59:55 +0200249 /*
250 * TODO: Move the trans_list into the subscriber connection and
251 * create a pending list for MT transactions. These exist before
252 * we have a subscriber connection.
253 */
Harald Welte4bfdfe72009-06-10 23:11:52 +0800254 struct llist_head trans_list;
Holger Hans Peter Freytherabcddf12010-06-14 18:20:15 +0800255 struct bsc_api *bsc_api;
Harald Welte4bfdfe72009-06-10 23:11:52 +0800256
Harald Welte52b1f982008-12-23 20:25:15 +0000257 unsigned int num_bts;
Harald Weltee441d9c2009-06-21 16:17:15 +0200258 struct llist_head bts_list;
Holger Hans Peter Freytherc4d88ad2009-11-21 21:18:38 +0100259
260 /* timer values */
261 int T3101;
Holger Hans Peter Freyther23975e72009-11-21 21:42:26 +0100262 int T3103;
263 int T3105;
264 int T3107;
265 int T3109;
266 int T3111;
267 int T3113;
268 int T3115;
269 int T3117;
270 int T3119;
Harald Welte2862dca2010-12-23 14:39:29 +0100271 int T3122;
Holger Hans Peter Freyther23975e72009-11-21 21:42:26 +0100272 int T3141;
Harald Welteeab84a12009-12-13 10:53:12 +0100273
Jan Luebbebfbdeec2012-12-27 00:27:16 +0100274 /* timer to expire old location updates */
275 struct osmo_timer_list subscr_expire_timer;
276
Alexander Couzens547c2072017-11-21 12:03:04 +0100277 enum gsm_chan_t ctype_by_chreq[_NUM_CHREQ_T];
Holger Hans Peter Freyther78891072010-09-06 09:36:02 +0800278
Holger Hans Peter Freyther76fc4a32010-09-06 09:41:50 +0800279 /* Use a TCH for handling requests of type paging any */
280 int pag_any_tch;
281
Holger Hans Peter Freyther3e8e0462010-09-15 22:29:25 +0800282 /* MSC data in case we are a true BSC */
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200283 struct osmo_bsc_data *bsc_data;
Holger Hans Peter Freytherdaee5ca2010-12-22 12:34:39 +0100284
Daniel Willmann6fc4a982011-07-22 17:55:42 +0200285 /* control interface */
286 struct ctrl_handle *ctrl;
Neels Hofmeyr5f0c71b2016-07-23 20:15:28 +0200287
288 /* Allow or disallow TCH/F on dynamic TCH/F_TCH/H_PDCH; OS#1778 */
289 bool dyn_ts_allow_tch_f;
Neels Hofmeyrd90fa422016-05-09 21:03:12 +0200290
291 /* all active subscriber connections. */
292 struct llist_head subscr_conns;
Neels Hofmeyr73983952016-05-10 13:29:33 +0200293
294 /* if override is nonzero, this timezone data is used for all MM
295 * contexts. */
296 /* TODO: in OsmoNITB, tz-override used to be BTS-specific. To enable
297 * BTS|RNC specific timezone overrides for multi-tz networks in
Neels Hofmeyrfe291de2017-02-23 21:06:12 +0100298 * OsmoMSC, this should be tied to the location area code (LAC). */
Neels Hofmeyr73983952016-05-10 13:29:33 +0200299 struct gsm_tz tz;
Neels Hofmeyr6d804b12017-02-18 22:20:46 +0100300
301 /* List of all struct bsc_subscr used in libbsc. This llist_head is
302 * allocated so that the llist_head pointer itself can serve as a
303 * talloc context (useful to not have to pass the entire gsm_network
304 * struct to the bsc_subscr_* API, and for bsc_susbscr unit tests to
305 * not require gsm_data.h). In an MSC-without-BSC environment, this
306 * pointer is NULL to indicate absence of a bsc_subscribers list. */
307 struct llist_head *bsc_subscribers;
Harald Weltea43e0b42016-06-19 18:06:02 +0200308
Neels Hofmeyrce4d88b2017-05-08 15:12:20 +0200309 /* Periodic location update default value */
310 uint8_t t3212;
Neels Hofmeyrc29505e2016-05-20 21:59:55 +0200311
312 struct {
Philipp Maier39c609b2017-09-27 15:51:34 +0200313 struct mgcp_client_conf *conf;
314 struct mgcp_client *client;
315 } mgw;
Harald Welte7e310b12009-03-30 20:56:32 +0000316};
317
Neels Hofmeyrc13e6872016-05-11 13:53:47 +0200318extern void talloc_ctx_init(void *ctx_root);
319
Harald Welte39315c42010-01-10 18:01:52 +0100320int gsm_set_bts_type(struct gsm_bts *bts, enum gsm_bts_type type);
Harald Weltee441d9c2009-06-21 16:17:15 +0200321
Harald Welte1d014a52009-08-08 15:38:29 +0200322enum gsm_bts_type parse_btstype(const char *arg);
Holger Hans Peter Freyther2dceae62009-06-12 17:39:38 +0200323const char *btstype2str(enum gsm_bts_type type);
Harald Weltebe991492009-05-23 13:56:40 +0000324struct gsm_bts *gsm_bts_by_lac(struct gsm_network *net, unsigned int lac,
325 struct gsm_bts *start_bts);
Harald Welte32201c12009-03-10 12:15:10 +0000326
Andreas Eversberg8226fa72009-06-29 15:19:38 +0200327extern void *tall_bsc_ctx;
Harald Weltef88c8a02009-12-20 13:48:15 +0100328extern int ipacc_rtp_direct;
Harald Welte2cf161b2009-06-20 22:36:41 +0200329
Harald Weltef383aa12012-07-02 19:51:55 +0200330/* this actaully refers to the IPA transport, not the BTS model */
Harald Welte32201c12009-03-10 12:15:10 +0000331static inline int is_ipaccess_bts(struct gsm_bts *bts)
332{
333 switch (bts->type) {
Mike Habene2d82272009-10-02 12:19:34 +0100334 case GSM_BTS_TYPE_NANOBTS:
Maxf9685c12017-03-23 12:01:07 +0100335 case GSM_BTS_TYPE_OSMOBTS:
Harald Welte32201c12009-03-10 12:15:10 +0000336 return 1;
337 default:
338 break;
339 }
340 return 0;
341}
342
Holger Hans Peter Freyther6f6cbf72015-04-04 19:35:22 +0200343static inline int is_sysmobts_v2(struct gsm_bts *bts)
344{
345 switch (bts->type) {
Maxf9685c12017-03-23 12:01:07 +0100346 case GSM_BTS_TYPE_OSMOBTS:
Holger Hans Peter Freyther6f6cbf72015-04-04 19:35:22 +0200347 return 1;
348 default:
349 break;
350 }
351 return 0;
352}
353
Harald Welte5b570672009-08-10 10:08:01 +0200354static inline int is_siemens_bts(struct gsm_bts *bts)
355{
356 switch (bts->type) {
357 case GSM_BTS_TYPE_BS11:
358 return 1;
359 default:
360 break;
361 }
362
363 return 0;
364}
365
Andreas Eversberg7d8fa342013-12-05 13:25:06 +0100366static inline int is_nokia_bts(struct gsm_bts *bts)
367{
368 switch (bts->type) {
369 case GSM_BTS_TYPE_NOKIA_SITE:
370 return 1;
371 default:
372 break;
373 }
374
375 return 0;
376}
377
Andreas Eversbergdcf38e12013-12-05 14:37:11 +0100378static inline int is_e1_bts(struct gsm_bts *bts)
379{
380 switch (bts->type) {
381 case GSM_BTS_TYPE_BS11:
382 case GSM_BTS_TYPE_RBS2000:
383 case GSM_BTS_TYPE_NOKIA_SITE:
384 return 1;
385 default:
386 break;
387 }
388
389 return 0;
390}
391
Holger Hans Peter Freyther4e13a8f2015-01-31 22:16:00 +0100392enum bts_gprs_mode bts_gprs_mode_parse(const char *arg, int *valid);
Harald Welte4511d892010-04-18 15:51:20 +0200393const char *bts_gprs_mode_name(enum bts_gprs_mode mode);
Holger Hans Peter Freyther4e13a8f2015-01-31 22:16:00 +0100394int bts_gprs_mode_is_compat(struct gsm_bts *bts, enum bts_gprs_mode mode);
Harald Welte4511d892010-04-18 15:51:20 +0200395
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200396int gsm48_ra_id_by_bts(uint8_t *buf, struct gsm_bts *bts);
Harald Welte97a282b2010-03-14 15:37:43 +0800397void gprs_ra_id_by_bts(struct gprs_ra_id *raid, struct gsm_bts *bts);
Harald Welted12b0fd2009-12-15 21:36:05 +0100398
Harald Weltef3d8e922010-06-14 22:44:42 +0200399int gsm_btsmodel_set_feature(struct gsm_bts_model *model, enum gsm_bts_features feat);
Harald Weltefbda4e12010-03-04 11:04:52 +0100400int gsm_bts_model_register(struct gsm_bts_model *model);
401
Neels Hofmeyr42eb0142016-05-20 17:15:44 +0200402struct gsm_subscriber_connection *bsc_subscr_con_allocate(struct gsm_lchan *lchan);
403void bsc_subscr_con_free(struct gsm_subscriber_connection *conn);
404
405struct gsm_subscriber_connection *msc_subscr_con_allocate(struct gsm_network *network);
406void msc_subscr_con_free(struct gsm_subscriber_connection *conn);
Holger Hans Peter Freyther2412a072010-06-28 15:47:12 +0800407
Harald Welte3300c012011-06-05 13:31:33 +0200408struct gsm_bts *gsm_bts_alloc_register(struct gsm_network *net,
409 enum gsm_bts_type type,
Harald Weltea2bbc5e2015-11-20 10:43:31 +0100410 uint8_t bsic);
Harald Welte142d12d2014-12-29 17:47:08 +0100411
Harald Welte3300c012011-06-05 13:31:33 +0200412void set_ts_e1link(struct gsm_bts_trx_ts *ts, uint8_t e1_nr,
413 uint8_t e1_ts, uint8_t e1_ts_ss);
414
Maxbe356ed2017-09-07 19:10:09 +0200415void gsm_trx_lock_rf(struct gsm_bts_trx *trx, bool locked, const char *reason);
Max71d082b2017-05-30 15:03:38 +0200416bool gsm_btsmodel_has_feature(struct gsm_bts_model *model, enum gsm_bts_features feat);
Harald Welte3300c012011-06-05 13:31:33 +0200417struct gsm_bts_trx *gsm_bts_trx_by_nr(struct gsm_bts *bts, int nr);
Holger Hans Peter Freythera49b2c02014-11-21 11:18:45 +0100418int gsm_bts_trx_set_system_infos(struct gsm_bts_trx *trx);
Alexander Chemerisc36a13b2015-05-30 14:40:54 -0400419int gsm_bts_set_system_infos(struct gsm_bts *bts);
Harald Welte3300c012011-06-05 13:31:33 +0200420
Pablo Neira Ayusoed5cacb2011-08-17 22:44:07 +0200421/* generic E1 line operations for all ISDN-based BTS. */
422extern struct e1inp_line_ops bts_isdn_e1inp_line_ops;
423
Harald Weltee555c2b2012-08-17 13:02:12 +0200424extern const struct value_string bts_type_names[_NUM_GSM_BTS_TYPE+1];
425extern const struct value_string bts_type_descs[_NUM_GSM_BTS_TYPE+1];
426
Max3d049d22017-10-09 17:12:53 +0200427char *get_model_oml_status(const struct gsm_bts *bts);
428
Max25cc4072017-10-10 14:50:35 +0200429unsigned long long bts_uptime(const struct gsm_bts *bts);
430
Holger Hans Peter Freytherf8c42192013-01-09 17:03:27 +0100431/* control interface handling */
432int bsc_base_ctrl_cmds_install(void);
433
Holger Hans Peter Freytherc22930e2014-12-17 14:46:17 +0100434/* dependency handling */
435void bts_depend_mark(struct gsm_bts *bts, int dep);
436void bts_depend_clear(struct gsm_bts *bts, int dep);
437int bts_depend_check(struct gsm_bts *bts);
Holger Hans Peter Freytherf7e23c52014-12-17 15:44:32 +0100438int bts_depend_is_depedency(struct gsm_bts *base, struct gsm_bts *other);
Holger Hans Peter Freytherc22930e2014-12-17 14:46:17 +0100439
Harald Welte2f8b9d22017-06-18 11:12:13 +0300440int gsm_bts_get_radio_link_timeout(const struct gsm_bts *bts);
441void gsm_bts_set_radio_link_timeout(struct gsm_bts *bts, int value);
442
Harald Weltea43e0b42016-06-19 18:06:02 +0200443bool classmark_is_r99(struct gsm_classmark *cm);
444
Harald Welte6be350c2011-05-25 13:10:08 +0200445#endif /* _GSM_DATA_H */