blob: 4344bf8a3a040115a7fd96c51f5feb564c2f9f2c [file] [log] [blame]
Harald Welte52b1f982008-12-23 20:25:15 +00001#ifndef _GSM_DATA_H
2#define _GSM_DATA_H
3
4#include <sys/types.h>
5
Harald Welte4bfdfe72009-06-10 23:11:52 +08006enum gsm_phys_chan_config {
7 GSM_PCHAN_NONE,
8 GSM_PCHAN_CCCH,
9 GSM_PCHAN_CCCH_SDCCH4,
10 GSM_PCHAN_TCH_F,
11 GSM_PCHAN_TCH_H,
12 GSM_PCHAN_SDCCH8_SACCH8C,
Harald Weltea1499d02009-10-24 10:25:50 +020013 GSM_PCHAN_PDCH, /* GPRS PDCH */
14 GSM_PCHAN_TCH_F_PDCH, /* TCH/F if used, PDCH otherwise */
Harald Welte4bfdfe72009-06-10 23:11:52 +080015 GSM_PCHAN_UNKNOWN,
16};
17
18enum gsm_chan_t {
19 GSM_LCHAN_NONE,
20 GSM_LCHAN_SDCCH,
21 GSM_LCHAN_TCH_F,
22 GSM_LCHAN_TCH_H,
23 GSM_LCHAN_UNKNOWN,
24};
25
Harald Welteeab84a12009-12-13 10:53:12 +010026/* RRLP mode of operation */
27enum rrlp_mode {
28 RRLP_MODE_NONE,
29 RRLP_MODE_MS_BASED,
30 RRLP_MODE_MS_PREF,
31 RRLP_MODE_ASS_PREF,
32};
Harald Welte4bfdfe72009-06-10 23:11:52 +080033
34/* Channel Request reason */
35enum gsm_chreq_reason_t {
36 GSM_CHREQ_REASON_EMERG,
37 GSM_CHREQ_REASON_PAG,
38 GSM_CHREQ_REASON_CALL,
39 GSM_CHREQ_REASON_LOCATION_UPD,
40 GSM_CHREQ_REASON_OTHER,
41};
42
Harald Weltedfe6c7d2010-02-20 16:24:02 +010043#include <osmocore/timer.h>
Holger Freyther1adb4ff2009-02-04 00:04:52 +000044#include <openbsc/gsm_04_08.h>
Harald Welte9943c5b2009-07-29 15:41:29 +020045#include <openbsc/abis_rsl.h>
Harald Welte4bfdfe72009-06-10 23:11:52 +080046#include <openbsc/mncc.h>
Harald Weltedfe6c7d2010-02-20 16:24:02 +010047#include <osmocore/tlv.h>
48#include <osmocore/bitvec.h>
49#include <osmocore/statistics.h>
50#include <osmocore/gsm_utils.h>
51#include <osmocore/utils.h>
Harald Welte8470bf22008-12-25 23:28:35 +000052
Harald Welte85770c72009-01-18 17:47:32 +000053#define TRX_NR_TS 8
Harald Welte8470bf22008-12-25 23:28:35 +000054#define TS_MAX_LCHAN 8
Harald Welte52b1f982008-12-23 20:25:15 +000055
56#define HARDCODED_ARFCN 123
Harald Welte02b0e092009-02-28 13:11:07 +000057#define HARDCODED_TSC 7
Harald Welte78f2f502009-05-23 16:56:52 +000058#define HARDCODED_BSIC 0x3f /* NCC = 7 / BCC = 7 */
Harald Welte52b1f982008-12-23 20:25:15 +000059
Harald Welte63589be2009-08-06 17:38:10 +020060/* for multi-drop config */
61#define HARDCODED_BTS0_TS 1
62#define HARDCODED_BTS1_TS 6
63#define HARDCODED_BTS2_TS 11
64
Harald Welte8e1e3ee2009-02-01 13:32:45 +000065enum gsm_hooks {
66 GSM_HOOK_NM_SWLOAD,
Harald Welte0932d1e2009-02-16 22:53:52 +000067 GSM_HOOK_RR_PAGING,
68};
69
70enum gsm_paging_event {
71 GSM_PAGING_SUCCEEDED,
72 GSM_PAGING_EXPIRED,
Holger Freyther85a7b362009-04-18 13:48:55 +020073 GSM_PAGING_OOM,
Harald Welte8e1e3ee2009-02-01 13:32:45 +000074};
75
Harald Welte4511d892010-04-18 15:51:20 +020076enum bts_gprs_mode {
77 BTS_GPRS_NONE = 0,
78 BTS_GPRS_GPRS = 1,
79 BTS_GPRS_EGPRS = 2,
80};
81
Harald Welte0809d792010-04-30 14:36:25 +020082/* the data structure stored in msgb->cb for openbsc apps */
83struct openbsc_msgb_cb {
84 unsigned char *gmmh;
85 u_int32_t tlli;
86};
87#define OBSC_MSGB_CB(__msgb) ((struct openbsc_msgb_cb *)&((__msgb)->cb[0]))
Harald Welte943c5bc2010-04-30 16:33:12 +020088#define msgb_tlli(__x) OBSC_MSGB_CB(__x)->tlli
89#define msgb_gmmh(__x) OBSC_MSGB_CB(__x)->gmmh
90#define msgb_llch(__x) (__x)->l4h
Harald Welte0809d792010-04-30 14:36:25 +020091
Harald Welte8e1e3ee2009-02-01 13:32:45 +000092struct msgb;
93typedef int gsm_cbfn(unsigned int hooknum,
94 unsigned int event,
95 struct msgb *msg,
96 void *data, void *param);
97
Holger Freytherc6ea9db2008-12-30 19:18:21 +000098/*
99 * Use the channel. As side effect the lchannel recycle timer
100 * will be started.
101 */
Harald Welteb9c758b2009-07-05 14:02:46 +0200102#define LCHAN_RELEASE_TIMEOUT 20, 0
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100103#define use_subscr_con(con) \
104 do { (con)->use_count++; \
Harald Welted0c19142009-12-24 11:46:44 +0100105 DEBUGP(DREF, "lchan (bts=%d,trx=%d,ts=%d,ch=%d) increases usage to: %d\n", \
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100106 (con)->lchan->ts->trx->bts->nr, (con)->lchan->ts->trx->nr, (con)->lchan->ts->nr, \
107 (con)->lchan->nr, (con)->use_count); \
108 bsc_schedule_timer(&(con)->release_timer, LCHAN_RELEASE_TIMEOUT); } while(0);
Holger Freytherc6ea9db2008-12-30 19:18:21 +0000109
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100110#define put_subscr_con(con) \
111 do { (con)->use_count--; \
Harald Welted0c19142009-12-24 11:46:44 +0100112 DEBUGP(DREF, "lchan (bts=%d,trx=%d,ts=%d,ch=%d) decreases usage to: %d\n", \
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100113 (con)->lchan->ts->trx->bts->nr, (con)->lchan->ts->trx->nr, (con)->lchan->ts->nr, \
114 (con)->lchan->nr, (con)->use_count); \
Holger Freyther4f584c32009-06-02 02:55:07 +0000115 } while(0);
116
Holger Freytherc6ea9db2008-12-30 19:18:21 +0000117
Sylvain Munaut47193072009-12-27 21:56:14 +0100118/* Real authentication information containing Ki */
119enum gsm_auth_algo {
120 AUTH_ALGO_NONE,
121 AUTH_ALGO_XOR,
122 AUTH_ALGO_COMP128v1,
123};
124
125struct gsm_auth_info {
126 enum gsm_auth_algo auth_algo;
127 unsigned int a3a8_ki_len;
128 u_int8_t a3a8_ki[16];
129};
130
131struct gsm_auth_tuple {
132 int use_count;
133 int key_seq;
134 u_int8_t rand[16];
135 u_int8_t sres[4];
136 u_int8_t kc[8];
137};
138
139
Harald Welte49f48b82009-02-17 15:29:33 +0000140struct gsm_lchan;
141struct gsm_subscriber;
Harald Welte4bfdfe72009-06-10 23:11:52 +0800142struct gsm_mncc;
Harald Welte805f6442009-07-28 18:25:29 +0200143struct rtp_socket;
Harald Welte49f48b82009-02-17 15:29:33 +0000144
Harald Weltebbcc7a52009-02-14 19:45:44 +0000145/* Network Management State */
146struct gsm_nm_state {
147 u_int8_t operational;
148 u_int8_t administrative;
Harald Welte8c1d0e42009-02-15 03:38:12 +0000149 u_int8_t availability;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000150};
Harald Weltebbcc7a52009-02-14 19:45:44 +0000151
Holger Freyther73487a22008-12-31 18:53:57 +0000152/*
153 * LOCATION UPDATING REQUEST state
154 *
155 * Our current operation is:
156 * - Get imei/tmsi
157 * - Accept/Reject according to global policy
158 */
159struct gsm_loc_updating_operation {
160 struct timer_list updating_timer;
Holger Hans Peter Freyther251aa912009-10-27 10:42:28 +0100161 unsigned int waiting_for_imsi : 1;
162 unsigned int waiting_for_imei : 1;
Holger Freyther73487a22008-12-31 18:53:57 +0000163};
164
Harald Weltef7c28b02009-12-21 13:30:17 +0100165/* Maximum number of neighbor cells whose average we track */
166#define MAX_NEIGH_MEAS 10
167/* Maximum size of the averaging window for neighbor cells */
168#define MAX_WIN_NEIGH_AVG 10
169
170/* processed neighbor measurements for one cell */
171struct neigh_meas_proc {
172 u_int16_t arfcn;
173 u_int8_t bsic;
174 u_int8_t rxlev[MAX_WIN_NEIGH_AVG];
175 unsigned int rxlev_cnt;
176 u_int8_t last_seen_nr;
177};
178
Harald Welte08d91a52009-08-30 15:37:11 +0900179#define MAX_A5_KEY_LEN (128/8)
180#define RSL_ENC_ALG_A5(x) (x+1)
181
Holger Hans Peter Freyther5ba6f482009-10-28 14:23:39 +0100182/* is the data link established? who established it? */
183#define LCHAN_SAPI_UNUSED 0
184#define LCHAN_SAPI_MS 1
185#define LCHAN_SAPI_NET 2
186
Harald Welteb8bfc562009-12-21 13:27:11 +0100187/* state of a logical channel */
188enum gsm_lchan_state {
189 LCHAN_S_NONE, /* channel is not active */
Harald Welte (local)3e460312009-12-27 18:12:29 +0100190 LCHAN_S_ACT_REQ, /* channel activatin requested */
Harald Welteb8bfc562009-12-21 13:27:11 +0100191 LCHAN_S_ACTIVE, /* channel is active and operational */
Harald Welte8e93b792009-12-29 10:44:17 +0100192 LCHAN_S_REL_REQ, /* channel release has been requested */
Harald Welteb8bfc562009-12-21 13:27:11 +0100193 LCHAN_S_INACTIVE, /* channel is set inactive */
194};
195
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100196/* the per subscriber data for lchan */
197struct gsm_subscriber_connection {
198 /* To whom we are allocated at the moment */
199 struct gsm_subscriber *subscr;
200
201 /* Timer started to release the channel */
202 struct timer_list release_timer;
203
204 /*
205 * Operations that have a state and might be pending
206 */
207 struct gsm_loc_updating_operation *loc_operation;
208
209 /* use count. how many users use this channel */
210 unsigned int use_count;
211
212 /* Are we part of a special "silent" call */
213 int silent_call;
214
Holger Hans Peter Freyther18b63f42010-03-23 07:52:17 +0100215 /* back pointers */
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100216 struct gsm_lchan *lchan;
Holger Hans Peter Freyther18b63f42010-03-23 07:52:17 +0100217 struct gsm_bts *bts;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100218};
219
Harald Welte8470bf22008-12-25 23:28:35 +0000220struct gsm_lchan {
221 /* The TS that we're part of */
222 struct gsm_bts_trx_ts *ts;
223 /* The logical subslot number in the TS */
224 u_int8_t nr;
Harald Welte45b407a2009-05-23 15:51:12 +0000225 /* The logical channel type */
Harald Welte8470bf22008-12-25 23:28:35 +0000226 enum gsm_chan_t type;
Harald Welte9943c5b2009-07-29 15:41:29 +0200227 /* RSL channel mode */
228 enum rsl_cmod_spd rsl_cmode;
Harald Welte45b407a2009-05-23 15:51:12 +0000229 /* If TCH, traffic channel mode */
Harald Welte9943c5b2009-07-29 15:41:29 +0200230 enum gsm48_chan_mode tch_mode;
Harald Welteb8bfc562009-12-21 13:27:11 +0100231 /* State */
232 enum gsm_lchan_state state;
Harald Welted4c9bf32009-02-15 16:56:18 +0000233 /* Power levels for MS and BTS */
234 u_int8_t bs_power;
235 u_int8_t ms_power;
Harald Welte08d91a52009-08-30 15:37:11 +0900236 /* Encryption information */
237 struct {
238 u_int8_t alg_id;
239 u_int8_t key_len;
240 u_int8_t key[MAX_A5_KEY_LEN];
241 } encr;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100242
243 struct timer_list T3101;
Holger Hans Peter Freytherea528022009-11-18 22:57:02 +0100244
245 /* AMR bits */
246 struct gsm48_multi_rate_conf mr_conf;
Harald Welted4c9bf32009-02-15 16:56:18 +0000247
Holger Hans Peter Freyther5ba6f482009-10-28 14:23:39 +0100248 /* Established data link layer services */
249 u_int8_t sapis[8];
250
Harald Welted12b0fd2009-12-15 21:36:05 +0100251 /* cache of last measurement reports on this lchan */
252 struct gsm_meas_rep meas_rep[6];
253 int meas_rep_idx;
254
Harald Weltef7c28b02009-12-21 13:30:17 +0100255 /* table of neighbor cell measurements */
256 struct neigh_meas_proc neigh_meas[MAX_NEIGH_MEAS];
257
Harald Welte2c828992009-12-02 01:56:49 +0530258 struct {
259 u_int32_t bound_ip;
Harald Welte5e3d91b2009-12-19 16:42:06 +0100260 u_int32_t connect_ip;
Harald Welte2c828992009-12-02 01:56:49 +0530261 u_int16_t bound_port;
Harald Welte5e3d91b2009-12-19 16:42:06 +0100262 u_int16_t connect_port;
Harald Welte2c828992009-12-02 01:56:49 +0530263 u_int16_t conn_id;
Sylvain Munautb54dda42009-12-20 22:06:40 +0100264 u_int8_t rtp_payload;
Harald Welte5e3d91b2009-12-19 16:42:06 +0100265 u_int8_t rtp_payload2;
266 u_int8_t speech_mode;
Harald Welte2c828992009-12-02 01:56:49 +0530267 struct rtp_socket *rtp_socket;
268 } abis_ip;
Holger Hans Peter Freyther68884aa2010-03-23 06:41:45 +0100269
270 struct gsm_subscriber_connection conn;
Harald Welte8470bf22008-12-25 23:28:35 +0000271};
272
Harald Welte85770c72009-01-18 17:47:32 +0000273struct gsm_e1_subslot {
274 /* Number of E1 link */
275 u_int8_t e1_nr;
276 /* Number of E1 TS inside E1 link */
277 u_int8_t e1_ts;
278 /* Sub-slot within the E1 TS, 0xff if full TS */
279 u_int8_t e1_ts_ss;
280};
281
Harald Welte4563eab2010-03-28 14:42:09 +0800282#define TS_F_PDCH_MODE 0x1000
Harald Welte52b1f982008-12-23 20:25:15 +0000283/* One Timeslot in a TRX */
284struct gsm_bts_trx_ts {
285 struct gsm_bts_trx *trx;
286 /* number of this timeslot at the TRX */
287 u_int8_t nr;
288
Harald Welte8470bf22008-12-25 23:28:35 +0000289 enum gsm_phys_chan_config pchan;
290
Harald Welte52b1f982008-12-23 20:25:15 +0000291 unsigned int flags;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000292 struct gsm_nm_state nm_state;
Harald Welte93e9d172009-06-20 19:04:31 +0200293 struct tlv_parsed nm_attr;
Harald Welte39c7deb2009-08-09 21:49:48 +0200294 u_int8_t nm_chan_comb;
Harald Welte8470bf22008-12-25 23:28:35 +0000295
Harald Welte85770c72009-01-18 17:47:32 +0000296 /* To which E1 subslot are we connected */
297 struct gsm_e1_subslot e1_link;
298
Harald Welte8470bf22008-12-25 23:28:35 +0000299 struct gsm_lchan lchan[TS_MAX_LCHAN];
Harald Welte52b1f982008-12-23 20:25:15 +0000300};
301
302/* One TRX in a BTS */
303struct gsm_bts_trx {
Harald Weltee441d9c2009-06-21 16:17:15 +0200304 /* list header in bts->trx_list */
305 struct llist_head list;
306
Harald Welte52b1f982008-12-23 20:25:15 +0000307 struct gsm_bts *bts;
308 /* number of this TRX in the BTS */
309 u_int8_t nr;
Harald Welte1fa60c82009-02-09 18:13:26 +0000310 /* how do we talk RSL with this TRX? */
Harald Welte42581822009-08-08 16:12:58 +0200311 struct gsm_e1_subslot rsl_e1_link;
312 u_int8_t rsl_tei;
Harald Welte1fa60c82009-02-09 18:13:26 +0000313 struct e1inp_sign_link *rsl_link;
Harald Welte42581822009-08-08 16:12:58 +0200314
Harald Weltebbcc7a52009-02-14 19:45:44 +0000315 struct gsm_nm_state nm_state;
Harald Welte93e9d172009-06-20 19:04:31 +0200316 struct tlv_parsed nm_attr;
Harald Welte8c1d0e42009-02-15 03:38:12 +0000317 struct {
318 struct gsm_nm_state nm_state;
319 } bb_transc;
Harald Welte52b1f982008-12-23 20:25:15 +0000320
321 u_int16_t arfcn;
Harald Weltefcd24452009-06-20 18:15:19 +0200322 int nominal_power; /* in dBm */
323 unsigned int max_power_red; /* in actual dB */
Harald Welte8b697c72009-06-05 19:18:45 +0000324
325 union {
326 struct {
327 struct {
328 struct gsm_nm_state nm_state;
329 } bbsig;
330 struct {
331 struct gsm_nm_state nm_state;
332 } pa;
333 } bs11;
334 };
Harald Welte85770c72009-01-18 17:47:32 +0000335 struct gsm_bts_trx_ts ts[TRX_NR_TS];
Harald Welte52b1f982008-12-23 20:25:15 +0000336};
337
Harald Welte978cb422009-01-18 17:57:27 +0000338enum gsm_bts_type {
339 GSM_BTS_TYPE_UNKNOWN,
340 GSM_BTS_TYPE_BS11,
Mike Habene2d82272009-10-02 12:19:34 +0100341 GSM_BTS_TYPE_NANOBTS,
Harald Welte978cb422009-01-18 17:57:27 +0000342};
343
Harald Welte39315c42010-01-10 18:01:52 +0100344struct gsm_bts_model {
345 struct llist_head list;
346
347 enum gsm_bts_type type;
348 const char *name;
349
350 struct tlv_definition nm_att_tlvdef;
351};
352
Holger Freytherceb59b72009-02-06 18:54:00 +0000353/**
354 * A pending paging request
355 */
356struct gsm_paging_request {
Harald Welte0932d1e2009-02-16 22:53:52 +0000357 /* list_head for list of all paging requests */
Holger Freytherceb59b72009-02-06 18:54:00 +0000358 struct llist_head entry;
Harald Welte0932d1e2009-02-16 22:53:52 +0000359 /* the subscriber which we're paging. Later gsm_paging_request
360 * should probably become a part of the gsm_subscriber struct? */
Holger Freytherceb59b72009-02-06 18:54:00 +0000361 struct gsm_subscriber *subscr;
Harald Welte0932d1e2009-02-16 22:53:52 +0000362 /* back-pointer to the BTS on which we are paging */
Holger Freytherceb59b72009-02-06 18:54:00 +0000363 struct gsm_bts *bts;
Harald Welte0932d1e2009-02-16 22:53:52 +0000364 /* what kind of channel type do we ask the MS to establish */
Holger Freytherceb59b72009-02-06 18:54:00 +0000365 int chan_type;
Harald Weltecd06bfb2009-02-10 17:33:56 +0000366
367 /* Timer 3113: how long do we try to page? */
368 struct timer_list T3113;
Harald Welte0932d1e2009-02-16 22:53:52 +0000369
370 /* callback to be called in case paging completes */
371 gsm_cbfn *cbfn;
372 void *cbfn_param;
Holger Freytherceb59b72009-02-06 18:54:00 +0000373};
374
375/*
376 * This keeps track of the paging status of one BTS. It
377 * includes a number of pending requests, a back pointer
378 * to the gsm_bts, a timer and some more state.
379 */
380struct gsm_bts_paging_state {
Holger Freytherceb59b72009-02-06 18:54:00 +0000381 /* pending requests */
382 struct llist_head pending_requests;
Holger Freytherceb59b72009-02-06 18:54:00 +0000383 struct gsm_bts *bts;
384
Harald Welte75a1fa82009-02-17 01:39:41 +0000385 struct timer_list work_timer;
386
Holger Freyther392209c2009-02-10 00:06:19 +0000387 /* load */
388 u_int16_t available_slots;
Holger Freytherceb59b72009-02-06 18:54:00 +0000389};
390
Harald Welte8b697c72009-06-05 19:18:45 +0000391struct gsm_envabtse {
392 struct gsm_nm_state nm_state;
393};
394
Harald Welte55dd4432009-10-24 10:19:14 +0200395struct gsm_bts_gprs_nsvc {
396 struct gsm_bts *bts;
Harald Welteab88a622010-03-18 00:01:23 +0800397 /* data read via VTY config file, to configure the BTS
398 * via OML from BSC */
Harald Welte55dd4432009-10-24 10:19:14 +0200399 int id;
Harald Welte97a282b2010-03-14 15:37:43 +0800400 u_int16_t nsvci;
Harald Welteab88a622010-03-18 00:01:23 +0800401 u_int16_t local_port; /* on the BTS */
402 u_int16_t remote_port; /* on the SGSN */
403 u_int32_t remote_ip; /* on the SGSN */
404
Harald Welte55dd4432009-10-24 10:19:14 +0200405 struct gsm_nm_state nm_state;
406};
407
Harald Welte52b1f982008-12-23 20:25:15 +0000408/* One BTS */
409struct gsm_bts {
Harald Weltee441d9c2009-06-21 16:17:15 +0200410 /* list header in net->bts_list */
411 struct llist_head list;
412
Harald Welte52b1f982008-12-23 20:25:15 +0000413 struct gsm_network *network;
414 /* number of ths BTS in network */
415 u_int8_t nr;
Holger Hans Peter Freytherc4a49e32009-08-21 14:44:12 +0200416 /* Cell Identity */
417 u_int16_t cell_identity;
Harald Welte52b1f982008-12-23 20:25:15 +0000418 /* location area code of this BTS */
Holger Hans Peter Freyther0b7f4b32009-09-29 14:02:33 +0200419 u_int16_t location_area_code;
Harald Welte02b0e092009-02-28 13:11:07 +0000420 /* Training Sequence Code */
421 u_int8_t tsc;
Harald Welte78f2f502009-05-23 16:56:52 +0000422 /* Base Station Identification Code (BSIC) */
423 u_int8_t bsic;
Harald Welte978cb422009-01-18 17:57:27 +0000424 /* type of BTS */
425 enum gsm_bts_type type;
Harald Welte39315c42010-01-10 18:01:52 +0100426 struct gsm_bts_model *model;
Harald Weltefcd24452009-06-20 18:15:19 +0200427 enum gsm_band band;
Harald Weltefc0d9522009-08-10 13:46:55 +0200428 /* should the channel allocator allocate channels from high TRX to TRX0,
429 * rather than starting from TRX0 and go upwards? */
430 int chan_alloc_reverse;
Harald Welte (local)0e451d02009-08-13 10:14:26 +0200431 /* maximum Tx power that the MS is permitted to use in this cell */
432 int ms_max_power;
Harald Weltefc0d9522009-08-10 13:46:55 +0200433
Harald Welte1fa60c82009-02-09 18:13:26 +0000434 /* how do we talk OML with this TRX? */
Harald Welte42581822009-08-08 16:12:58 +0200435 struct gsm_e1_subslot oml_e1_link;
436 u_int8_t oml_tei;
Harald Welte1fa60c82009-02-09 18:13:26 +0000437 struct e1inp_sign_link *oml_link;
Harald Welte52b1f982008-12-23 20:25:15 +0000438
439 /* Abis network management O&M handle */
440 struct abis_nm_h *nmh;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000441 struct gsm_nm_state nm_state;
Harald Welte93e9d172009-06-20 19:04:31 +0200442 struct tlv_parsed nm_attr;
Harald Welte978cb422009-01-18 17:57:27 +0000443
Harald Welte52b1f982008-12-23 20:25:15 +0000444 /* number of this BTS on given E1 link */
445 u_int8_t bts_nr;
446
Holger Freytherceb59b72009-02-06 18:54:00 +0000447 /* paging state and control */
448 struct gsm_bts_paging_state paging;
449
Harald Welte52b1f982008-12-23 20:25:15 +0000450 /* CCCH is on C0 */
451 struct gsm_bts_trx *c0;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000452
453 struct {
454 struct gsm_nm_state nm_state;
455 } site_mgr;
Harald Welteedb37782009-05-01 14:59:07 +0000456
Harald Weltea43f7892009-12-01 18:04:30 +0530457 /* parameters from which we build SYSTEM INFORMATION */
458 struct {
459 struct gsm48_rach_control rach_control;
460 u_int8_t ncc_permitted;
461 struct gsm48_cell_sel_par cell_sel_par;
462 struct gsm48_cell_options cell_options;
463 struct gsm48_control_channel_descr chan_desc;
Harald Welte6c40def2009-12-14 22:07:14 +0100464 struct bitvec neigh_list;
465 struct bitvec cell_alloc;
466 struct {
467 /* bitmask large enough for all possible ARFCN's */
468 u_int8_t neigh_list[1024/8];
469 u_int8_t cell_alloc[1024/8];
470 } data;
Harald Weltea43f7892009-12-01 18:04:30 +0530471 } si_common;
472
Harald Welteedb37782009-05-01 14:59:07 +0000473 /* ip.accesss Unit ID's have Site/BTS/TRX layout */
Harald Welte7b26bcb2009-05-28 11:39:21 +0000474 union {
475 struct {
476 u_int16_t site_id;
477 u_int16_t bts_id;
Harald Welte88a412a2009-12-16 17:32:37 +0100478 u_int32_t flags;
Harald Welte7b26bcb2009-05-28 11:39:21 +0000479 } ip_access;
480 struct {
481 struct {
482 struct gsm_nm_state nm_state;
483 } cclk;
484 struct {
485 struct gsm_nm_state nm_state;
486 } rack;
Harald Welte8b697c72009-06-05 19:18:45 +0000487 struct gsm_envabtse envabtse[4];
Harald Welte7b26bcb2009-05-28 11:39:21 +0000488 } bs11;
489 };
Harald Welte55dd4432009-10-24 10:19:14 +0200490
491 /* Not entirely sure how ip.access specific this is */
492 struct {
Harald Welte4511d892010-04-18 15:51:20 +0200493 enum bts_gprs_mode mode;
Harald Welte55dd4432009-10-24 10:19:14 +0200494 struct {
495 struct gsm_nm_state nm_state;
Harald Weltea5731cf2010-03-22 11:48:36 +0800496 u_int16_t nsei;
Harald Welte55dd4432009-10-24 10:19:14 +0200497 } nse;
498 struct {
499 struct gsm_nm_state nm_state;
Harald Welte97a282b2010-03-14 15:37:43 +0800500 u_int16_t bvci;
Harald Welte55dd4432009-10-24 10:19:14 +0200501 } cell;
502 struct gsm_bts_gprs_nsvc nsvc[2];
Harald Welte97a282b2010-03-14 15:37:43 +0800503 u_int8_t rac;
Harald Welte55dd4432009-10-24 10:19:14 +0200504 } gprs;
Holger Hans Peter Freyther95c22902010-04-25 23:08:39 +0800505
506 /* RACH NM values */
507 int rach_b_thresh;
508 int rach_ldavg_slots;
Harald Weltebbcc7a52009-02-14 19:45:44 +0000509
Harald Welte52b1f982008-12-23 20:25:15 +0000510 /* transceivers */
511 int num_trx;
Harald Weltee441d9c2009-06-21 16:17:15 +0200512 struct llist_head trx_list;
Harald Welte52b1f982008-12-23 20:25:15 +0000513};
514
Harald Welte24ff6ee2009-12-22 00:41:05 +0100515/* Some statistics of our network */
516struct gsmnet_stats {
517 struct {
Harald Welteffa55a42009-12-22 19:07:32 +0100518 struct counter *total;
519 struct counter *no_channel;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100520 } chreq;
521 struct {
Harald Welteffa55a42009-12-22 19:07:32 +0100522 struct counter *attempted;
523 struct counter *no_channel; /* no channel available */
524 struct counter *timeout; /* T3103 timeout */
525 struct counter *completed; /* HO COMPL received */
526 struct counter *failed; /* HO FAIL received */
Harald Welte24ff6ee2009-12-22 00:41:05 +0100527 } handover;
528 struct {
Harald Welteffa55a42009-12-22 19:07:32 +0100529 struct counter *attach;
530 struct counter *normal;
531 struct counter *periodic;
532 struct counter *detach;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100533 } loc_upd_type;
534 struct {
Harald Welteffa55a42009-12-22 19:07:32 +0100535 struct counter *reject;
536 struct counter *accept;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100537 } loc_upd_resp;
538 struct {
Harald Welteffa55a42009-12-22 19:07:32 +0100539 struct counter *attempted;
540 struct counter *detached;
541 struct counter *completed;
542 struct counter *expired;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100543 } paging;
544 struct {
Harald Welteffa55a42009-12-22 19:07:32 +0100545 struct counter *submitted; /* MO SMS submissions */
546 struct counter *no_receiver;
547 struct counter *delivered; /* MT SMS deliveries */
548 struct counter *rp_err_mem;
549 struct counter *rp_err_other;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100550 } sms;
551 struct {
Harald Welteffa55a42009-12-22 19:07:32 +0100552 struct counter *dialled; /* total number of dialled calls */
553 struct counter *alerted; /* we alerted the other end */
554 struct counter *connected;/* how many calls were accepted */
Harald Welte24ff6ee2009-12-22 00:41:05 +0100555 } call;
Holger Hans Peter Freyther3ba36d52010-04-17 06:48:29 +0200556 struct {
557 struct counter *rf_fail;
558 struct counter *rll_err;
559 } chan;
Holger Hans Peter Freytherbb110f92010-04-12 10:45:52 +0200560 struct {
561 struct counter *oml_fail;
562 struct counter *rsl_fail;
563 } bts;
Harald Welte24ff6ee2009-12-22 00:41:05 +0100564};
565
Harald Welte (local)69de3972009-08-12 14:42:23 +0200566enum gsm_auth_policy {
567 GSM_AUTH_POLICY_CLOSED, /* only subscribers authorized in DB */
568 GSM_AUTH_POLICY_ACCEPT_ALL, /* accept everyone, even if not authorized in DB */
569 GSM_AUTH_POLICY_TOKEN, /* accept first, send token per sms, then revoke authorization */
570};
571
Harald Welteb84ddfc2009-12-01 17:36:54 +0530572#define GSM_T3101_DEFAULT 10
573#define GSM_T3113_DEFAULT 60
574
Harald Welte52b1f982008-12-23 20:25:15 +0000575struct gsm_network {
576 /* global parameters */
Harald Welteb84e2f42008-12-28 23:42:04 +0000577 u_int16_t country_code;
578 u_int16_t network_code;
Harald Weltec6ba9c22008-12-30 18:01:02 +0000579 char *name_long;
580 char *name_short;
Harald Welte (local)69de3972009-08-12 14:42:23 +0200581 enum gsm_auth_policy auth_policy;
Harald Welte1085c092009-11-18 20:33:19 +0100582 enum gsm48_reject_value reject_cause;
Harald Welte4381cfe2009-08-30 15:47:06 +0900583 int a5_encryption;
Holger Hans Peter Freytherf7d752f2009-11-16 17:12:38 +0100584 int neci;
Harald Welte648b6ce2009-12-14 09:00:24 +0100585 int send_mm_info;
Harald Weltebc814502009-12-19 21:41:52 +0100586 struct {
587 int active;
Harald Weltef7c28b02009-12-21 13:30:17 +0100588 /* Window RXLEV averaging */
589 unsigned int win_rxlev_avg; /* number of SACCH frames */
590 /* Window RXQUAL averaging */
591 unsigned int win_rxqual_avg; /* number of SACCH frames */
592 /* Window RXLEV neighbouring cells averaging */
593 unsigned int win_rxlev_avg_neigh; /* number of SACCH frames */
594
595 /* how often should we check for power budget HO */
596 unsigned int pwr_interval; /* SACCH frames */
597 /* how much better does a neighbor cell have to be ? */
598 unsigned int pwr_hysteresis; /* dBm */
599 /* maximum distacne before we try a handover */
600 unsigned int max_distance; /* TA values */
Harald Weltebc814502009-12-19 21:41:52 +0100601 } handover;
Harald Welte52b1f982008-12-23 20:25:15 +0000602
Harald Welte24ff6ee2009-12-22 00:41:05 +0100603 struct gsmnet_stats stats;
604
Harald Welte4bfdfe72009-06-10 23:11:52 +0800605 /* layer 4 */
606 int (*mncc_recv) (struct gsm_network *net, int msg_type, void *arg);
607 struct llist_head upqueue;
608 struct llist_head trans_list;
609
Harald Welte52b1f982008-12-23 20:25:15 +0000610 unsigned int num_bts;
Harald Weltee441d9c2009-06-21 16:17:15 +0200611 struct llist_head bts_list;
Holger Hans Peter Freytherc4d88ad2009-11-21 21:18:38 +0100612
613 /* timer values */
614 int T3101;
Holger Hans Peter Freyther23975e72009-11-21 21:42:26 +0100615 int T3103;
616 int T3105;
617 int T3107;
618 int T3109;
619 int T3111;
620 int T3113;
621 int T3115;
622 int T3117;
623 int T3119;
624 int T3141;
Harald Welteeab84a12009-12-13 10:53:12 +0100625
626 /* Radio Resource Location Protocol (TS 04.31) */
627 struct {
628 enum rrlp_mode mode;
629 } rrlp;
Harald Welte52b1f982008-12-23 20:25:15 +0000630};
631
Harald Welte7e310b12009-03-30 20:56:32 +0000632#define SMS_HDR_SIZE 128
633#define SMS_TEXT_SIZE 256
634struct gsm_sms {
Harald Welted409be72009-11-07 00:06:19 +0900635 unsigned long long id;
Harald Welte7e310b12009-03-30 20:56:32 +0000636 struct gsm_subscriber *sender;
637 struct gsm_subscriber *receiver;
638
Harald Welteb9c758b2009-07-05 14:02:46 +0200639 unsigned long validity_minutes;
Harald Welte76042182009-08-08 16:03:15 +0200640 u_int8_t reply_path_req;
641 u_int8_t status_rep_req;
642 u_int8_t ud_hdr_ind;
643 u_int8_t protocol_id;
644 u_int8_t data_coding_scheme;
645 u_int8_t msg_ref;
646 char dest_addr[20+1]; /* DA LV is 12 bytes max, i.e. 10 bytes
647 * BCD == 20 bytes string */
648 u_int8_t user_data_len;
649 u_int8_t user_data[SMS_TEXT_SIZE];
Harald Weltef3efc592009-07-27 20:11:35 +0200650
Harald Welte7e310b12009-03-30 20:56:32 +0000651 char text[SMS_TEXT_SIZE];
652};
653
Harald Welte3606cc52009-12-05 15:13:22 +0530654
Harald Weltee441d9c2009-06-21 16:17:15 +0200655struct gsm_network *gsm_network_init(u_int16_t country_code, u_int16_t network_code,
Harald Welte4bfdfe72009-06-10 23:11:52 +0800656 int (*mncc_recv)(struct gsm_network *, int, void *));
Harald Weltee441d9c2009-06-21 16:17:15 +0200657struct gsm_bts *gsm_bts_alloc(struct gsm_network *net, enum gsm_bts_type type,
658 u_int8_t tsc, u_int8_t bsic);
659struct gsm_bts_trx *gsm_bts_trx_alloc(struct gsm_bts *bts);
Harald Welte39315c42010-01-10 18:01:52 +0100660int gsm_set_bts_type(struct gsm_bts *bts, enum gsm_bts_type type);
Harald Weltee441d9c2009-06-21 16:17:15 +0200661
662struct gsm_bts *gsm_bts_num(struct gsm_network *net, int num);
Harald Welte84874c92009-12-14 22:33:02 +0100663
664/* Get reference to a neighbor cell on a given BCCH ARFCN */
Harald Welte0b121032009-12-15 00:21:31 +0100665struct gsm_bts *gsm_bts_neighbor(const struct gsm_bts *bts,
666 u_int16_t arfcn, u_int8_t bsic);
Harald Welte84874c92009-12-14 22:33:02 +0100667
Harald Weltee441d9c2009-06-21 16:17:15 +0200668struct gsm_bts_trx *gsm_bts_trx_num(struct gsm_bts *bts, int num);
Harald Welte8470bf22008-12-25 23:28:35 +0000669
Harald Weltea72c98e2009-01-04 16:10:38 +0000670const char *gsm_pchan_name(enum gsm_phys_chan_config c);
Harald Welte65da9122009-08-07 00:32:22 +0200671enum gsm_phys_chan_config gsm_pchan_parse(const char *name);
Harald Welte (local)ccd88452009-12-27 18:05:25 +0100672const char *gsm_lchant_name(enum gsm_chan_t c);
Harald Weltea72c98e2009-01-04 16:10:38 +0000673const char *gsm_chreq_name(enum gsm_chreq_reason_t c);
Harald Welte (local)d48f4eb2009-12-28 23:14:22 +0100674char *gsm_trx_name(struct gsm_bts_trx *trx);
Harald Welte23a68632009-02-19 17:06:42 +0000675char *gsm_ts_name(struct gsm_bts_trx_ts *ts);
Harald Welte (local)19ef62a2009-12-27 18:16:36 +0100676char *gsm_lchan_name(struct gsm_lchan *lchan);
Harald Welte1887f9d2009-12-29 10:52:38 +0100677const char *gsm_lchans_name(enum gsm_lchan_state s);
Harald Weltea72c98e2009-01-04 16:10:38 +0000678
Harald Weltead384642008-12-26 10:20:07 +0000679enum gsm_e1_event {
680 EVT_E1_NONE,
Harald Welte1fa60c82009-02-09 18:13:26 +0000681 EVT_E1_TEI_UP,
682 EVT_E1_TEI_DN,
Harald Weltead384642008-12-26 10:20:07 +0000683};
684
Harald Weltecd06bfb2009-02-10 17:33:56 +0000685void set_ts_e1link(struct gsm_bts_trx_ts *ts, u_int8_t e1_nr,
686 u_int8_t e1_ts, u_int8_t e1_ts_ss);
Harald Welte1d014a52009-08-08 15:38:29 +0200687enum gsm_bts_type parse_btstype(const char *arg);
Holger Hans Peter Freyther2dceae62009-06-12 17:39:38 +0200688const char *btstype2str(enum gsm_bts_type type);
Harald Welte6e670aa2010-01-07 20:44:32 +0100689struct gsm_bts_trx *gsm_bts_trx_by_nr(struct gsm_bts *bts, int nr);
Harald Weltebe991492009-05-23 13:56:40 +0000690struct gsm_bts *gsm_bts_by_lac(struct gsm_network *net, unsigned int lac,
691 struct gsm_bts *start_bts);
Harald Welte32201c12009-03-10 12:15:10 +0000692
Andreas Eversberg8226fa72009-06-29 15:19:38 +0200693extern void *tall_bsc_ctx;
Harald Weltef88c8a02009-12-20 13:48:15 +0100694extern int ipacc_rtp_direct;
Harald Welte2cf161b2009-06-20 22:36:41 +0200695
Harald Welte32201c12009-03-10 12:15:10 +0000696static inline int is_ipaccess_bts(struct gsm_bts *bts)
697{
698 switch (bts->type) {
Mike Habene2d82272009-10-02 12:19:34 +0100699 case GSM_BTS_TYPE_NANOBTS:
Harald Welte32201c12009-03-10 12:15:10 +0000700 return 1;
701 default:
702 break;
703 }
704 return 0;
705}
706
Harald Welte5b570672009-08-10 10:08:01 +0200707static inline int is_siemens_bts(struct gsm_bts *bts)
708{
709 switch (bts->type) {
710 case GSM_BTS_TYPE_BS11:
711 return 1;
712 default:
713 break;
714 }
715
716 return 0;
717}
718
Harald Welte (local)69de3972009-08-12 14:42:23 +0200719
720enum gsm_auth_policy gsm_auth_policy_parse(const char *arg);
721const char *gsm_auth_policy_name(enum gsm_auth_policy policy);
722
Harald Welteeab84a12009-12-13 10:53:12 +0100723enum rrlp_mode rrlp_mode_parse(const char *arg);
724const char *rrlp_mode_name(enum rrlp_mode mode);
725
Harald Welte4511d892010-04-18 15:51:20 +0200726enum bts_gprs_mode bts_gprs_mode_parse(const char *arg);
727const char *bts_gprs_mode_name(enum bts_gprs_mode mode);
728
Holger Hans Peter Freyther2d501ea2009-11-11 11:54:24 +0100729void gsm_trx_lock_rf(struct gsm_bts_trx *trx, int locked);
730
Harald Welte97a282b2010-03-14 15:37:43 +0800731int gsm48_ra_id_by_bts(u_int8_t *buf, struct gsm_bts *bts);
732void gprs_ra_id_by_bts(struct gprs_ra_id *raid, struct gsm_bts *bts);
Harald Welted12b0fd2009-12-15 21:36:05 +0100733struct gsm_meas_rep *lchan_next_meas_rep(struct gsm_lchan *lchan);
734
Harald Weltefbda4e12010-03-04 11:04:52 +0100735int gsm_bts_model_register(struct gsm_bts_model *model);
736
Harald Welte52b1f982008-12-23 20:25:15 +0000737#endif