blob: 0ff58117eba7b7bc081ba67ffad9c35b4ed2c5d8 [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>
Philipp Maier39f62bb2017-04-09 12:32:51 +020015#include <osmocom/sigtran/sccp_sap.h>
Harald Weltef142c972011-05-24 13:25:38 +020016
Neels Hofmeyrc0164792017-09-04 15:15:32 +020017#include <osmocom/bsc/common.h>
18#include <osmocom/bsc/rest_octets.h>
19#include <osmocom/bsc/common_cs.h>
Harald Welteb96be392011-05-25 12:33:33 +020020
Philipp Maier39f62bb2017-04-09 12:32:51 +020021
Holger Hans Peter Freytherd7b22c62013-04-29 09:11:02 +020022/** annotations for msgb ownership */
23#define __uses
24
Holger Hans Peter Freyther6f615552010-11-15 20:50:42 +010025#define OBSC_NM_W_ACK_CB(__msgb) (__msgb)->cb[3]
26
Neels Hofmeyr6d804b12017-02-18 22:20:46 +010027struct bsc_subscr;
Neels Hofmeyr7b656882017-07-09 22:09:18 +020028struct gprs_ra_id;
Holger Hans Peter Freyther694c82d2011-10-26 18:37:09 +020029
Holger Hans Peter Freyther9c595b72010-06-15 11:20:52 +080030#define OBSC_LINKID_CB(__msgb) (__msgb)->cb[3]
31
Neels Hofmeyr0e5d8072017-01-10 00:49:56 +010032#define tmsi_from_string(str) strtoul(str, NULL, 10)
33
Max70fdd242017-06-15 15:10:53 +020034/* 3-bit long values */
35#define EARFCN_PRIO_INVALID 8
36#define EARFCN_MEAS_BW_INVALID 8
37/* 5-bit long values */
38#define EARFCN_QRXLV_INVALID 32
39#define EARFCN_THRESH_LOW_INVALID 32
40
Harald Welte8e1e3ee2009-02-01 13:32:45 +000041struct msgb;
42typedef int gsm_cbfn(unsigned int hooknum,
43 unsigned int event,
44 struct msgb *msg,
45 void *data, void *param);
46
Harald Weltef7c28b02009-12-21 13:30:17 +010047/* Maximum number of neighbor cells whose average we track */
48#define MAX_NEIGH_MEAS 10
49/* Maximum size of the averaging window for neighbor cells */
50#define MAX_WIN_NEIGH_AVG 10
51
52/* processed neighbor measurements for one cell */
53struct neigh_meas_proc {
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020054 uint16_t arfcn;
55 uint8_t bsic;
56 uint8_t rxlev[MAX_WIN_NEIGH_AVG];
Harald Weltef7c28b02009-12-21 13:30:17 +010057 unsigned int rxlev_cnt;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020058 uint8_t last_seen_nr;
Harald Weltef7c28b02009-12-21 13:30:17 +010059};
60
Harald Weltea43e0b42016-06-19 18:06:02 +020061struct gsm_classmark {
62 bool classmark1_set;
63 struct gsm48_classmark1 classmark1;
64 uint8_t classmark2_len;
65 uint8_t classmark2[3];
66 uint8_t classmark3_len;
67 uint8_t classmark3[14]; /* if cm3 gets extended by spec, it will be truncated */
68};
69
Neels Hofmeyr378a4922016-05-09 21:07:43 +020070/* active radio connection of a mobile subscriber */
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +010071struct gsm_subscriber_connection {
Harald Weltea43e0b42016-06-19 18:06:02 +020072 /* global linked list of subscriber_connections */
Holger Hans Peter Freyther79f763f2010-09-16 00:53:37 +080073 struct llist_head entry;
74
Harald Weltea43e0b42016-06-19 18:06:02 +020075 /* libbsc subscriber information (if available) */
Neels Hofmeyr6d804b12017-02-18 22:20:46 +010076 struct bsc_subscr *bsub;
77
Harald Welte4a8ebc82017-12-18 18:34:41 +010078 /* SCCP connection associatd with this subscriber_connection */
79 struct osmo_bsc_sccp_con *sccp_con;
Holger Hans Peter Freyther2f9d1ef2010-09-16 20:14:01 +080080
Holger Hans Peter Freyther18b63f42010-03-23 07:52:17 +010081 /* back pointers */
Neels Hofmeyr5e0b0a62016-05-09 22:33:01 +020082 struct gsm_network *network;
83
Harald Welte4a8ebc82017-12-18 18:34:41 +010084 /* the primary / currently active lchan to the BTS/subscriber */
85 struct gsm_lchan *lchan;
86 /* the future/allocated but not yet used lchan during HANDOVER */
87 struct gsm_lchan *ho_lchan;
88 /* a short-hand pointer to the BTS currently serving the subscriber,
89 * points to gsm_subscriber_connection.lchan->ts->trx->bts */
90 struct gsm_bts *bts;
Holger Hans Peter Freyther77cd95d2010-11-14 16:19:48 +010091
Harald Welte4a8ebc82017-12-18 18:34:41 +010092 /* timer for assignment handling */
93 struct osmo_timer_list T10;
94 /* the future allocated but not yet used lchan during ASSIGNMENT */
95 struct gsm_lchan *secondary_lchan;
Holger Hans Peter Freyther77cd95d2010-11-14 16:19:48 +010096
Harald Welte4a8ebc82017-12-18 18:34:41 +010097 /* buffer/cache for classmark of the ME of the subscriber */
Harald Weltea43e0b42016-06-19 18:06:02 +020098 struct gsm_classmark classmark;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +010099};
100
Harald Welte148ee362017-12-18 18:44:25 +0100101static inline struct gsm_bts *conn_get_bts(struct gsm_subscriber_connection *conn) {
102 return conn->bts;
103}
104
Harald Weltef142c972011-05-24 13:25:38 +0200105
Harald Welte6be350c2011-05-25 13:10:08 +0200106#include "gsm_data_shared.h"
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100107
Harald Welted82101e2017-12-09 23:07:38 +0100108enum {
109 BTS_CTR_CHREQ_TOTAL,
110 BTS_CTR_CHREQ_NO_CHANNEL,
111 BTS_CTR_CHAN_RF_FAIL,
112 BTS_CTR_CHAN_RLL_ERR,
113 BTS_CTR_BTS_OML_FAIL,
114 BTS_CTR_BTS_RSL_FAIL,
115 BTS_CTR_CODEC_AMR_F,
116 BTS_CTR_CODEC_AMR_H,
117 BTS_CTR_CODEC_EFR,
118 BTS_CTR_CODEC_V1_FR,
119 BTS_CTR_CODEC_V1_HR,
Harald Weltecf9d4312017-12-13 23:17:16 +0100120 BTS_CTR_PAGING_ATTEMPTED,
121 BTS_CTR_PAGING_ALREADY,
122 BTS_CTR_PAGING_RESPONDED,
123 BTS_CTR_PAGING_EXPIRED,
Harald Welte4f598922017-12-14 13:47:02 +0100124 BTS_CTR_CHAN_ACT_TOTAL,
125 BTS_CTR_CHAN_ACT_NACK,
Harald Welte62d9cb02017-12-14 14:00:26 +0100126 BTS_CTR_RSL_UNKNOWN,
Harald Welte581398a2017-12-14 14:29:44 +0100127 BTS_CTR_RSL_IPA_NACK,
Harald Welte00d64fd2017-12-14 14:34:16 +0100128 BTS_CTR_MODE_MODIFY_NACK,
Harald Welted82101e2017-12-09 23:07:38 +0100129};
130
131static const struct rate_ctr_desc bts_ctr_description[] = {
Harald Welte1ef46d92017-12-09 23:10:46 +0100132 [BTS_CTR_CHREQ_TOTAL] = {"chreq:total", "Received channel requests."},
133 [BTS_CTR_CHREQ_NO_CHANNEL] = {"chreq:no_channel", "Sent to MS no channel available."},
134 [BTS_CTR_CHAN_RF_FAIL] = {"chan:rf_fail", "Received a RF failure indication from BTS."},
135 [BTS_CTR_CHAN_RLL_ERR] = {"chan:rll_err", "Received a RLL failure with T200 cause from BTS."},
Harald Welted82101e2017-12-09 23:07:38 +0100136 [BTS_CTR_BTS_OML_FAIL] = {"oml_fail", "Received a TEI down on a OML link."},
137 [BTS_CTR_BTS_RSL_FAIL] = {"rsl_fail", "Received a TEI down on a OML link."},
Harald Welte1ef46d92017-12-09 23:10:46 +0100138 [BTS_CTR_CODEC_AMR_F] = {"codec:amr_f", "Count the usage of AMR/F codec by channel mode requested."},
139 [BTS_CTR_CODEC_AMR_H] = {"codec:amr_h", "Count the usage of AMR/H codec by channel mode requested."},
140 [BTS_CTR_CODEC_EFR] = {"codec:efr", "Count the usage of EFR codec by channel mode requested."},
141 [BTS_CTR_CODEC_V1_FR] = {"codec:fr", "Count the usage of FR codec by channel mode requested."},
142 [BTS_CTR_CODEC_V1_HR] = {"codec:hr", "Count the usage of HR codec by channel mode requested."},
Harald Weltecf9d4312017-12-13 23:17:16 +0100143
144 [BTS_CTR_PAGING_ATTEMPTED] = {"paging:attempted", "Paging attempts for a subscriber."},
145 [BTS_CTR_PAGING_ALREADY] = {"paging:already", "Paging attempts ignored as subsciber was already being paged."},
146 [BTS_CTR_PAGING_RESPONDED] = {"paging:responded", "Paging attempts with successful paging response."},
147 [BTS_CTR_PAGING_EXPIRED] = {"paging:expired", "Paging Request expired because of timeout T3113."},
Harald Welte4f598922017-12-14 13:47:02 +0100148 [BTS_CTR_CHAN_ACT_TOTAL] = {"chan_act:total", "Total number of Channel Activations."},
149 [BTS_CTR_CHAN_ACT_NACK] = {"chan_act:nack", "Number of Channel Activations that the BTS NACKed"},
Harald Welte62d9cb02017-12-14 14:00:26 +0100150 [BTS_CTR_RSL_UNKNOWN] = {"rsl:unknown", "Number of unknown/unsupported RSL messages received from BTS"},
Harald Welte581398a2017-12-14 14:29:44 +0100151 [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 +0100152 [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 +0100153};
154
155static const struct rate_ctr_group_desc bts_ctrg_desc = {
156 "bts",
157 "base transceiver station",
158 OSMO_STATS_CLASS_GLOBAL,
159 ARRAY_SIZE(bts_ctr_description),
160 bts_ctr_description,
161};
Holger Hans Peter Freyther5ba6f482009-10-28 14:23:39 +0100162
Alexander Couzens20423ea2016-07-12 15:42:02 +0200163enum {
Alexander Couzensb847a212016-08-02 11:34:11 +0200164 BSC_CTR_HANDOVER_ATTEMPTED,
165 BSC_CTR_HANDOVER_NO_CHANNEL,
166 BSC_CTR_HANDOVER_TIMEOUT,
167 BSC_CTR_HANDOVER_COMPLETED,
168 BSC_CTR_HANDOVER_FAILED,
169 BSC_CTR_PAGING_ATTEMPTED,
170 BSC_CTR_PAGING_DETACHED,
Harald Weltecf9d4312017-12-13 23:17:16 +0100171 BSC_CTR_PAGING_RESPONDED,
Alexander Couzensb847a212016-08-02 11:34:11 +0200172};
173
174static const struct rate_ctr_desc bsc_ctr_description[] = {
Harald Welte1ef46d92017-12-09 23:10:46 +0100175 [BSC_CTR_HANDOVER_ATTEMPTED] = {"handover:attempted", "Received handover attempts."},
176 [BSC_CTR_HANDOVER_NO_CHANNEL] = {"handover:no_channel", "Sent no channel available responses."},
177 [BSC_CTR_HANDOVER_TIMEOUT] = {"handover:timeout", "Count the amount of timeouts of timer T3103."},
178 [BSC_CTR_HANDOVER_COMPLETED] = {"handover:completed", "Received handover completed."},
179 [BSC_CTR_HANDOVER_FAILED] = {"handover:failed", "Receive HO FAIL messages."},
Harald Weltecf9d4312017-12-13 23:17:16 +0100180
181 [BSC_CTR_PAGING_ATTEMPTED] = {"paging:attempted", "Paging attempts for a subscriber."},
Harald Welte1ef46d92017-12-09 23:10:46 +0100182 [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 +0100183 [BSC_CTR_PAGING_RESPONDED] = {"paging:responded", "Paging attempts with successful response."},
Alexander Couzensb847a212016-08-02 11:34:11 +0200184};
185
Alexander Couzensb847a212016-08-02 11:34:11 +0200186
187
188static const struct rate_ctr_group_desc bsc_ctrg_desc = {
189 "bsc",
190 "base station controller",
191 OSMO_STATS_CLASS_GLOBAL,
192 ARRAY_SIZE(bsc_ctr_description),
193 bsc_ctr_description,
Alexander Couzens20423ea2016-07-12 15:42:02 +0200194};
195
Harald Weltedea252d2017-12-10 19:55:18 +0100196#define GSM_T3101_DEFAULT 3 /* s */
Harald Weltea0d324b2017-07-20 01:47:39 +0200197#define GSM_T3103_DEFAULT 5 /* s */
198#define GSM_T3105_DEFAULT 100 /* ms */
199#define GSM_T3107_DEFAULT 5 /* s */
Harald Welteed23c1d2017-12-10 19:58:16 +0100200#define GSM_T3109_DEFAULT 5 /* s, must be 2s + radio_link_timeout*0.48 */
Harald Weltea0d324b2017-07-20 01:47:39 +0200201#define GSM_T3111_DEFAULT 2 /* s */
Harald Welte6e59ced2017-12-14 12:49:43 +0100202#define GSM_T3113_DEFAULT 10 /* s */
Harald Weltea0d324b2017-07-20 01:47:39 +0200203#define GSM_T3115_DEFAULT 10
204#define GSM_T3117_DEFAULT 10
205#define GSM_T3119_DEFAULT 10
Andreas Eversberg75e13a42013-02-07 11:51:16 +0100206#define GSM_T3122_DEFAULT 10
Harald Weltea0d324b2017-07-20 01:47:39 +0200207#define GSM_T3141_DEFAULT 10
Harald Welteb84ddfc2009-12-01 17:36:54 +0530208
Neels Hofmeyr73983952016-05-10 13:29:33 +0200209struct gsm_tz {
210 int override; /* if 0, use system's time zone instead. */
211 int hr; /* hour */
212 int mn; /* minute */
213 int dst; /* daylight savings */
214};
215
Harald Welte52b1f982008-12-23 20:25:15 +0000216struct gsm_network {
Neels Hofmeyrce4d88b2017-05-08 15:12:20 +0200217 /* TODO MSCSPLIT the gsm_network struct is basically a kitchen sink for
218 * global settings and variables, "madly" mixing BSC and MSC stuff. Split
219 * this in e.g. struct osmo_bsc and struct osmo_msc, with the things
220 * these have in common, like country and network code, put in yet
221 * separate structs and placed as members in osmo_bsc and osmo_msc. */
222
Harald Welte52b1f982008-12-23 20:25:15 +0000223 /* global parameters */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200224 uint16_t country_code;
225 uint16_t network_code;
Harald Welte4381cfe2009-08-30 15:47:06 +0900226 int a5_encryption;
Holger Hans Peter Freytherf7d752f2009-11-16 17:12:38 +0100227 int neci;
Harald Weltebc814502009-12-19 21:41:52 +0100228 struct {
229 int active;
Harald Weltef7c28b02009-12-21 13:30:17 +0100230 /* Window RXLEV averaging */
231 unsigned int win_rxlev_avg; /* number of SACCH frames */
232 /* Window RXQUAL averaging */
233 unsigned int win_rxqual_avg; /* number of SACCH frames */
234 /* Window RXLEV neighbouring cells averaging */
235 unsigned int win_rxlev_avg_neigh; /* number of SACCH frames */
236
237 /* how often should we check for power budget HO */
238 unsigned int pwr_interval; /* SACCH frames */
239 /* how much better does a neighbor cell have to be ? */
240 unsigned int pwr_hysteresis; /* dBm */
241 /* maximum distacne before we try a handover */
242 unsigned int max_distance; /* TA values */
Harald Weltebc814502009-12-19 21:41:52 +0100243 } handover;
Harald Welte52b1f982008-12-23 20:25:15 +0000244
Alexander Couzensb847a212016-08-02 11:34:11 +0200245 struct rate_ctr_group *bsc_ctrs;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100246
Neels Hofmeyrc29505e2016-05-20 21:59:55 +0200247 /*
248 * TODO: Move the trans_list into the subscriber connection and
249 * create a pending list for MT transactions. These exist before
250 * we have a subscriber connection.
251 */
Harald Welte4bfdfe72009-06-10 23:11:52 +0800252 struct llist_head trans_list;
Holger Hans Peter Freytherabcddf12010-06-14 18:20:15 +0800253 struct bsc_api *bsc_api;
Harald Welte4bfdfe72009-06-10 23:11:52 +0800254
Harald Welte52b1f982008-12-23 20:25:15 +0000255 unsigned int num_bts;
Harald Weltee441d9c2009-06-21 16:17:15 +0200256 struct llist_head bts_list;
Holger Hans Peter Freytherc4d88ad2009-11-21 21:18:38 +0100257
258 /* timer values */
259 int T3101;
Holger Hans Peter Freyther23975e72009-11-21 21:42:26 +0100260 int T3103;
261 int T3105;
262 int T3107;
263 int T3109;
264 int T3111;
265 int T3113;
266 int T3115;
267 int T3117;
268 int T3119;
Harald Welte2862dca2010-12-23 14:39:29 +0100269 int T3122;
Holger Hans Peter Freyther23975e72009-11-21 21:42:26 +0100270 int T3141;
Harald Welteeab84a12009-12-13 10:53:12 +0100271
Jan Luebbebfbdeec2012-12-27 00:27:16 +0100272 /* timer to expire old location updates */
273 struct osmo_timer_list subscr_expire_timer;
274
Alexander Couzens547c2072017-11-21 12:03:04 +0100275 enum gsm_chan_t ctype_by_chreq[_NUM_CHREQ_T];
Holger Hans Peter Freyther78891072010-09-06 09:36:02 +0800276
Holger Hans Peter Freyther76fc4a32010-09-06 09:41:50 +0800277 /* Use a TCH for handling requests of type paging any */
278 int pag_any_tch;
279
Holger Hans Peter Freyther3e8e0462010-09-15 22:29:25 +0800280 /* MSC data in case we are a true BSC */
Holger Hans Peter Freyther8ec49522011-08-15 15:53:00 +0200281 struct osmo_bsc_data *bsc_data;
Holger Hans Peter Freytherdaee5ca2010-12-22 12:34:39 +0100282
Daniel Willmann6fc4a982011-07-22 17:55:42 +0200283 /* control interface */
284 struct ctrl_handle *ctrl;
Neels Hofmeyr5f0c71b2016-07-23 20:15:28 +0200285
286 /* Allow or disallow TCH/F on dynamic TCH/F_TCH/H_PDCH; OS#1778 */
287 bool dyn_ts_allow_tch_f;
Neels Hofmeyrd90fa422016-05-09 21:03:12 +0200288
289 /* all active subscriber connections. */
290 struct llist_head subscr_conns;
Neels Hofmeyr73983952016-05-10 13:29:33 +0200291
292 /* if override is nonzero, this timezone data is used for all MM
293 * contexts. */
294 /* TODO: in OsmoNITB, tz-override used to be BTS-specific. To enable
295 * BTS|RNC specific timezone overrides for multi-tz networks in
Neels Hofmeyrfe291de2017-02-23 21:06:12 +0100296 * OsmoMSC, this should be tied to the location area code (LAC). */
Neels Hofmeyr73983952016-05-10 13:29:33 +0200297 struct gsm_tz tz;
Neels Hofmeyr6d804b12017-02-18 22:20:46 +0100298
299 /* List of all struct bsc_subscr used in libbsc. This llist_head is
300 * allocated so that the llist_head pointer itself can serve as a
301 * talloc context (useful to not have to pass the entire gsm_network
302 * struct to the bsc_subscr_* API, and for bsc_susbscr unit tests to
303 * not require gsm_data.h). In an MSC-without-BSC environment, this
304 * pointer is NULL to indicate absence of a bsc_subscribers list. */
305 struct llist_head *bsc_subscribers;
Harald Weltea43e0b42016-06-19 18:06:02 +0200306
Neels Hofmeyrce4d88b2017-05-08 15:12:20 +0200307 /* Periodic location update default value */
308 uint8_t t3212;
Neels Hofmeyrc29505e2016-05-20 21:59:55 +0200309
310 struct {
Philipp Maier39c609b2017-09-27 15:51:34 +0200311 struct mgcp_client_conf *conf;
312 struct mgcp_client *client;
313 } mgw;
Harald Welte7e310b12009-03-30 20:56:32 +0000314};
315
Neels Hofmeyrc13e6872016-05-11 13:53:47 +0200316extern void talloc_ctx_init(void *ctx_root);
317
Harald Welte39315c42010-01-10 18:01:52 +0100318int gsm_set_bts_type(struct gsm_bts *bts, enum gsm_bts_type type);
Harald Weltee441d9c2009-06-21 16:17:15 +0200319
Harald Welte1d014a52009-08-08 15:38:29 +0200320enum gsm_bts_type parse_btstype(const char *arg);
Holger Hans Peter Freyther2dceae62009-06-12 17:39:38 +0200321const char *btstype2str(enum gsm_bts_type type);
Harald Weltebe991492009-05-23 13:56:40 +0000322struct gsm_bts *gsm_bts_by_lac(struct gsm_network *net, unsigned int lac,
323 struct gsm_bts *start_bts);
Harald Welte32201c12009-03-10 12:15:10 +0000324
Andreas Eversberg8226fa72009-06-29 15:19:38 +0200325extern void *tall_bsc_ctx;
Harald Weltef88c8a02009-12-20 13:48:15 +0100326extern int ipacc_rtp_direct;
Harald Welte2cf161b2009-06-20 22:36:41 +0200327
Harald Weltef383aa12012-07-02 19:51:55 +0200328/* this actaully refers to the IPA transport, not the BTS model */
Harald Welte32201c12009-03-10 12:15:10 +0000329static inline int is_ipaccess_bts(struct gsm_bts *bts)
330{
331 switch (bts->type) {
Mike Habene2d82272009-10-02 12:19:34 +0100332 case GSM_BTS_TYPE_NANOBTS:
Maxf9685c12017-03-23 12:01:07 +0100333 case GSM_BTS_TYPE_OSMOBTS:
Harald Welte32201c12009-03-10 12:15:10 +0000334 return 1;
335 default:
336 break;
337 }
338 return 0;
339}
340
Holger Hans Peter Freyther6f6cbf72015-04-04 19:35:22 +0200341static inline int is_sysmobts_v2(struct gsm_bts *bts)
342{
343 switch (bts->type) {
Maxf9685c12017-03-23 12:01:07 +0100344 case GSM_BTS_TYPE_OSMOBTS:
Holger Hans Peter Freyther6f6cbf72015-04-04 19:35:22 +0200345 return 1;
346 default:
347 break;
348 }
349 return 0;
350}
351
Harald Welte5b570672009-08-10 10:08:01 +0200352static inline int is_siemens_bts(struct gsm_bts *bts)
353{
354 switch (bts->type) {
355 case GSM_BTS_TYPE_BS11:
356 return 1;
357 default:
358 break;
359 }
360
361 return 0;
362}
363
Andreas Eversberg7d8fa342013-12-05 13:25:06 +0100364static inline int is_nokia_bts(struct gsm_bts *bts)
365{
366 switch (bts->type) {
367 case GSM_BTS_TYPE_NOKIA_SITE:
368 return 1;
369 default:
370 break;
371 }
372
373 return 0;
374}
375
Andreas Eversbergdcf38e12013-12-05 14:37:11 +0100376static inline int is_e1_bts(struct gsm_bts *bts)
377{
378 switch (bts->type) {
379 case GSM_BTS_TYPE_BS11:
380 case GSM_BTS_TYPE_RBS2000:
381 case GSM_BTS_TYPE_NOKIA_SITE:
382 return 1;
383 default:
384 break;
385 }
386
387 return 0;
388}
389
Holger Hans Peter Freyther4e13a8f2015-01-31 22:16:00 +0100390enum bts_gprs_mode bts_gprs_mode_parse(const char *arg, int *valid);
Harald Welte4511d892010-04-18 15:51:20 +0200391const char *bts_gprs_mode_name(enum bts_gprs_mode mode);
Holger Hans Peter Freyther4e13a8f2015-01-31 22:16:00 +0100392int bts_gprs_mode_is_compat(struct gsm_bts *bts, enum bts_gprs_mode mode);
Harald Welte4511d892010-04-18 15:51:20 +0200393
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200394int gsm48_ra_id_by_bts(uint8_t *buf, struct gsm_bts *bts);
Harald Welte97a282b2010-03-14 15:37:43 +0800395void gprs_ra_id_by_bts(struct gprs_ra_id *raid, struct gsm_bts *bts);
Harald Welted12b0fd2009-12-15 21:36:05 +0100396
Harald Weltef3d8e922010-06-14 22:44:42 +0200397int gsm_btsmodel_set_feature(struct gsm_bts_model *model, enum gsm_bts_features feat);
Harald Weltefbda4e12010-03-04 11:04:52 +0100398int gsm_bts_model_register(struct gsm_bts_model *model);
399
Neels Hofmeyr42eb0142016-05-20 17:15:44 +0200400struct gsm_subscriber_connection *bsc_subscr_con_allocate(struct gsm_lchan *lchan);
401void bsc_subscr_con_free(struct gsm_subscriber_connection *conn);
402
403struct gsm_subscriber_connection *msc_subscr_con_allocate(struct gsm_network *network);
404void msc_subscr_con_free(struct gsm_subscriber_connection *conn);
Holger Hans Peter Freyther2412a072010-06-28 15:47:12 +0800405
Harald Welte3300c012011-06-05 13:31:33 +0200406struct gsm_bts *gsm_bts_alloc_register(struct gsm_network *net,
407 enum gsm_bts_type type,
Harald Weltea2bbc5e2015-11-20 10:43:31 +0100408 uint8_t bsic);
Harald Welte142d12d2014-12-29 17:47:08 +0100409
Harald Welte3300c012011-06-05 13:31:33 +0200410void set_ts_e1link(struct gsm_bts_trx_ts *ts, uint8_t e1_nr,
411 uint8_t e1_ts, uint8_t e1_ts_ss);
412
Maxbe356ed2017-09-07 19:10:09 +0200413void gsm_trx_lock_rf(struct gsm_bts_trx *trx, bool locked, const char *reason);
Max71d082b2017-05-30 15:03:38 +0200414bool gsm_btsmodel_has_feature(struct gsm_bts_model *model, enum gsm_bts_features feat);
Harald Welte3300c012011-06-05 13:31:33 +0200415struct gsm_bts_trx *gsm_bts_trx_by_nr(struct gsm_bts *bts, int nr);
Holger Hans Peter Freythera49b2c02014-11-21 11:18:45 +0100416int gsm_bts_trx_set_system_infos(struct gsm_bts_trx *trx);
Alexander Chemerisc36a13b2015-05-30 14:40:54 -0400417int gsm_bts_set_system_infos(struct gsm_bts *bts);
Harald Welte3300c012011-06-05 13:31:33 +0200418
Pablo Neira Ayusoed5cacb2011-08-17 22:44:07 +0200419/* generic E1 line operations for all ISDN-based BTS. */
420extern struct e1inp_line_ops bts_isdn_e1inp_line_ops;
421
Harald Weltee555c2b2012-08-17 13:02:12 +0200422extern const struct value_string bts_type_names[_NUM_GSM_BTS_TYPE+1];
423extern const struct value_string bts_type_descs[_NUM_GSM_BTS_TYPE+1];
424
Max3d049d22017-10-09 17:12:53 +0200425char *get_model_oml_status(const struct gsm_bts *bts);
426
Max25cc4072017-10-10 14:50:35 +0200427unsigned long long bts_uptime(const struct gsm_bts *bts);
428
Holger Hans Peter Freytherf8c42192013-01-09 17:03:27 +0100429/* control interface handling */
430int bsc_base_ctrl_cmds_install(void);
431
Holger Hans Peter Freytherc22930e2014-12-17 14:46:17 +0100432/* dependency handling */
433void bts_depend_mark(struct gsm_bts *bts, int dep);
434void bts_depend_clear(struct gsm_bts *bts, int dep);
435int bts_depend_check(struct gsm_bts *bts);
Holger Hans Peter Freytherf7e23c52014-12-17 15:44:32 +0100436int bts_depend_is_depedency(struct gsm_bts *base, struct gsm_bts *other);
Holger Hans Peter Freytherc22930e2014-12-17 14:46:17 +0100437
Harald Welte2f8b9d22017-06-18 11:12:13 +0300438int gsm_bts_get_radio_link_timeout(const struct gsm_bts *bts);
439void gsm_bts_set_radio_link_timeout(struct gsm_bts *bts, int value);
440
Harald Weltea43e0b42016-06-19 18:06:02 +0200441bool classmark_is_r99(struct gsm_classmark *cm);
442
Harald Welte6be350c2011-05-25 13:10:08 +0200443#endif /* _GSM_DATA_H */