blob: bc276d1f79b7bb233f8bd935ddeb9ceccf622fcf [file] [log] [blame]
Harald Welte52b1f982008-12-23 20:25:15 +00001#ifndef _GSM_DATA_H
2#define _GSM_DATA_H
3
Harald Welte52b1f982008-12-23 20:25:15 +00004
Holger Hans Peter Freyther3e8e0462010-09-15 22:29:25 +08005struct osmo_msc_data;
Holger Hans Peter Freyther2f9d1ef2010-09-16 20:14:01 +08006struct osmo_bsc_sccp_con;
Holger Hans Peter Freyther11b28f92010-12-24 13:48:27 +01007struct gsm_sms_queue;
Holger Hans Peter Freyther3e8e0462010-09-15 22:29:25 +08008
Harald Welte4bfdfe72009-06-10 23:11:52 +08009enum gsm_phys_chan_config {
10 GSM_PCHAN_NONE,
11 GSM_PCHAN_CCCH,
12 GSM_PCHAN_CCCH_SDCCH4,
13 GSM_PCHAN_TCH_F,
14 GSM_PCHAN_TCH_H,
15 GSM_PCHAN_SDCCH8_SACCH8C,
Harald Weltea1499d02009-10-24 10:25:50 +020016 GSM_PCHAN_PDCH, /* GPRS PDCH */
17 GSM_PCHAN_TCH_F_PDCH, /* TCH/F if used, PDCH otherwise */
Harald Welte4bfdfe72009-06-10 23:11:52 +080018 GSM_PCHAN_UNKNOWN,
19};
20
21enum gsm_chan_t {
22 GSM_LCHAN_NONE,
23 GSM_LCHAN_SDCCH,
24 GSM_LCHAN_TCH_F,
25 GSM_LCHAN_TCH_H,
26 GSM_LCHAN_UNKNOWN,
27};
28
Harald Welteeab84a12009-12-13 10:53:12 +010029/* RRLP mode of operation */
30enum rrlp_mode {
31 RRLP_MODE_NONE,
32 RRLP_MODE_MS_BASED,
33 RRLP_MODE_MS_PREF,
34 RRLP_MODE_ASS_PREF,
35};
Harald Welte4bfdfe72009-06-10 23:11:52 +080036
37/* Channel Request reason */
38enum gsm_chreq_reason_t {
39 GSM_CHREQ_REASON_EMERG,
40 GSM_CHREQ_REASON_PAG,
41 GSM_CHREQ_REASON_CALL,
42 GSM_CHREQ_REASON_LOCATION_UPD,
43 GSM_CHREQ_REASON_OTHER,
44};
45
Pablo Neira Ayuso136f4532011-03-22 16:47:59 +010046#include <osmocom/core/timer.h>
Harald Welte7401ae62010-06-15 16:44:12 +020047#include <openbsc/system_information.h>
Sylvain Munaute0b06b02010-11-28 18:17:28 +010048#include <openbsc/rest_octets.h>
Harald Welte4bfdfe72009-06-10 23:11:52 +080049#include <openbsc/mncc.h>
Harald Welte887deab2010-03-06 11:38:05 +010050
Pablo Neira Ayuso136f4532011-03-22 16:47:59 +010051#include <osmocom/gsm/tlv.h>
52#include <osmocom/core/bitvec.h>
53#include <osmocom/core/statistics.h>
54#include <osmocom/gsm/gsm_utils.h>
55#include <osmocom/core/utils.h>
56#include <osmocom/gsm/rxlev_stat.h>
Harald Welte8470bf22008-12-25 23:28:35 +000057
Pablo Neira Ayuso136f4532011-03-22 16:47:59 +010058#include <osmocom/gsm/protocol/gsm_08_58.h>
Sylvain Munaut81a8bf12010-12-01 22:28:59 +010059
60
Harald Welte85770c72009-01-18 17:47:32 +000061#define TRX_NR_TS 8
Harald Welte8470bf22008-12-25 23:28:35 +000062#define TS_MAX_LCHAN 8
Harald Welte52b1f982008-12-23 20:25:15 +000063
64#define HARDCODED_ARFCN 123
Harald Welte02b0e092009-02-28 13:11:07 +000065#define HARDCODED_TSC 7
Harald Welte78f2f502009-05-23 16:56:52 +000066#define HARDCODED_BSIC 0x3f /* NCC = 7 / BCC = 7 */
Harald Welte52b1f982008-12-23 20:25:15 +000067
Harald Welte63589be2009-08-06 17:38:10 +020068/* for multi-drop config */
69#define HARDCODED_BTS0_TS 1
70#define HARDCODED_BTS1_TS 6
71#define HARDCODED_BTS2_TS 11
72
Holger Hans Peter Freyther928ca742010-11-10 09:19:30 +010073/* reserved according to GSM 03.03 ยง 2.4 */
74#define GSM_RESERVED_TMSI 0xFFFFFFFF
75
Harald Welte8e1e3ee2009-02-01 13:32:45 +000076enum gsm_hooks {
77 GSM_HOOK_NM_SWLOAD,
Harald Welte0932d1e2009-02-16 22:53:52 +000078 GSM_HOOK_RR_PAGING,
Sylvain Munaut30a15382009-12-24 00:27:26 +010079 GSM_HOOK_RR_SECURITY,
Harald Welte0932d1e2009-02-16 22:53:52 +000080};
81
82enum gsm_paging_event {
83 GSM_PAGING_SUCCEEDED,
84 GSM_PAGING_EXPIRED,
Holger Freyther85a7b362009-04-18 13:48:55 +020085 GSM_PAGING_OOM,
Holger Hans Peter Freytherd3baf412010-12-23 18:19:17 +010086 GSM_PAGING_BUSY,
Harald Welte8e1e3ee2009-02-01 13:32:45 +000087};
88
Harald Welte4511d892010-04-18 15:51:20 +020089enum bts_gprs_mode {
90 BTS_GPRS_NONE = 0,
91 BTS_GPRS_GPRS = 1,
92 BTS_GPRS_EGPRS = 2,
93};
94
Holger Hans Peter Freyther6f615552010-11-15 20:50:42 +010095#define OBSC_NM_W_ACK_CB(__msgb) (__msgb)->cb[3]
96
Harald Welte0809d792010-04-30 14:36:25 +020097/* the data structure stored in msgb->cb for openbsc apps */
98struct openbsc_msgb_cb {
Harald Weltefd3fa1d2010-05-02 09:50:42 +020099 unsigned char *bssgph;
100 unsigned char *llch;
Harald Welte44f1c272010-04-30 19:54:29 +0200101
Harald Welte11d7c102010-05-02 11:54:55 +0200102 /* Cell Identifier */
103 unsigned char *bssgp_cell_id;
104
Harald Weltee6afd602010-05-02 11:19:37 +0200105 /* Identifiers of a BTS, equal to 'struct bssgp_bts_ctx' */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200106 uint16_t nsei;
107 uint16_t bvci;
Harald Welte44f1c272010-04-30 19:54:29 +0200108
Harald Weltee6afd602010-05-02 11:19:37 +0200109 /* Identifier of a MS (inside BTS), equal to 'struct sgsn_mm_ctx' */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200110 uint32_t tlli;
Harald Welte44f1c272010-04-30 19:54:29 +0200111} __attribute__((packed));
Harald Welte0809d792010-04-30 14:36:25 +0200112#define OBSC_MSGB_CB(__msgb) ((struct openbsc_msgb_cb *)&((__msgb)->cb[0]))
Harald Welte943c5bc2010-04-30 16:33:12 +0200113#define msgb_tlli(__x) OBSC_MSGB_CB(__x)->tlli
Harald Welte44f1c272010-04-30 19:54:29 +0200114#define msgb_nsei(__x) OBSC_MSGB_CB(__x)->nsei
115#define msgb_bvci(__x) OBSC_MSGB_CB(__x)->bvci
Harald Weltefd3fa1d2010-05-02 09:50:42 +0200116#define msgb_gmmh(__x) (__x)->l3h
117#define msgb_bssgph(__x) OBSC_MSGB_CB(__x)->bssgph
Harald Welte721961c2010-05-02 21:29:36 +0200118#define msgb_bssgp_len(__x) ((__x)->tail - (uint8_t *)msgb_bssgph(__x))
Harald Welte11d7c102010-05-02 11:54:55 +0200119#define msgb_bcid(__x) OBSC_MSGB_CB(__x)->bssgp_cell_id
Harald Weltefd3fa1d2010-05-02 09:50:42 +0200120#define msgb_llch(__x) OBSC_MSGB_CB(__x)->llch
Harald Welte0809d792010-04-30 14:36:25 +0200121
Holger Hans Peter Freyther9c595b72010-06-15 11:20:52 +0800122#define OBSC_LINKID_CB(__msgb) (__msgb)->cb[3]
123
Sylvain Munaut30a15382009-12-24 00:27:26 +0100124enum gsm_security_event {
125 GSM_SECURITY_NOAVAIL,
126 GSM_SECURITY_AUTH_FAILED,
127 GSM_SECURITY_SUCCEEDED,
128};
129
Harald Welte8e1e3ee2009-02-01 13:32:45 +0000130struct msgb;
131typedef int gsm_cbfn(unsigned int hooknum,
132 unsigned int event,
133 struct msgb *msg,
134 void *data, void *param);
135
Sylvain Munaut47193072009-12-27 21:56:14 +0100136/* Real authentication information containing Ki */
137enum gsm_auth_algo {
138 AUTH_ALGO_NONE,
139 AUTH_ALGO_XOR,
140 AUTH_ALGO_COMP128v1,
141};
142
143struct gsm_auth_info {
144 enum gsm_auth_algo auth_algo;
145 unsigned int a3a8_ki_len;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200146 uint8_t a3a8_ki[16];
Sylvain Munaut47193072009-12-27 21:56:14 +0100147};
148
149struct gsm_auth_tuple {
150 int use_count;
151 int key_seq;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200152 uint8_t rand[16];
153 uint8_t sres[4];
154 uint8_t kc[8];
Sylvain Munaut47193072009-12-27 21:56:14 +0100155};
Sylvain Munautb48216f2010-06-09 12:45:37 +0200156#define GSM_KEY_SEQ_INVAL 7 /* GSM 04.08 - 10.5.1.2 */
Sylvain Munaut47193072009-12-27 21:56:14 +0100157
158
Harald Welte49f48b82009-02-17 15:29:33 +0000159struct gsm_lchan;
160struct gsm_subscriber;
Harald Welte4bfdfe72009-06-10 23:11:52 +0800161struct gsm_mncc;
Harald Welte805f6442009-07-28 18:25:29 +0200162struct rtp_socket;
Holger Hans Peter Freytherabcddf12010-06-14 18:20:15 +0800163struct bsc_api;
Harald Welte49f48b82009-02-17 15:29:33 +0000164
Harald Weltebbcc7a52009-02-14 19:45:44 +0000165/* Network Management State */
166struct gsm_nm_state {
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200167 uint8_t operational;
168 uint8_t administrative;
169 uint8_t availability;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000170};
Harald Weltebbcc7a52009-02-14 19:45:44 +0000171
Holger Freyther73487a22008-12-31 18:53:57 +0000172/*
173 * LOCATION UPDATING REQUEST state
174 *
175 * Our current operation is:
176 * - Get imei/tmsi
177 * - Accept/Reject according to global policy
178 */
179struct gsm_loc_updating_operation {
Pablo Neira Ayusobf540cb2011-05-06 12:11:06 +0200180 struct osmo_timer_list updating_timer;
Holger Hans Peter Freyther251aa912009-10-27 10:42:28 +0100181 unsigned int waiting_for_imsi : 1;
182 unsigned int waiting_for_imei : 1;
Sylvain Munaut2030a2a2010-06-10 13:36:59 +0200183 unsigned int key_seq : 4;
Holger Freyther73487a22008-12-31 18:53:57 +0000184};
185
Sylvain Munaut30a15382009-12-24 00:27:26 +0100186/*
187 * AUTHENTICATION/CIPHERING state
188 */
189struct gsm_security_operation {
190 struct gsm_auth_tuple atuple;
191 gsm_cbfn *cb;
192 void *cb_data;
193};
194
Holger Hans Peter Freyther02d39b22010-07-05 15:34:16 +0800195/*
196 * A dummy to keep a connection up for at least
197 * a couple of seconds to work around MSC issues.
198 */
199struct gsm_anchor_operation {
Pablo Neira Ayusobf540cb2011-05-06 12:11:06 +0200200 struct osmo_timer_list timeout;
Holger Hans Peter Freyther02d39b22010-07-05 15:34:16 +0800201};
202
Harald Weltef7c28b02009-12-21 13:30:17 +0100203/* Maximum number of neighbor cells whose average we track */
204#define MAX_NEIGH_MEAS 10
205/* Maximum size of the averaging window for neighbor cells */
206#define MAX_WIN_NEIGH_AVG 10
207
208/* processed neighbor measurements for one cell */
209struct neigh_meas_proc {
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200210 uint16_t arfcn;
211 uint8_t bsic;
212 uint8_t rxlev[MAX_WIN_NEIGH_AVG];
Harald Weltef7c28b02009-12-21 13:30:17 +0100213 unsigned int rxlev_cnt;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200214 uint8_t last_seen_nr;
Harald Weltef7c28b02009-12-21 13:30:17 +0100215};
216
Harald Welte08d91a52009-08-30 15:37:11 +0900217#define MAX_A5_KEY_LEN (128/8)
Sylvain Munaute824d9c2010-06-11 00:19:42 +0200218#define A38_XOR_MIN_KEY_LEN 12
219#define A38_XOR_MAX_KEY_LEN 16
Sylvain Munaut30a15382009-12-24 00:27:26 +0100220#define A38_COMP128_KEY_LEN 16
Harald Welte08d91a52009-08-30 15:37:11 +0900221#define RSL_ENC_ALG_A5(x) (x+1)
222
Holger Hans Peter Freyther5ba6f482009-10-28 14:23:39 +0100223/* is the data link established? who established it? */
224#define LCHAN_SAPI_UNUSED 0
225#define LCHAN_SAPI_MS 1
226#define LCHAN_SAPI_NET 2
227
Harald Welteb8bfc562009-12-21 13:27:11 +0100228/* state of a logical channel */
229enum gsm_lchan_state {
230 LCHAN_S_NONE, /* channel is not active */
Harald Welte (local)3e460312009-12-27 18:12:29 +0100231 LCHAN_S_ACT_REQ, /* channel activatin requested */
Harald Welteb8bfc562009-12-21 13:27:11 +0100232 LCHAN_S_ACTIVE, /* channel is active and operational */
Harald Welte8e93b792009-12-29 10:44:17 +0100233 LCHAN_S_REL_REQ, /* channel release has been requested */
Holger Hans Peter Freyther4b4dd102010-05-31 21:38:24 +0800234 LCHAN_S_REL_ERR, /* channel is in an error state */
Harald Welteb8bfc562009-12-21 13:27:11 +0100235 LCHAN_S_INACTIVE, /* channel is set inactive */
236};
237
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100238/* the per subscriber data for lchan */
239struct gsm_subscriber_connection {
Holger Hans Peter Freyther79f763f2010-09-16 00:53:37 +0800240 struct llist_head entry;
241
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100242 /* To whom we are allocated at the moment */
243 struct gsm_subscriber *subscr;
244
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100245 /*
246 * Operations that have a state and might be pending
247 */
248 struct gsm_loc_updating_operation *loc_operation;
Sylvain Munaut30a15382009-12-24 00:27:26 +0100249 struct gsm_security_operation *sec_operation;
Holger Hans Peter Freyther02d39b22010-07-05 15:34:16 +0800250 struct gsm_anchor_operation *anch_operation;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100251
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100252 /* Are we part of a special "silent" call */
253 int silent_call;
Holger Hans Peter Freyther182c81f2010-12-29 16:28:33 +0100254 int put_channel;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100255
Holger Hans Peter Freyther2f9d1ef2010-09-16 20:14:01 +0800256 /* bsc structures */
257 struct osmo_bsc_sccp_con *sccp_con;
258
Holger Hans Peter Freyther18b63f42010-03-23 07:52:17 +0100259 /* back pointers */
Holger Hans Peter Freyther40494552010-06-28 17:09:29 +0800260 int in_release;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100261 struct gsm_lchan *lchan;
Holger Hans Peter Freythere071ab72010-06-30 12:40:10 +0800262 struct gsm_lchan *ho_lchan;
Holger Hans Peter Freyther18b63f42010-03-23 07:52:17 +0100263 struct gsm_bts *bts;
Holger Hans Peter Freyther77cd95d2010-11-14 16:19:48 +0100264
265 /* for assignment handling */
Pablo Neira Ayusobf540cb2011-05-06 12:11:06 +0200266 struct osmo_timer_list T10;
Holger Hans Peter Freyther77cd95d2010-11-14 16:19:48 +0100267 struct gsm_lchan *secondary_lchan;
268
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100269};
270
Harald Welte8470bf22008-12-25 23:28:35 +0000271struct gsm_lchan {
272 /* The TS that we're part of */
273 struct gsm_bts_trx_ts *ts;
274 /* The logical subslot number in the TS */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200275 uint8_t nr;
Harald Welte45b407a2009-05-23 15:51:12 +0000276 /* The logical channel type */
Harald Welte8470bf22008-12-25 23:28:35 +0000277 enum gsm_chan_t type;
Harald Welte9943c5b2009-07-29 15:41:29 +0200278 /* RSL channel mode */
279 enum rsl_cmod_spd rsl_cmode;
Harald Welte45b407a2009-05-23 15:51:12 +0000280 /* If TCH, traffic channel mode */
Harald Welte9943c5b2009-07-29 15:41:29 +0200281 enum gsm48_chan_mode tch_mode;
Harald Welteb8bfc562009-12-21 13:27:11 +0100282 /* State */
283 enum gsm_lchan_state state;
Harald Welted4c9bf32009-02-15 16:56:18 +0000284 /* Power levels for MS and BTS */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200285 uint8_t bs_power;
286 uint8_t ms_power;
Harald Welte08d91a52009-08-30 15:37:11 +0900287 /* Encryption information */
288 struct {
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200289 uint8_t alg_id;
290 uint8_t key_len;
291 uint8_t key[MAX_A5_KEY_LEN];
Harald Welte08d91a52009-08-30 15:37:11 +0900292 } encr;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100293
Pablo Neira Ayusobf540cb2011-05-06 12:11:06 +0200294 struct osmo_timer_list T3101;
295 struct osmo_timer_list T3111;
296 struct osmo_timer_list error_timer;
Holger Hans Peter Freytherea528022009-11-18 22:57:02 +0100297
298 /* AMR bits */
299 struct gsm48_multi_rate_conf mr_conf;
Harald Welted4c9bf32009-02-15 16:56:18 +0000300
Holger Hans Peter Freyther5ba6f482009-10-28 14:23:39 +0100301 /* Established data link layer services */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200302 uint8_t sapis[8];
Holger Hans Peter Freyther4b85a322010-07-29 17:09:36 +0800303 int sach_deact;
304 int release_reason;
Holger Hans Peter Freyther5ba6f482009-10-28 14:23:39 +0100305
Holger Hans Peter Freyther5ba05f42010-06-22 12:11:59 +0800306 /* GSM Random Access data */
307 struct gsm48_req_ref *rqd_ref;
308 uint8_t rqd_ta;
309
Harald Welted12b0fd2009-12-15 21:36:05 +0100310 /* cache of last measurement reports on this lchan */
311 struct gsm_meas_rep meas_rep[6];
312 int meas_rep_idx;
313
Harald Weltef7c28b02009-12-21 13:30:17 +0100314 /* table of neighbor cell measurements */
315 struct neigh_meas_proc neigh_meas[MAX_NEIGH_MEAS];
316
Harald Welte2c828992009-12-02 01:56:49 +0530317 struct {
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200318 uint32_t bound_ip;
319 uint32_t connect_ip;
320 uint16_t bound_port;
321 uint16_t connect_port;
322 uint16_t conn_id;
323 uint8_t rtp_payload;
324 uint8_t rtp_payload2;
325 uint8_t speech_mode;
Harald Welte2c828992009-12-02 01:56:49 +0530326 struct rtp_socket *rtp_socket;
327 } abis_ip;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100328
Holger Hans Peter Freyther2412a072010-06-28 15:47:12 +0800329 struct gsm_subscriber_connection *conn;
Harald Welte8470bf22008-12-25 23:28:35 +0000330};
331
Harald Welte85770c72009-01-18 17:47:32 +0000332struct gsm_e1_subslot {
333 /* Number of E1 link */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200334 uint8_t e1_nr;
Harald Welte85770c72009-01-18 17:47:32 +0000335 /* Number of E1 TS inside E1 link */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200336 uint8_t e1_ts;
Harald Welte85770c72009-01-18 17:47:32 +0000337 /* Sub-slot within the E1 TS, 0xff if full TS */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200338 uint8_t e1_ts_ss;
Harald Welte85770c72009-01-18 17:47:32 +0000339};
340
Harald Welte4563eab2010-03-28 14:42:09 +0800341#define TS_F_PDCH_MODE 0x1000
Harald Welte52b1f982008-12-23 20:25:15 +0000342/* One Timeslot in a TRX */
343struct gsm_bts_trx_ts {
344 struct gsm_bts_trx *trx;
345 /* number of this timeslot at the TRX */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200346 uint8_t nr;
Harald Welte52b1f982008-12-23 20:25:15 +0000347
Harald Welte8470bf22008-12-25 23:28:35 +0000348 enum gsm_phys_chan_config pchan;
349
Harald Welte52b1f982008-12-23 20:25:15 +0000350 unsigned int flags;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000351 struct gsm_nm_state nm_state;
Harald Welte93e9d172009-06-20 19:04:31 +0200352 struct tlv_parsed nm_attr;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200353 uint8_t nm_chan_comb;
Harald Welte8470bf22008-12-25 23:28:35 +0000354
Harald Welte6e0cd042009-09-12 13:05:33 +0200355 struct {
Harald Weltefd370892010-06-15 08:52:12 +0200356 /* Parameters below are configured by VTY */
Harald Weltea39b0f22010-06-14 22:26:10 +0200357 int enabled;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200358 uint8_t maio;
359 uint8_t hsn;
Harald Weltea39b0f22010-06-14 22:26:10 +0200360 struct bitvec arfcns;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200361 uint8_t arfcns_data[1024/8];
Harald Weltefd370892010-06-15 08:52:12 +0200362 /* This is the pre-computed MA for channel assignments */
363 struct bitvec ma;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200364 uint8_t ma_len; /* part of ma_data that is used */
365 uint8_t ma_data[8]; /* 10.5.2.21: max 8 bytes value part */
Harald Welte6e0cd042009-09-12 13:05:33 +0200366 } hopping;
367
Harald Welte85770c72009-01-18 17:47:32 +0000368 /* To which E1 subslot are we connected */
369 struct gsm_e1_subslot e1_link;
370
Harald Welte8470bf22008-12-25 23:28:35 +0000371 struct gsm_lchan lchan[TS_MAX_LCHAN];
Harald Welte52b1f982008-12-23 20:25:15 +0000372};
373
374/* One TRX in a BTS */
375struct gsm_bts_trx {
Harald Weltee441d9c2009-06-21 16:17:15 +0200376 /* list header in bts->trx_list */
377 struct llist_head list;
378
Harald Welte52b1f982008-12-23 20:25:15 +0000379 struct gsm_bts *bts;
380 /* number of this TRX in the BTS */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200381 uint8_t nr;
Harald Welte197dea92010-05-14 17:59:53 +0200382 /* human readable name / description */
383 char *description;
Harald Welte1fa60c82009-02-09 18:13:26 +0000384 /* how do we talk RSL with this TRX? */
Harald Welte42581822009-08-08 16:12:58 +0200385 struct gsm_e1_subslot rsl_e1_link;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200386 uint8_t rsl_tei;
Harald Welte1fa60c82009-02-09 18:13:26 +0000387 struct e1inp_sign_link *rsl_link;
Harald Welte15ccc772011-02-13 19:36:18 +0100388 /* Some BTS (specifically Ericsson RBS) have a per-TRX OML Link */
389 struct e1inp_sign_link *oml_link;
Harald Welte42581822009-08-08 16:12:58 +0200390
Harald Weltebbcc7a52009-02-14 19:45:44 +0000391 struct gsm_nm_state nm_state;
Harald Welte93e9d172009-06-20 19:04:31 +0200392 struct tlv_parsed nm_attr;
Harald Welte8c1d0e42009-02-15 03:38:12 +0000393 struct {
394 struct gsm_nm_state nm_state;
395 } bb_transc;
Harald Welte52b1f982008-12-23 20:25:15 +0000396
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200397 uint16_t arfcn;
Harald Weltefcd24452009-06-20 18:15:19 +0200398 int nominal_power; /* in dBm */
399 unsigned int max_power_red; /* in actual dB */
Harald Welte8b697c72009-06-05 19:18:45 +0000400
401 union {
402 struct {
403 struct {
404 struct gsm_nm_state nm_state;
405 } bbsig;
406 struct {
407 struct gsm_nm_state nm_state;
408 } pa;
409 } bs11;
Harald Welte549faad2010-03-05 19:36:20 +0100410 struct {
411 unsigned int test_state;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200412 uint8_t test_nr;
Harald Welte887deab2010-03-06 11:38:05 +0100413 struct rxlev_stats rxlev_stat;
Harald Welte549faad2010-03-05 19:36:20 +0100414 } ipaccess;
Harald Welte8b697c72009-06-05 19:18:45 +0000415 };
Harald Welte85770c72009-01-18 17:47:32 +0000416 struct gsm_bts_trx_ts ts[TRX_NR_TS];
Harald Welte52b1f982008-12-23 20:25:15 +0000417};
418
Harald Welte7401ae62010-06-15 16:44:12 +0200419#define GSM_BTS_SI(bts, i) (void *)(bts->si_buf[i])
420
Harald Welte978cb422009-01-18 17:57:27 +0000421enum gsm_bts_type {
422 GSM_BTS_TYPE_UNKNOWN,
423 GSM_BTS_TYPE_BS11,
Mike Habene2d82272009-10-02 12:19:34 +0100424 GSM_BTS_TYPE_NANOBTS,
Harald Weltedb44f602011-02-11 18:36:18 +0100425 GSM_BTS_TYPE_RBS2000,
Harald Weltefd355a32011-03-04 13:41:31 +0100426 GSM_BTS_TYPE_HSL_FEMTO,
Harald Welte978cb422009-01-18 17:57:27 +0000427};
428
Harald Welteface7ed2011-02-14 16:15:21 +0100429struct vty;
430
Harald Welte39315c42010-01-10 18:01:52 +0100431struct gsm_bts_model {
432 struct llist_head list;
433
434 enum gsm_bts_type type;
435 const char *name;
436
Harald Welte09cefee2011-02-12 12:29:21 +0100437 int (*oml_rcvmsg)(struct msgb *msg);
438
Harald Welteface7ed2011-02-14 16:15:21 +0100439 void (*config_write_bts)(struct vty *vty, struct gsm_bts *bts);
440 void (*config_write_trx)(struct vty *vty, struct gsm_bts_trx *trx);
441 void (*config_write_ts)(struct vty *vty, struct gsm_bts_trx_ts *ts);
442
Harald Welte39315c42010-01-10 18:01:52 +0100443 struct tlv_definition nm_att_tlvdef;
Harald Weltef3d8e922010-06-14 22:44:42 +0200444
445 struct bitvec features;
446 uint8_t _features_data[128/8];
447};
448
449enum gsm_bts_features {
450 BTS_FEAT_HSCSD,
451 BTS_FEAT_GPRS,
452 BTS_FEAT_EGPRS,
453 BTS_FEAT_ECSD,
454 BTS_FEAT_HOPPING,
Harald Welte39315c42010-01-10 18:01:52 +0100455};
456
Holger Freytherceb59b72009-02-06 18:54:00 +0000457/*
458 * This keeps track of the paging status of one BTS. It
459 * includes a number of pending requests, a back pointer
460 * to the gsm_bts, a timer and some more state.
461 */
462struct gsm_bts_paging_state {
Holger Freytherceb59b72009-02-06 18:54:00 +0000463 /* pending requests */
464 struct llist_head pending_requests;
Holger Freytherceb59b72009-02-06 18:54:00 +0000465 struct gsm_bts *bts;
466
Pablo Neira Ayusobf540cb2011-05-06 12:11:06 +0200467 struct osmo_timer_list work_timer;
468 struct osmo_timer_list credit_timer;
Harald Welte75a1fa82009-02-17 01:39:41 +0000469
Holger Hans Peter Freythere66bf1f2010-09-06 10:11:25 +0800470 /* free chans needed */
471 int free_chans_need;
472
Holger Freyther392209c2009-02-10 00:06:19 +0000473 /* load */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200474 uint16_t available_slots;
Holger Freytherceb59b72009-02-06 18:54:00 +0000475};
476
Harald Welte8b697c72009-06-05 19:18:45 +0000477struct gsm_envabtse {
478 struct gsm_nm_state nm_state;
479};
480
Harald Welte55dd4432009-10-24 10:19:14 +0200481struct gsm_bts_gprs_nsvc {
482 struct gsm_bts *bts;
Harald Welteab88a622010-03-18 00:01:23 +0800483 /* data read via VTY config file, to configure the BTS
484 * via OML from BSC */
Harald Welte55dd4432009-10-24 10:19:14 +0200485 int id;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200486 uint16_t nsvci;
487 uint16_t local_port; /* on the BTS */
488 uint16_t remote_port; /* on the SGSN */
489 uint32_t remote_ip; /* on the SGSN */
Harald Welteab88a622010-03-18 00:01:23 +0800490
Harald Welte55dd4432009-10-24 10:19:14 +0200491 struct gsm_nm_state nm_state;
492};
493
Harald Welte64c07d22011-02-15 11:43:27 +0100494enum neigh_list_manual_mode {
495 NL_MODE_AUTOMATIC = 0,
496 NL_MODE_MANUAL = 1,
497 NL_MODE_MANUAL_SI5SEP = 2, /* SI2 and SI5 have separate neighbor lists */
498};
499
Harald Welte52b1f982008-12-23 20:25:15 +0000500/* One BTS */
501struct gsm_bts {
Harald Weltee441d9c2009-06-21 16:17:15 +0200502 /* list header in net->bts_list */
503 struct llist_head list;
504
Harald Welte52b1f982008-12-23 20:25:15 +0000505 struct gsm_network *network;
506 /* number of ths BTS in network */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200507 uint8_t nr;
Harald Welte197dea92010-05-14 17:59:53 +0200508 /* human readable name / description */
509 char *description;
Holger Hans Peter Freytherc4a49e32009-08-21 14:44:12 +0200510 /* Cell Identity */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200511 uint16_t cell_identity;
Harald Welte52b1f982008-12-23 20:25:15 +0000512 /* location area code of this BTS */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200513 uint16_t location_area_code;
Harald Welte02b0e092009-02-28 13:11:07 +0000514 /* Training Sequence Code */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200515 uint8_t tsc;
Harald Welte78f2f502009-05-23 16:56:52 +0000516 /* Base Station Identification Code (BSIC) */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200517 uint8_t bsic;
Harald Welte978cb422009-01-18 17:57:27 +0000518 /* type of BTS */
519 enum gsm_bts_type type;
Harald Welte39315c42010-01-10 18:01:52 +0100520 struct gsm_bts_model *model;
Harald Weltefcd24452009-06-20 18:15:19 +0200521 enum gsm_band band;
Harald Weltefc0d9522009-08-10 13:46:55 +0200522 /* should the channel allocator allocate channels from high TRX to TRX0,
523 * rather than starting from TRX0 and go upwards? */
524 int chan_alloc_reverse;
Harald Welte (local)0e451d02009-08-13 10:14:26 +0200525 /* maximum Tx power that the MS is permitted to use in this cell */
526 int ms_max_power;
Harald Weltefc0d9522009-08-10 13:46:55 +0200527
Harald Welte1fa60c82009-02-09 18:13:26 +0000528 /* how do we talk OML with this TRX? */
Harald Welte42581822009-08-08 16:12:58 +0200529 struct gsm_e1_subslot oml_e1_link;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200530 uint8_t oml_tei;
Harald Welte1fa60c82009-02-09 18:13:26 +0000531 struct e1inp_sign_link *oml_link;
Harald Welte52b1f982008-12-23 20:25:15 +0000532
533 /* Abis network management O&M handle */
534 struct abis_nm_h *nmh;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000535 struct gsm_nm_state nm_state;
Harald Welte93e9d172009-06-20 19:04:31 +0200536 struct tlv_parsed nm_attr;
Harald Welte978cb422009-01-18 17:57:27 +0000537
Harald Welte52b1f982008-12-23 20:25:15 +0000538 /* number of this BTS on given E1 link */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200539 uint8_t bts_nr;
Harald Welte52b1f982008-12-23 20:25:15 +0000540
Holger Freytherceb59b72009-02-06 18:54:00 +0000541 /* paging state and control */
542 struct gsm_bts_paging_state paging;
543
Harald Welte52b1f982008-12-23 20:25:15 +0000544 /* CCCH is on C0 */
545 struct gsm_bts_trx *c0;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000546
547 struct {
548 struct gsm_nm_state nm_state;
549 } site_mgr;
Harald Welteedb37782009-05-01 14:59:07 +0000550
Harald Welte64c07d22011-02-15 11:43:27 +0100551 enum neigh_list_manual_mode neigh_list_manual_mode;
Harald Weltea43f7892009-12-01 18:04:30 +0530552 /* parameters from which we build SYSTEM INFORMATION */
553 struct {
554 struct gsm48_rach_control rach_control;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200555 uint8_t ncc_permitted;
Harald Weltea43f7892009-12-01 18:04:30 +0530556 struct gsm48_cell_sel_par cell_sel_par;
Sylvain Munaute0b06b02010-11-28 18:17:28 +0100557 struct gsm48_si_selection_params cell_ro_sel_par; /* rest octet */
Harald Weltea43f7892009-12-01 18:04:30 +0530558 struct gsm48_cell_options cell_options;
559 struct gsm48_control_channel_descr chan_desc;
Harald Welte6c40def2009-12-14 22:07:14 +0100560 struct bitvec neigh_list;
561 struct bitvec cell_alloc;
Harald Welte64c07d22011-02-15 11:43:27 +0100562 struct bitvec si5_neigh_list;
Harald Welte6c40def2009-12-14 22:07:14 +0100563 struct {
564 /* bitmask large enough for all possible ARFCN's */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200565 uint8_t neigh_list[1024/8];
566 uint8_t cell_alloc[1024/8];
Harald Welte64c07d22011-02-15 11:43:27 +0100567 /* If the user wants a different neighbor list in SI5 than in SI2 */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200568 uint8_t si5_neigh_list[1024/8];
Harald Welte6c40def2009-12-14 22:07:14 +0100569 } data;
Harald Weltea43f7892009-12-01 18:04:30 +0530570 } si_common;
571
Harald Welte9fbff4a2010-07-30 11:50:09 +0200572 /* do we use static (user-defined) system information messages? (bitmask) */
573 uint32_t si_mode_static;
574 /* bitmask of all SI that are present/valid in si_buf */
575 uint32_t si_valid;
Harald Welte7401ae62010-06-15 16:44:12 +0200576 /* buffers where we put the pre-computed SI */
577 sysinfo_buf_t si_buf[_MAX_SYSINFO_TYPE];
578
Harald Welteedb37782009-05-01 14:59:07 +0000579 /* ip.accesss Unit ID's have Site/BTS/TRX layout */
Harald Welte7b26bcb2009-05-28 11:39:21 +0000580 union {
581 struct {
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200582 uint16_t site_id;
583 uint16_t bts_id;
584 uint32_t flags;
Harald Welte7b26bcb2009-05-28 11:39:21 +0000585 } ip_access;
586 struct {
587 struct {
588 struct gsm_nm_state nm_state;
589 } cclk;
590 struct {
591 struct gsm_nm_state nm_state;
592 } rack;
Harald Welte8b697c72009-06-05 19:18:45 +0000593 struct gsm_envabtse envabtse[4];
Harald Welte7b26bcb2009-05-28 11:39:21 +0000594 } bs11;
Harald Weltea8e6a652011-02-13 22:13:28 +0100595 struct {
596 struct {
Harald Welteaf9b8102011-03-06 21:20:38 +0100597 struct gsm_nm_state nm_state;
Harald Weltea8e6a652011-02-13 22:13:28 +0100598 struct llist_head conn_groups;
599 } is;
Harald Weltea02085d2011-02-13 22:45:02 +0100600 struct {
Harald Welteaf9b8102011-03-06 21:20:38 +0100601 struct gsm_nm_state nm_state;
Harald Weltea02085d2011-02-13 22:45:02 +0100602 struct llist_head conn_groups;
603 } con;
Harald Welteaf9b8102011-03-06 21:20:38 +0100604 struct {
605 struct gsm_nm_state nm_state;
606 } dp;
607 struct {
608 struct gsm_nm_state nm_state;
609 } tf;
Harald Weltea8e6a652011-02-13 22:13:28 +0100610 } rbs2000;
Harald Weltefd355a32011-03-04 13:41:31 +0100611 struct {
612 unsigned long serno;
613 } hsl;
Harald Welte7b26bcb2009-05-28 11:39:21 +0000614 };
Harald Welte55dd4432009-10-24 10:19:14 +0200615
616 /* Not entirely sure how ip.access specific this is */
617 struct {
Harald Welte4511d892010-04-18 15:51:20 +0200618 enum bts_gprs_mode mode;
Harald Welte55dd4432009-10-24 10:19:14 +0200619 struct {
620 struct gsm_nm_state nm_state;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200621 uint16_t nsei;
Harald Welte615e9562010-05-11 23:50:21 +0200622 uint8_t timer[7];
Harald Welte55dd4432009-10-24 10:19:14 +0200623 } nse;
624 struct {
625 struct gsm_nm_state nm_state;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200626 uint16_t bvci;
Harald Welte615e9562010-05-11 23:50:21 +0200627 uint8_t timer[11];
Harald Welte55dd4432009-10-24 10:19:14 +0200628 } cell;
629 struct gsm_bts_gprs_nsvc nsvc[2];
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200630 uint8_t rac;
Harald Welte55dd4432009-10-24 10:19:14 +0200631 } gprs;
Holger Hans Peter Freyther95c22902010-04-25 23:08:39 +0800632
633 /* RACH NM values */
634 int rach_b_thresh;
635 int rach_ldavg_slots;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000636
Harald Welte52b1f982008-12-23 20:25:15 +0000637 /* transceivers */
638 int num_trx;
Harald Weltee441d9c2009-06-21 16:17:15 +0200639 struct llist_head trx_list;
Holger Hans Peter Freyther6f615552010-11-15 20:50:42 +0100640
641 /* Abis NM queue */
642 struct llist_head abis_queue;
643 int abis_nm_pend;
Harald Welte52b1f982008-12-23 20:25:15 +0000644};
645
Harald Welte24ff6ee2009-12-22 00:41:05 +0100646/* Some statistics of our network */
647struct gsmnet_stats {
648 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200649 struct osmo_counter *total;
650 struct osmo_counter *no_channel;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100651 } chreq;
652 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200653 struct osmo_counter *attempted;
654 struct osmo_counter *no_channel; /* no channel available */
655 struct osmo_counter *timeout; /* T3103 timeout */
656 struct osmo_counter *completed; /* HO COMPL received */
657 struct osmo_counter *failed; /* HO FAIL received */
Harald Welte24ff6ee2009-12-22 00:41:05 +0100658 } handover;
659 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200660 struct osmo_counter *attach;
661 struct osmo_counter *normal;
662 struct osmo_counter *periodic;
663 struct osmo_counter *detach;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100664 } loc_upd_type;
665 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200666 struct osmo_counter *reject;
667 struct osmo_counter *accept;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100668 } loc_upd_resp;
669 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200670 struct osmo_counter *attempted;
671 struct osmo_counter *detached;
672 struct osmo_counter *completed;
673 struct osmo_counter *expired;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100674 } paging;
675 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200676 struct osmo_counter *submitted; /* MO SMS submissions */
677 struct osmo_counter *no_receiver;
678 struct osmo_counter *delivered; /* MT SMS deliveries */
679 struct osmo_counter *rp_err_mem;
680 struct osmo_counter *rp_err_other;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100681 } sms;
682 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200683 struct osmo_counter *mo_setup;
684 struct osmo_counter *mo_connect_ack;
685 struct osmo_counter *mt_setup;
686 struct osmo_counter *mt_connect;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100687 } call;
Holger Hans Peter Freyther3ba36d52010-04-17 06:48:29 +0200688 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200689 struct osmo_counter *rf_fail;
690 struct osmo_counter *rll_err;
Holger Hans Peter Freyther3ba36d52010-04-17 06:48:29 +0200691 } chan;
Holger Hans Peter Freytherbb110f92010-04-12 10:45:52 +0200692 struct {
Pablo Neira Ayusodfb342c2011-05-06 12:13:10 +0200693 struct osmo_counter *oml_fail;
694 struct osmo_counter *rsl_fail;
Holger Hans Peter Freytherbb110f92010-04-12 10:45:52 +0200695 } bts;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100696};
697
Harald Welte (local)69de3972009-08-12 14:42:23 +0200698enum gsm_auth_policy {
699 GSM_AUTH_POLICY_CLOSED, /* only subscribers authorized in DB */
700 GSM_AUTH_POLICY_ACCEPT_ALL, /* accept everyone, even if not authorized in DB */
701 GSM_AUTH_POLICY_TOKEN, /* accept first, send token per sms, then revoke authorization */
702};
703
Harald Welteb84ddfc2009-12-01 17:36:54 +0530704#define GSM_T3101_DEFAULT 10
705#define GSM_T3113_DEFAULT 60
706
Harald Welte52b1f982008-12-23 20:25:15 +0000707struct gsm_network {
708 /* global parameters */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200709 uint16_t country_code;
710 uint16_t network_code;
Harald Weltec6ba9c22008-12-30 18:01:02 +0000711 char *name_long;
712 char *name_short;
Harald Welte (local)69de3972009-08-12 14:42:23 +0200713 enum gsm_auth_policy auth_policy;
Harald Welte1085c092009-11-18 20:33:19 +0100714 enum gsm48_reject_value reject_cause;
Harald Welte4381cfe2009-08-30 15:47:06 +0900715 int a5_encryption;
Holger Hans Peter Freytherf7d752f2009-11-16 17:12:38 +0100716 int neci;
Harald Welte648b6ce2009-12-14 09:00:24 +0100717 int send_mm_info;
Harald Weltebc814502009-12-19 21:41:52 +0100718 struct {
719 int active;
Harald Weltef7c28b02009-12-21 13:30:17 +0100720 /* Window RXLEV averaging */
721 unsigned int win_rxlev_avg; /* number of SACCH frames */
722 /* Window RXQUAL averaging */
723 unsigned int win_rxqual_avg; /* number of SACCH frames */
724 /* Window RXLEV neighbouring cells averaging */
725 unsigned int win_rxlev_avg_neigh; /* number of SACCH frames */
726
727 /* how often should we check for power budget HO */
728 unsigned int pwr_interval; /* SACCH frames */
729 /* how much better does a neighbor cell have to be ? */
730 unsigned int pwr_hysteresis; /* dBm */
731 /* maximum distacne before we try a handover */
732 unsigned int max_distance; /* TA values */
Harald Weltebc814502009-12-19 21:41:52 +0100733 } handover;
Harald Welte52b1f982008-12-23 20:25:15 +0000734
Harald Welte24ff6ee2009-12-22 00:41:05 +0100735 struct gsmnet_stats stats;
736
Harald Welte4bfdfe72009-06-10 23:11:52 +0800737 /* layer 4 */
Harald Welte29b64e92010-12-23 01:07:46 +0100738 int (*mncc_recv) (struct gsm_network *net, struct msgb *msg);
Harald Welte4bfdfe72009-06-10 23:11:52 +0800739 struct llist_head upqueue;
740 struct llist_head trans_list;
Holger Hans Peter Freytherabcddf12010-06-14 18:20:15 +0800741 struct bsc_api *bsc_api;
Harald Welte4bfdfe72009-06-10 23:11:52 +0800742
Harald Welte52b1f982008-12-23 20:25:15 +0000743 unsigned int num_bts;
Harald Weltee441d9c2009-06-21 16:17:15 +0200744 struct llist_head bts_list;
Holger Hans Peter Freytherc4d88ad2009-11-21 21:18:38 +0100745
746 /* timer values */
747 int T3101;
Holger Hans Peter Freyther23975e72009-11-21 21:42:26 +0100748 int T3103;
749 int T3105;
750 int T3107;
751 int T3109;
752 int T3111;
753 int T3113;
754 int T3115;
755 int T3117;
756 int T3119;
Harald Welte2862dca2010-12-23 14:39:29 +0100757 int T3122;
Holger Hans Peter Freyther23975e72009-11-21 21:42:26 +0100758 int T3141;
Harald Welteeab84a12009-12-13 10:53:12 +0100759
760 /* Radio Resource Location Protocol (TS 04.31) */
761 struct {
762 enum rrlp_mode mode;
763 } rrlp;
Holger Hans Peter Freyther5a3a61d2010-09-06 09:25:48 +0800764
765 /* enable the DTXu and DTXd for this network */
766 int dtx_enabled;
767
Holger Hans Peter Freyther78891072010-09-06 09:36:02 +0800768 enum gsm_chan_t ctype_by_chreq[16];
769
Holger Hans Peter Freyther76fc4a32010-09-06 09:41:50 +0800770 /* Use a TCH for handling requests of type paging any */
771 int pag_any_tch;
772
Holger Hans Peter Freyther3e8e0462010-09-15 22:29:25 +0800773 /* MSC data in case we are a true BSC */
774 struct osmo_msc_data *msc_data;
Holger Hans Peter Freyther8cc59032010-11-14 21:09:08 +0100775 int hardcoded_rtp_payload;
Holger Hans Peter Freytherdaee5ca2010-12-22 12:34:39 +0100776
777 /* subscriber related features */
778 int keep_subscr;
Holger Hans Peter Freyther11b28f92010-12-24 13:48:27 +0100779 struct gsm_sms_queue *sms_queue;
Harald Welte52b1f982008-12-23 20:25:15 +0000780};
781
Harald Welte7e310b12009-03-30 20:56:32 +0000782#define SMS_HDR_SIZE 128
783#define SMS_TEXT_SIZE 256
784struct gsm_sms {
Harald Welted409be72009-11-07 00:06:19 +0900785 unsigned long long id;
Harald Welte7e310b12009-03-30 20:56:32 +0000786 struct gsm_subscriber *sender;
787 struct gsm_subscriber *receiver;
788
Harald Welteb9c758b2009-07-05 14:02:46 +0200789 unsigned long validity_minutes;
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200790 uint8_t reply_path_req;
791 uint8_t status_rep_req;
792 uint8_t ud_hdr_ind;
793 uint8_t protocol_id;
794 uint8_t data_coding_scheme;
795 uint8_t msg_ref;
Harald Welte76042182009-08-08 16:03:15 +0200796 char dest_addr[20+1]; /* DA LV is 12 bytes max, i.e. 10 bytes
797 * BCD == 20 bytes string */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200798 uint8_t user_data_len;
799 uint8_t user_data[SMS_TEXT_SIZE];
Harald Weltef3efc592009-07-27 20:11:35 +0200800
Harald Welte7e310b12009-03-30 20:56:32 +0000801 char text[SMS_TEXT_SIZE];
802};
803
Harald Welte3606cc52009-12-05 15:13:22 +0530804
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200805struct gsm_network *gsm_network_init(uint16_t country_code, uint16_t network_code,
Harald Welte29b64e92010-12-23 01:07:46 +0100806 int (*mncc_recv)(struct gsm_network *, struct msgb *));
Harald Weltee441d9c2009-06-21 16:17:15 +0200807struct gsm_bts *gsm_bts_alloc(struct gsm_network *net, enum gsm_bts_type type,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200808 uint8_t tsc, uint8_t bsic);
Harald Weltee441d9c2009-06-21 16:17:15 +0200809struct gsm_bts_trx *gsm_bts_trx_alloc(struct gsm_bts *bts);
Harald Welte39315c42010-01-10 18:01:52 +0100810int gsm_set_bts_type(struct gsm_bts *bts, enum gsm_bts_type type);
Harald Weltee441d9c2009-06-21 16:17:15 +0200811
812struct gsm_bts *gsm_bts_num(struct gsm_network *net, int num);
Harald Welte84874c92009-12-14 22:33:02 +0100813
814/* Get reference to a neighbor cell on a given BCCH ARFCN */
Harald Welte0b121032009-12-15 00:21:31 +0100815struct gsm_bts *gsm_bts_neighbor(const struct gsm_bts *bts,
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200816 uint16_t arfcn, uint8_t bsic);
Harald Welte84874c92009-12-14 22:33:02 +0100817
Harald Weltee441d9c2009-06-21 16:17:15 +0200818struct gsm_bts_trx *gsm_bts_trx_num(struct gsm_bts *bts, int num);
Harald Welte8470bf22008-12-25 23:28:35 +0000819
Harald Weltea72c98e2009-01-04 16:10:38 +0000820const char *gsm_pchan_name(enum gsm_phys_chan_config c);
Harald Welte65da9122009-08-07 00:32:22 +0200821enum gsm_phys_chan_config gsm_pchan_parse(const char *name);
Harald Welte (local)ccd88452009-12-27 18:05:25 +0100822const char *gsm_lchant_name(enum gsm_chan_t c);
Harald Weltea72c98e2009-01-04 16:10:38 +0000823const char *gsm_chreq_name(enum gsm_chreq_reason_t c);
Harald Welte (local)d48f4eb2009-12-28 23:14:22 +0100824char *gsm_trx_name(struct gsm_bts_trx *trx);
Harald Welte23a68632009-02-19 17:06:42 +0000825char *gsm_ts_name(struct gsm_bts_trx_ts *ts);
Harald Welte (local)19ef62a2009-12-27 18:16:36 +0100826char *gsm_lchan_name(struct gsm_lchan *lchan);
Harald Welte1887f9d2009-12-29 10:52:38 +0100827const char *gsm_lchans_name(enum gsm_lchan_state s);
Harald Weltea72c98e2009-01-04 16:10:38 +0000828
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200829void set_ts_e1link(struct gsm_bts_trx_ts *ts, uint8_t e1_nr,
830 uint8_t e1_ts, uint8_t e1_ts_ss);
Harald Welte1d014a52009-08-08 15:38:29 +0200831enum gsm_bts_type parse_btstype(const char *arg);
Holger Hans Peter Freyther2dceae62009-06-12 17:39:38 +0200832const char *btstype2str(enum gsm_bts_type type);
Harald Welte6e670aa2010-01-07 20:44:32 +0100833struct gsm_bts_trx *gsm_bts_trx_by_nr(struct gsm_bts *bts, int nr);
Harald Weltebe991492009-05-23 13:56:40 +0000834struct gsm_bts *gsm_bts_by_lac(struct gsm_network *net, unsigned int lac,
835 struct gsm_bts *start_bts);
Harald Welte32201c12009-03-10 12:15:10 +0000836
Andreas Eversberg8226fa72009-06-29 15:19:38 +0200837extern void *tall_bsc_ctx;
Harald Weltef88c8a02009-12-20 13:48:15 +0100838extern int ipacc_rtp_direct;
Harald Welte2cf161b2009-06-20 22:36:41 +0200839
Harald Welte32201c12009-03-10 12:15:10 +0000840static inline int is_ipaccess_bts(struct gsm_bts *bts)
841{
842 switch (bts->type) {
Mike Habene2d82272009-10-02 12:19:34 +0100843 case GSM_BTS_TYPE_NANOBTS:
Harald Welte32201c12009-03-10 12:15:10 +0000844 return 1;
845 default:
846 break;
847 }
848 return 0;
849}
850
Harald Welte5b570672009-08-10 10:08:01 +0200851static inline int is_siemens_bts(struct gsm_bts *bts)
852{
853 switch (bts->type) {
854 case GSM_BTS_TYPE_BS11:
855 return 1;
856 default:
857 break;
858 }
859
860 return 0;
861}
862
Harald Welte (local)69de3972009-08-12 14:42:23 +0200863
864enum gsm_auth_policy gsm_auth_policy_parse(const char *arg);
865const char *gsm_auth_policy_name(enum gsm_auth_policy policy);
866
Harald Welteeab84a12009-12-13 10:53:12 +0100867enum rrlp_mode rrlp_mode_parse(const char *arg);
868const char *rrlp_mode_name(enum rrlp_mode mode);
869
Harald Welte4511d892010-04-18 15:51:20 +0200870enum bts_gprs_mode bts_gprs_mode_parse(const char *arg);
871const char *bts_gprs_mode_name(enum bts_gprs_mode mode);
872
Holger Hans Peter Freyther2d501ea2009-11-11 11:54:24 +0100873void gsm_trx_lock_rf(struct gsm_bts_trx *trx, int locked);
874
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +0200875int gsm48_ra_id_by_bts(uint8_t *buf, struct gsm_bts *bts);
Harald Welte97a282b2010-03-14 15:37:43 +0800876void gprs_ra_id_by_bts(struct gprs_ra_id *raid, struct gsm_bts *bts);
Harald Welted12b0fd2009-12-15 21:36:05 +0100877struct gsm_meas_rep *lchan_next_meas_rep(struct gsm_lchan *lchan);
878
Harald Weltef3d8e922010-06-14 22:44:42 +0200879int gsm_btsmodel_set_feature(struct gsm_bts_model *model, enum gsm_bts_features feat);
880int gsm_bts_has_feature(struct gsm_bts *bts, enum gsm_bts_features feat);
Harald Weltefbda4e12010-03-04 11:04:52 +0100881int gsm_bts_model_register(struct gsm_bts_model *model);
882
Holger Hans Peter Freyther2412a072010-06-28 15:47:12 +0800883struct gsm_subscriber_connection *subscr_con_allocate(struct gsm_lchan *lchan);
884void subscr_con_free(struct gsm_subscriber_connection *conn);
885
Harald Welte52b1f982008-12-23 20:25:15 +0000886#endif