blob: cc4a36709050db925650a70e4c58b56e3b39586d [file] [log] [blame]
Harald Welte52b1f982008-12-23 20:25:15 +00001/* GSM Radio Signalling Link messages on the A-bis interface
2 * 3GPP TS 08.58 version 8.6.0 Release 1999 / ETSI TS 100 596 V8.6.0 */
3
4/* (C) 2008 by Harald Welte <laforge@gnumonks.org>
5 * All Rights Reserved
6 *
7 * This program is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This program is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License along
18 * with this program; if not, write to the Free Software Foundation, Inc.,
19 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
20 *
21 */
22
23#ifndef _RSL_H
24#define _RSL_H
25
26struct abis_rsl_common_hdr {
27 u_int8_t msg_discr;
28 u_int8_t msg_type;
29 u_int8_t data[0];
30} __attribute__ ((packed));
31
32/* Chapter 8.3 */
33struct abis_rsl_rll_hdr {
34 struct abis_rsl_common_hdr c;
35 u_int8_t ie_chan;
36 u_int8_t chan_nr;
37 u_int8_t ie_link_id;
38 u_int8_t link_id;
39 u_int8_t data[0];
40} __attribute__ ((packed));
41
42/* Chapter 8.3 and 8.4 */
43struct abis_rsl_dchan_hdr {
44 struct abis_rsl_common_hdr c;
45 u_int8_t ie_chan;
46 u_int8_t chan_nr;
47 u_int8_t data[0];
48} __attribute__ ((packed));
49
50
51/* Chapter 9.1 */
52#define ABIS_RSL_MDISC_RLL 0x02
53#define ABIS_RSL_MDISC_DED_CHAN 0x08
54#define ABIS_RSL_MDISC_COM_CHAN 0x0c
55#define ABIS_RSL_MDISC_TRX 0x10
56#define ABIS_RSL_MDISC_LOC 0x20
Harald Welte75099262009-02-16 21:12:08 +000057#define ABIS_RSL_MDISC_IPACCESS 0x7e
Harald Welte4a543e82009-02-28 13:17:55 +000058#define ABIS_RSL_MDISC_TRANSP 0x01
Harald Welte52b1f982008-12-23 20:25:15 +000059
60#define ABIS_RSL_MDISC_IS_TRANSP(x) (x & 0x01)
61
Holger Freyther590d66a2008-12-30 19:13:13 +000062/* Chapter 9.1 */
Harald Welte52b1f982008-12-23 20:25:15 +000063enum abis_rsl_msgtype {
64 /* Radio Link Layer Management */
65 RSL_MT_DATA_REQ = 0x01,
66 RSL_MT_DATA_IND,
67 RSL_MT_ERROR_IND,
68 RSL_MT_EST_REQ,
69 RSL_MT_EST_CONF,
70 RSL_MT_EST_IND,
71 RSL_MT_REL_REQ,
72 RSL_MT_REL_CONF,
73 RSL_MT_REL_IND,
74 RSL_MT_UNIT_DATA_REQ,
75 RSL_MT_UNIT_DATA_IND, /* 0x0b */
76
77 /* Common Channel Management / TRX Management */
78 RSL_MT_BCCH_INFO = 0x11,
79 RSL_MT_CCCH_LOAD_IND,
80 RSL_MT_CHAN_RQD,
81 RSL_MT_DELETE_IND,
82 RSL_MT_PAGING_CMD,
83 RSL_MT_IMMEDIATE_ASSIGN_CMD,
84 RSL_MT_SMS_BC_REQ,
85 /* empty */
86 RSL_MT_RF_RES_IND = 0x19,
87 RSL_MT_SACCH_FILL,
88 RSL_MT_OVERLOAD,
89 RSL_MT_ERROR_REPORT,
90 RSL_MT_SMS_BC_CMD,
91 RSL_MT_CBCH_LOAD_IND,
92 RSL_MT_NOT_CMD, /* 0x1f */
93
94 /* Dedicate Channel Management */
95 RSL_MT_CHAN_ACTIV = 0x21,
96 RSL_MT_CHAN_ACTIV_ACK,
97 RSL_MT_CHAN_ACTIV_NACK,
98 RSL_MT_CONN_FAIL,
99 RSL_MT_DEACTIVATE_SACCH,
100 RSL_MT_ENCR_CMD,
101 RSL_MT_HANDO_DET,
102 RSL_MT_MEAS_RES,
103 RSL_MT_MODE_MODIFY_REQ,
104 RSL_MT_MODE_MODIFY_ACK,
105 RSL_MT_MODE_MODIFY_NACK,
106 RSL_MT_PHY_CONTEXT_REQ,
107 RSL_MT_PHY_CONTEXT_CONF,
108 RSL_MT_RF_CHAN_REL,
109 RSL_MT_MS_POWER_CONTROL,
Harald Welte8470bf22008-12-25 23:28:35 +0000110 RSL_MT_BS_POWER_CONTROL, /* 0x30 */
Harald Welte52b1f982008-12-23 20:25:15 +0000111 RSL_MT_PREPROC_CONFIG,
112 RSL_MT_PREPROC_MEAS_RES,
113 RSL_MT_RF_CHAN_REL_ACK,
114 RSL_MT_SACCH_INFO_MODIFY,
115 RSL_MT_TALKER_DET,
116 RSL_MT_LISTENER_DET,
117 RSL_MT_REMOTE_CODEC_CONF_REP,
118 RSL_MT_RTD_REP,
119 RSL_MT_PRE_HANDO_NOTIF,
120 RSL_MT_MR_CODEC_MOD_REQ,
121 RSL_MT_MR_CODEC_MOD_ACK,
122 RSL_MT_MR_CODEC_MOD_NACK,
123 RSL_MT_MR_CODEC_MOD_PER,
124 RSL_MT_TFO_REP,
125 RSL_MT_TFO_MOD_REQ, /* 0x3f */
Harald Weltea1f0ac72009-07-12 21:59:04 +0200126 RSL_MT_LOCATION_INFO = 0x41,
Harald Welte75099262009-02-16 21:12:08 +0000127
128 /* ip.access specific RSL message types */
Harald Weltea1f0ac72009-07-12 21:59:04 +0200129 RSL_MT_IPAC_DIR_RETR_ENQ = 0x40,
130 RSL_MT_IPAC_PDCH_ACT = 0x48,
131 RSL_MT_IPAC_PDCH_ACT_ACK,
132 RSL_MT_IPAC_PDCH_ACT_NACK,
133 RSL_MT_IPAC_PDCH_DEACT = 0x4b,
134 RSL_MT_IPAC_PDCH_DEACT_ACK,
135 RSL_MT_IPAC_PDCH_DEACT_NACK,
136 RSL_MT_IPAC_CONNECT_MUX = 0x50,
137 RSL_MT_IPAC_CONNECT_MUX_ACK,
138 RSL_MT_IPAC_CONNECT_MUX_NACK,
139 RSL_MT_IPAC_BIND_MUX = 0x53,
140 RSL_MT_IPAC_BIND_MUX_ACK,
141 RSL_MT_IPAC_BIND_MUX_NACK,
142 RSL_MT_IPAC_DISC_MUX = 0x56,
143 RSL_MT_IPAC_DISC_MUX_ACK,
144 RSL_MT_IPAC_DISC_MUX_NACK,
Harald Welte75099262009-02-16 21:12:08 +0000145 RSL_MT_IPAC_BIND = 0x70, /* Bind to local BTS RTP port */
146 RSL_MT_IPAC_BIND_ACK,
147 RSL_MT_IPAC_BIND_NACK,
148 RSL_MT_IPAC_CONNECT = 0x73,
149 RSL_MT_IPAC_CONNECT_ACK,
150 RSL_MT_IPAC_CONNECT_NACK,
151 RSL_MT_IPAC_DISCONNECT_IND = 0x76,
Harald Weltea1f0ac72009-07-12 21:59:04 +0200152 RSL_MT_IPAC_DISCONNECT = 0x77,
153 RSL_MT_IPAC_DISCONNECT_ACK,
154 RSL_MT_IPAC_DISCONNECT_NACK,
Harald Welte52b1f982008-12-23 20:25:15 +0000155};
156
157/* Chapter 9.3 */
158enum abis_rsl_ie {
159 RSL_IE_CHAN_NR = 0x01,
160 RSL_IE_LINK_IDENT,
161 RSL_IE_ACT_TYPE,
162 RSL_IE_BS_POWER,
163 RSL_IE_CHAN_IDENT,
164 RSL_IE_CHAN_MODE,
165 RSL_IE_ENCR_INFO,
166 RSL_IE_FRAME_NUMBER,
167 RSL_IE_HANDO_REF,
168 RSL_IE_L1_INFO,
169 RSL_IE_L3_INFO,
170 RSL_IE_MS_IDENTITY,
171 RSL_IE_MS_POWER,
172 RSL_IE_PAGING_GROUP,
173 RSL_IE_PAGING_LOAD,
174 RSL_IE_PYHS_CONTEXT = 0x10,
175 RSL_IE_ACCESS_DELAY,
176 RSL_IE_RACH_LOAD,
177 RSL_IE_REQ_REFERENCE,
178 RSL_IE_RELEASE_MODE,
179 RSL_IE_RESOURCE_INFO,
180 RSL_IE_RLM_CAUSE,
181 RSL_IE_STARTNG_TIME,
182 RSL_IE_TIMING_ADVANCE,
183 RSL_IE_UPLINK_MEAS,
184 RSL_IE_CAUSE,
185 RSL_IE_MEAS_RES_NR,
186 RSL_IE_MSG_ID,
187 /* reserved */
188 RSL_IE_SYSINFO_TYPE = 0x1e,
189 RSL_IE_MS_POWER_PARAM,
190 RSL_IE_BS_POWER_PARAM,
191 RSL_IE_PREPROC_PARAM,
192 RSL_IE_PREPROC_MEAS,
193 RSL_IE_IMM_ASS_INFO, /* Phase 1 (3.6.0), later Full below */
194 RSL_IE_SMSCB_INFO = 0x24,
195 RSL_IE_MS_TIMING_OFFSET,
196 RSL_IE_ERR_MSG,
197 RSL_IE_FULL_BCCH_INFO,
198 RSL_IE_CHAN_NEEDED,
199 RSL_IE_CB_CMD_TYPE,
200 RSL_IE_SMSCB_MSG,
201 RSL_IE_FULL_IMM_ASS_INFO,
202 RSL_IE_SACCH_INFO,
203 RSL_IE_CBCH_LOAD_INFO,
204 RSL_IE_SMSCB_CHAN_INDICATOR,
205 RSL_IE_GROUP_CALL_REF,
206 RSL_IE_CHAN_DESC,
207 RSL_IE_NCH_DRX_INFO,
208 RSL_IE_CMD_INDICATOR,
209 RSL_IE_EMLPP_PRIO,
210 RSL_IE_UIC,
211 RSL_IE_MAIN_CHAN_REF,
212 RSL_IE_MR_CONFIG,
213 RSL_IE_MR_CONTROL,
214 RSL_IE_SUP_CODEC_TYPES,
215 RSL_IE_CODEC_CONFIG,
216 RSL_IE_RTD,
217 RSL_IE_TFO_STATUS,
218 RSL_IE_LLP_APDU,
Harald Welte75099262009-02-16 21:12:08 +0000219
Harald Welte86c162d2009-07-12 09:45:05 +0200220 RSL_IE_IPAC_SRTP_CONFIG = 0xe0,
221 RSL_IE_IPAC_PROXY_UDP = 0xe1,
222 RSL_IE_IPAC_BSCMPL_TOUT = 0xe2,
Harald Welte75099262009-02-16 21:12:08 +0000223 RSL_IE_IPAC_REMOTE_IP = 0xf0,
224 RSL_IE_IPAC_REMOTE_PORT = 0xf1,
Harald Welte86c162d2009-07-12 09:45:05 +0200225 RSL_IE_IPAC_RTP_PAYLOAD = 0xf2,
Harald Welte75099262009-02-16 21:12:08 +0000226 RSL_IE_IPAC_LOCAL_PORT = 0xf3,
Harald Welte86c162d2009-07-12 09:45:05 +0200227 RSL_IE_IPAC_SPEECH_MODE = 0xf4,
Harald Welte75099262009-02-16 21:12:08 +0000228 RSL_IE_IPAC_LOCAL_IP = 0xf5,
Harald Welte86c162d2009-07-12 09:45:05 +0200229 RSL_IE_IPAC_CONN_STAT = 0xf6,
230 RSL_IE_IPAC_HO_C_PARMS = 0xf7,
231 RSL_IE_IPAC_CONN_ID = 0xf8,
232 RSL_IE_IPAC_RTP_CSD_FMT = 0xf9,
233 RSL_IE_IPAC_RTP_JIT_BUF = 0xfa,
234 RSL_IE_IPAC_RTP_COMPR = 0xfb,
235 RSL_IE_IPAC_RTP_PAYLOAD2= 0xfc,
236 RSL_IE_IPAC_RTP_MPLEX = 0xfd,
237 RSL_IE_IPAC_RTP_MPLEX_ID= 0xfe,
Harald Welte52b1f982008-12-23 20:25:15 +0000238};
239
240/* Chapter 9.3.1 */
241#define RSL_CHAN_NR_MASK 0xf8
242#define RSL_CHAN_Bm_ACCHs 0x08
243#define RSL_CHAN_Lm_ACCHs 0x10 /* .. 0x18 */
244#define RSL_CHAN_SDCCH4_ACCH 0x20 /* .. 0x38 */
245#define RSL_CHAN_SDCCH8_ACCH 0x40 /* ...0x78 */
246#define RSL_CHAN_BCCH 0x80
247#define RSL_CHAN_RACH 0x88
248#define RSL_CHAN_PCH_AGCH 0x90
249
250/* Chapter 9.3.3 */
251#define RSL_ACT_TYPE_INITIAL 0x00
252#define RSL_ACT_TYPE_REACT 0x80
253#define RSL_ACT_INTRA_IMM_ASS 0x00
254#define RSL_ACT_INTRA_NORM_ASS 0x01
255#define RSL_ACT_INTER_ASYNC 0x02
256#define RSL_ACT_INTER_SYNC 0x03
257#define RSL_ACT_SECOND_ADD 0x04
258#define RSL_ACT_SECOND_MULTI 0x05
259
260/* Chapter 9.3.6 */
261struct rsl_ie_chan_mode {
262 u_int8_t dtx_dtu;
263 u_int8_t spd_ind;
264 u_int8_t chan_rt;
265 u_int8_t chan_rate;
266} __attribute__ ((packed));
267#define RSL_CMOD_DTXu 0x01 /* uplink */
268#define RSL_CMOD_DTXd 0x02 /* downlink */
269#define RSL_CMOD_SPD_SPEECH 0x01
270#define RSL_CMOD_SPD_DATA 0x02
271#define RSL_CMOD_SPD_SIGN 0x03
272#define RSL_CMOD_CRT_SDCCH 0x01
273#define RSL_CMOD_CRT_TCH_Bm 0x08 /* full-rate */
274#define RSL_CMOD_CRT_TCH_Lm 0x09 /* half-rate */
275/* FIXME: More CRT types */
276#define RSL_CMOD_SP_GSM1 0x01
277#define RSL_CMOD_SP_GSM2 0x11
278#define RSL_CMOD_SP_GSM3 0x21
279
280/* Chapter 9.3.5 */
281struct rsl_ie_chan_ident {
282 /* GSM 04.08 10.5.2.5 */
283 struct {
284 u_int8_t iei;
285 u_int8_t chan_nr; /* enc_chan_nr */
286 u_int8_t oct3;
287 u_int8_t oct4;
288 } chan_desc;
289#if 0 /* spec says we need this but Abissim doesn't use it */
290 struct {
291 u_int8_t tag;
292 u_int8_t len;
293 } mobile_alloc;
294#endif
295} __attribute__ ((packed));
296
Harald Welte4b634542008-12-27 01:55:51 +0000297/* Chapter 9.3.22 */
298#define RLL_CAUSE_T200_EXPIRED 0x01
299#define RLL_CAUSE_REEST_REQ 0x02
300#define RLL_CAUSE_UNSOL_UA_RESP 0x03
301#define RLL_CAUSE_UNSOL_DM_RESP 0x04
302#define RLL_CAUSE_UNSOL_DM_RESP_MF 0x05
303#define RLL_CAUSE_UNSOL_SPRV_RESP 0x06
304#define RLL_CAUSE_SEQ_ERR 0x07
305#define RLL_CAUSE_UFRM_INC_PARAM 0x08
306#define RLL_CAUSE_SFRM_INC_PARAM 0x09
307#define RLL_CAUSE_IFRM_INC_MBITS 0x0a
308#define RLL_CAUSE_IFRM_INC_LEN 0x0b
309#define RLL_CAUSE_FRM_UNIMPL 0x0c
310#define RLL_CAUSE_SABM_MF 0x0d
311#define RLL_CAUSE_SABM_INFO_NOTALL 0x0e
312
Harald Welte702d8702008-12-26 20:25:35 +0000313/* Chapter 9.3.26 */
314#define RSL_ERRCLS_NORMAL 0x00
315#define RSL_ERRCLS_RESOURCE_UNAVAIL 0x20
316#define RSL_ERRCLS_SERVICE_UNAVAIL 0x30
317#define RSL_ERRCLS_SERVICE_UNIMPL 0x40
318#define RSL_ERRCLS_INVAL_MSG 0x50
319#define RSL_ERRCLS_PROTO_ERROR 0x60
320#define RSL_ERRCLS_INTERWORKING 0x70
321
322#define RSL_ERR_RADIO_IF_FAIL 0x00
323#define RSL_ERR_RADIO_LINK_FAIL 0x01
324#define RSL_ERR_HANDOVER_ACC_FAIL 0x02
325#define RSL_ERR_TALKER_ACC_FAIL 0x03
326#define RSL_ERR_OM_INTERVENTION 0x07
327#define RSL_ERR_EQUIPMENT_FAIL 0x20
328#define RSL_ERR_RR_UNAVAIL 0x21
329#define RSL_ERR_TERR_CH_FAIL 0x22
330#define RSL_ERR_CCCH_OVERLOAD 0x23
331#define RSL_ERR_ACCH_OVERLOAD 0x24
332#define RSL_ERR_PROCESSOR_OVERLOAD 0x25
333#define RSL_ERR_RES_UNAVAIL 0x2f
334#define RSL_ERR_TRANSC_UNAVAIL 0x30
335#define RSL_ERR_SERV_OPT_UNAVAIL 0x3f
336#define RSL_ERR_ENCR_UNIMPL 0x40
337#define RSL_ERR_SEV_OPT_UNIMPL 0x4f
338#define RSL_ERR_RCH_ALR_ACTV_ALLOC 0x50
339#define RSL_ERR_INVALID_MESSAGE 0x5f
340#define RSL_ERR_MSG_DISCR 0x60
341#define RSL_ERR_MSG_TYPE 0x61
342#define RSL_ERR_MSG_SEQA 0x62
343#define RSL_ERR_IE_ERROR 0x63
344#define RSL_ERR_MAND_IE_ERROR 0x64
345#define RSL_ERR_OPT_IE_ERROR 0x65
346#define RSL_ERR_IE_NONEXIST 0x66
347#define RSL_ERR_IE_LENGTH 0x67
348#define RSL_ERR_IE_CONTENT 0x68
349#define RSL_ERR_PROTO 0x6f
350#define RSL_ERR_INTERWORKING 0x7f
351
Harald Welte52b1f982008-12-23 20:25:15 +0000352/* Chapter 9.3.30 */
353#define RSL_SYSTEM_INFO_8 0x00
354#define RSL_SYSTEM_INFO_1 0x01
355#define RSL_SYSTEM_INFO_2 0x02
356#define RSL_SYSTEM_INFO_3 0x03
357#define RSL_SYSTEM_INFO_4 0x04
358#define RSL_SYSTEM_INFO_5 0x05
359#define RSL_SYSTEM_INFO_6 0x06
360#define RSL_SYSTEM_INFO_7 0x07
361#define RSL_SYSTEM_INFO_16 0x08
362#define RSL_SYSTEM_INFO_17 0x09
363#define RSL_SYSTEM_INFO_2bis 0x0a
364#define RSL_SYSTEM_INFO_2ter 0x0b
365#define RSL_SYSTEM_INFO_5bis 0x0d
366#define RSL_SYSTEM_INFO_5ter 0x0e
367#define RSL_SYSTEM_INFO_10 0x0f
368#define REL_EXT_MEAS_ORDER 0x47
369#define RSL_MEAS_INFO 0x48
370#define RSL_SYSTEM_INFO_13 0x28
371#define RSL_SYSTEM_INFO_2quater 0x29
372#define RSL_SYSTEM_INFO_9 0x2a
373#define RSL_SYSTEM_INFO_18 0x2b
374#define RSL_SYSTEM_INFO_19 0x2c
375#define RSL_SYSTEM_INFO_20 0x2d
376
377/* Chapter 9.3.40 */
378#define RSL_CHANNEED_ANY 0x00
379#define RSL_CHANNEED_SDCCH 0x01
380#define RSL_CHANNEED_TCH_F 0x02
381#define RSL_CHANNEED_TCH_ForH 0x03
382
Holger Freytherb0155442009-02-03 23:24:04 +0000383/* Chapter 3.3.2.3 Brocast control channel */
384/* CCCH-CONF, NC is not combined */
385#define RSL_BCCH_CCCH_CONF_1_NC 0x00
386#define RSL_BCCH_CCCH_CONF_1_C 0x01
387#define RSL_BCCH_CCCH_CONF_2_NC 0x02
388#define RSL_BCCH_CCCH_CONF_3_NC 0x04
389#define RSL_BCCH_CCCH_CONF_4_NC 0x06
390
391/* BS-PA-MFRMS */
392#define RSL_BS_PA_MFRMS_2 0x00
393#define RSL_BS_PA_MFRMS_3 0x01
394#define RSL_BS_PA_MFRMS_4 0x02
395#define RSL_BS_PA_MFRMS_5 0x03
396#define RSL_BS_PA_MFRMS_6 0x04
397#define RSL_BS_PA_MFRMS_7 0x05
398#define RSL_BS_PA_MFRMS_8 0x06
399#define RSL_BS_PA_MFRMS_9 0x07
400
Harald Welte0427a9f2009-07-12 11:17:16 +0200401/* RSL_IE_IPAC_RTP_PAYLOAD[2] */
402enum rsl_ipac_rtp_payload {
403 RSL_IPAC_RTP_GSM = 1,
404 RSL_IPAC_RTP_EFR,
405 RSL_IPAC_RTP_AMR,
406 RSL_IPAC_RTP_CSD,
407 RSL_IPAC_RTP_MUX,
408};
409
410/* RSL_IE_IPAC_SPEECH_MODE, lower four bits */
411enum rsl_ipac_speech_mode_s {
412 RSL_IPAC_SPEECH_GSM_FR = 0, /* GSM FR (Type 1, FS) */
413 RSL_IPAC_SPEECH_GSM_EFR = 1, /* GSM EFR (Type 2, FS) */
414 RSL_IPAC_SPEECH_GSM_AMR_FR = 2, /* GSM AMR/FR (Type 3, FS) */
415 RSL_IPAC_SPEECH_GSM_HR = 3, /* GSM HR (Type 1, HS) */
416 RSL_IPAC_SPEECH_GSM_AMR_HR = 5, /* GSM AMR/hr (Type 3, HS) */
417 RSL_IPAC_SPEECH_AS_RTP = 0xf, /* As specified by RTP Payload IE */
418};
419/* RSL_IE_IPAC_SPEECH_MODE, upper four bits */
420enum rsl_ipac_speech_mode_m {
421 RSL_IPAC_SPEECH_M_RXTX = 0, /* Send and Receive */
422 RSL_IPAC_SPEECH_M_RX = 1, /* Receive only */
423 RSL_IPAC_SPEECH_M_TX = 2, /* Send only */
424};
425
426/* RSL_IE_IPAC_RTP_CSD_FMT, lower four bits */
427enum rsl_ipac_rtp_csd_format_d {
428 RSL_IPAC_RTP_CSD_EXT_TRAU = 0,
429 RSL_IPAC_RTP_CSD_NON_TRAU = 1,
430 RSL_IPAC_RTP_CSD_TRAU_BTS = 2,
431 RSL_IPAC_RTP_CSD_IWF_FREE = 3,
432};
433/* RSL_IE_IPAC_RTP_CSD_FMT, upper four bits */
434enum rsl_ipac_rtp_csd_format_ir {
435 RSL_IPAC_RTP_CSD_IR_8k = 0,
436 RSL_IPAC_RTP_CSD_IR_16k = 1,
437 RSL_IPAC_RTP_CSD_IR_32k = 2,
438 RSL_IPAC_RTP_CSD_IR_64k = 3,
439};
Harald Welte52b1f982008-12-23 20:25:15 +0000440
441#include "msgb.h"
442
Harald Weltee79769b2009-02-07 00:48:17 +0000443int rsl_bcch_info(struct gsm_bts_trx *trx, u_int8_t type,
Harald Welte52b1f982008-12-23 20:25:15 +0000444 const u_int8_t *data, int len);
Harald Weltee79769b2009-02-07 00:48:17 +0000445int rsl_sacch_filling(struct gsm_bts_trx *trx, u_int8_t type,
Harald Welte52b1f982008-12-23 20:25:15 +0000446 const u_int8_t *data, int len);
Harald Weltee79769b2009-02-07 00:48:17 +0000447int rsl_chan_activate(struct gsm_bts_trx *trx, u_int8_t chan_nr,
Harald Welte52b1f982008-12-23 20:25:15 +0000448 u_int8_t act_type,
449 struct rsl_ie_chan_mode *chan_mode,
450 struct rsl_ie_chan_ident *chan_ident,
451 u_int8_t bs_power, u_int8_t ms_power,
452 u_int8_t ta);
Harald Welteda783762009-02-18 03:29:53 +0000453int rsl_chan_activate_lchan(struct gsm_lchan *lchan, u_int8_t act_type,
Harald Welteddab3c72009-02-28 13:19:15 +0000454 u_int8_t ta, u_int8_t mode);
Harald Welteda783762009-02-18 03:29:53 +0000455int rsl_chan_mode_modify_req(struct gsm_lchan *ts);
Harald Welte52b1f982008-12-23 20:25:15 +0000456int rsl_paging_cmd(struct gsm_bts *bts, u_int8_t paging_group, u_int8_t len,
457 u_int8_t *ms_ident, u_int8_t chan_needed);
Holger Freyther7448a532009-01-04 20:18:23 +0000458int rsl_paging_cmd_subscr(struct gsm_bts *bts, u_int8_t chan_needed,
459 struct gsm_subscriber *subscr);
Harald Welte52b1f982008-12-23 20:25:15 +0000460int rsl_imm_assign_cmd(struct gsm_bts *bts, u_int8_t len, u_int8_t *val);
Harald Welte52b1f982008-12-23 20:25:15 +0000461
Harald Welte8470bf22008-12-25 23:28:35 +0000462int rsl_data_request(struct msgb *msg, u_int8_t link_id);
463
Harald Welte75099262009-02-16 21:12:08 +0000464/* ip.access specfic RSL extensions */
465int rsl_ipacc_bind(struct gsm_lchan *lchan);
466int rsl_ipacc_connect(struct gsm_lchan *lchan, u_int32_t ip,
Harald Welte20855542009-07-12 09:50:35 +0200467 u_int16_t port, u_int16_t conn_id,
468 u_int8_t rtp_payload2);
Harald Welte75099262009-02-16 21:12:08 +0000469
Harald Welte8470bf22008-12-25 23:28:35 +0000470int abis_rsl_rcvmsg(struct msgb *msg);
471
Holger Freyther2976c402009-02-04 01:09:20 +0000472unsigned int get_paging_group(u_int64_t imsi, unsigned int bs_cc_chans,
473 int n_pag_blocks);
474unsigned int n_pag_blocks(int bs_ccch_sdcch_comb, unsigned int bs_ag_blks_res);
Holger Freyther3aa8d6c2009-02-04 02:14:45 +0000475u_int64_t str_to_imsi(const char *imsi_str);
Harald Welte45f83a12009-02-11 11:43:19 +0000476u_int8_t lchan2chan_nr(struct gsm_lchan *lchan);
Holger Freyther2976c402009-02-04 01:09:20 +0000477
Harald Welte8470bf22008-12-25 23:28:35 +0000478/* to be provided by external code */
479int abis_rsl_sendmsg(struct msgb *msg);
Harald Welteae0f2362009-07-19 18:36:49 +0200480int rsl_deact_sacch(struct gsm_lchan *lchan);
Holger Freyther67b4b9a2009-01-01 03:46:11 +0000481int rsl_chan_release(struct gsm_lchan *lchan);
Harald Welte52b1f982008-12-23 20:25:15 +0000482
Holger Freytherb0155442009-02-03 23:24:04 +0000483/* BCCH related code */
484int rsl_ccch_conf_to_bs_cc_chans(int ccch_conf);
485int rsl_ccch_conf_to_bs_ccch_sdcch_comb(int ccch_conf);
486int rsl_number_of_paging_subchannels(struct gsm_bts *bts);
487
Harald Weltefcd24452009-06-20 18:15:19 +0200488int rsl_chan_bs_power_ctrl(struct gsm_lchan *lchan, unsigned int fpc, int db);
489int rsl_chan_ms_power_ctrl(struct gsm_lchan *lchan, unsigned int fpc, int dbm);
490
Harald Welte52b1f982008-12-23 20:25:15 +0000491#endif /* RSL_MT_H */
492