blob: 29cca826992dc663ce0b2a8fcb913a0941b5f966 [file] [log] [blame]
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +02001/* (C) 2009,2010 by Holger Hans Peter Freyther <zecke@selfish.org>
2 * (C) 2009,2010 by On-Waves
3 * All Rights Reserved
4 *
5 * This program is free software; you can redistribute it and/or modify
6 * it under the terms of the GNU General Public License as published by
7 * the Free Software Foundation; either version 2 of the License, or
8 * (at your option) any later version.
9 *
10 * This program is distributed in the hope that it will be useful,
11 * but WITHOUT ANY WARRANTY; without even the implied warranty of
12 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
13 * GNU General Public License for more details.
14 *
15 * You should have received a copy of the GNU General Public License along
16 * with this program; if not, write to the Free Software Foundation, Inc.,
17 * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
18 *
19 */
20
Pablo Neira Ayuso83419342011-03-22 16:36:13 +010021#include <osmocom/gsm/gsm0808.h>
22#include <osmocom/gsm/protocol/gsm_08_08.h>
23#include <osmocom/gsm/gsm48.h>
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020024
25#include <arpa/inet.h>
26
27#define BSSMAP_MSG_SIZE 512
28#define BSSMAP_MSG_HEADROOM 128
29
Holger Hans Peter Freyther06f795c2010-07-23 18:20:02 +080030struct msgb *gsm0808_create_layer3(struct msgb *msg_l3, uint16_t nc, uint16_t cc, int lac, uint16_t _ci)
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020031{
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020032 struct msgb* msg;
Harald Welte65c2d362012-01-21 14:26:01 +010033 struct {
34 uint8_t ident;
35 struct gsm48_loc_area_id lai;
36 uint16_t ci;
37 } __attribute__ ((packed)) lai_ci;
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020038
39 msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
40 "bssmap cmpl l3");
41 if (!msg)
42 return NULL;
43
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020044 /* create layer 3 header */
Harald Welte65c2d362012-01-21 14:26:01 +010045 msgb_v_put(msg, BSS_MAP_MSG_COMPLETE_LAYER_3);
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020046
47 /* create the cell header */
Harald Welte65c2d362012-01-21 14:26:01 +010048 lai_ci.ident = CELL_IDENT_WHOLE_GLOBAL;
49 gsm48_generate_lai(&lai_ci.lai, cc, nc, lac);
50 lai_ci.ci = htons(_ci);
51 msgb_tlv_put(msg, GSM0808_IE_CELL_IDENTIFIER, sizeof(lai_ci),
52 (uint8_t *) &lai_ci);
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020053
54 /* copy the layer3 data */
Harald Welte65c2d362012-01-21 14:26:01 +010055 msgb_tlv_put(msg, GSM0808_IE_LAYER_3_INFORMATION,
56 msgb_l3len(msg_l3), msg_l3->l3h);
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020057
Harald Welte65c2d362012-01-21 14:26:01 +010058 /* push the bssmap header */
59 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020060
61 return msg;
62}
63
64struct msgb *gsm0808_create_reset(void)
65{
Harald Welte65c2d362012-01-21 14:26:01 +010066 uint8_t cause = GSM0808_CAUSE_EQUIPMENT_FAILURE;
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020067 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
68 "bssmap: reset");
69 if (!msg)
70 return NULL;
71
Harald Welte65c2d362012-01-21 14:26:01 +010072 msgb_v_put(msg, BSS_MAP_MSG_RESET);
73 msgb_tlv_put(msg, GSM0808_IE_CAUSE, 1, &cause);
74 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
75
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020076 return msg;
77}
78
Harald Weltea62fe312013-06-19 15:14:37 +020079struct msgb *gsm0808_create_reset_ack(void)
80{
81 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
82 "bssmap: reset ack");
83 if (!msg)
84 return NULL;
85
86 msgb_v_put(msg, BSS_MAP_MSG_RESET_ACKNOWLEDGE);
87 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
88
89 return msg;
90}
91
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020092struct msgb *gsm0808_create_clear_complete(void)
93{
94 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
95 "bssmap: clear complete");
Harald Welte65c2d362012-01-21 14:26:01 +010096 uint8_t val = BSS_MAP_MSG_CLEAR_COMPLETE;
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +020097 if (!msg)
98 return NULL;
99
Harald Welte65c2d362012-01-21 14:26:01 +0100100 msg->l3h = msg->data;
101 msgb_tlv_put(msg, BSSAP_MSG_BSS_MANAGEMENT, 1, &val);
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200102
103 return msg;
104}
105
Holger Hans Peter Freythera3f05d82010-10-27 11:49:24 +0200106struct msgb *gsm0808_create_clear_command(uint8_t reason)
107{
108 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
109 "bssmap: clear command");
110 if (!msg)
111 return NULL;
112
Holger Hans Peter Freytheraeebe392010-10-27 12:36:05 +0200113 msg->l3h = msgb_tv_put(msg, BSSAP_MSG_BSS_MANAGEMENT, 4);
114 msgb_v_put(msg, BSS_MAP_MSG_CLEAR_CMD);
115 msgb_tlv_put(msg, GSM0808_IE_CAUSE, 1, &reason);
Harald Welte65c2d362012-01-21 14:26:01 +0100116
Holger Hans Peter Freythera3f05d82010-10-27 11:49:24 +0200117 return msg;
118}
119
Holger Hans Peter Freyther81716d52010-04-17 06:16:35 +0200120struct msgb *gsm0808_create_cipher_complete(struct msgb *layer3, uint8_t alg_id)
121{
122 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
123 "cipher-complete");
124 if (!msg)
125 return NULL;
126
127 /* send response with BSS override for A5/1... cheating */
Harald Welte65c2d362012-01-21 14:26:01 +0100128 msgb_v_put(msg, BSS_MAP_MSG_CIPHER_MODE_COMPLETE);
Holger Hans Peter Freyther81716d52010-04-17 06:16:35 +0200129
130 /* include layer3 in case we have at least two octets */
131 if (layer3 && msgb_l3len(layer3) > 2) {
Harald Welte65c2d362012-01-21 14:26:01 +0100132 msg->l4h = msgb_tlv_put(msg, GSM0808_IE_LAYER_3_MESSAGE_CONTENTS,
133 msgb_l3len(layer3), layer3->l3h);
Holger Hans Peter Freyther81716d52010-04-17 06:16:35 +0200134 }
135
136 /* and the optional BSS message */
Harald Welte65c2d362012-01-21 14:26:01 +0100137 msgb_tv_put(msg, GSM0808_IE_CHOSEN_ENCR_ALG, alg_id);
Holger Hans Peter Freyther81716d52010-04-17 06:16:35 +0200138
Harald Welte65c2d362012-01-21 14:26:01 +0100139 /* pre-pend the header */
140 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
141
Holger Hans Peter Freyther81716d52010-04-17 06:16:35 +0200142 return msg;
143}
144
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200145struct msgb *gsm0808_create_cipher_reject(uint8_t cause)
146{
147 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
148 "bssmap: clear complete");
149 if (!msg)
150 return NULL;
151
Harald Welte65c2d362012-01-21 14:26:01 +0100152 msgb_tv_put(msg, BSS_MAP_MSG_CIPHER_MODE_REJECT, cause);
153
154 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200155
156 return msg;
157}
158
Harald Welte07b625d2012-01-23 10:02:58 +0100159struct msgb *gsm0808_create_classmark_update(const uint8_t *cm2, uint8_t cm2_len,
160 const uint8_t *cm3, uint8_t cm3_len)
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200161{
162 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
163 "classmark-update");
164 if (!msg)
165 return NULL;
166
Harald Welte65c2d362012-01-21 14:26:01 +0100167 msgb_v_put(msg, BSS_MAP_MSG_CLASSMARK_UPDATE);
Harald Welte07b625d2012-01-23 10:02:58 +0100168 msgb_tlv_put(msg, GSM0808_IE_CLASSMARK_INFORMATION_T2, cm2_len, cm2);
169 if (cm3)
170 msgb_tlv_put(msg, GSM0808_IE_CLASSMARK_INFORMATION_T3,
171 cm3_len, cm3);
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200172
Harald Welte65c2d362012-01-21 14:26:01 +0100173 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
174
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200175 return msg;
176}
177
178struct msgb *gsm0808_create_sapi_reject(uint8_t link_id)
179{
180 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
181 "bssmap: sapi 'n' reject");
182 if (!msg)
183 return NULL;
184
Harald Welte65c2d362012-01-21 14:26:01 +0100185 msgb_v_put(msg, BSS_MAP_MSG_SAPI_N_REJECT);
186 msgb_v_put(msg, link_id);
187 msgb_v_put(msg, GSM0808_CAUSE_BSS_NOT_EQUIPPED);
188
189 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200190
191 return msg;
192}
193
Holger Hans Peter Freytherb60a4b32010-07-23 18:35:59 +0800194struct msgb *gsm0808_create_assignment_completed(uint8_t rr_cause,
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200195 uint8_t chosen_channel, uint8_t encr_alg_id,
196 uint8_t speech_mode)
197{
Harald Welte65c2d362012-01-21 14:26:01 +0100198 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
199 "bssmap: ass compl");
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200200 if (!msg)
201 return NULL;
202
Harald Welte65c2d362012-01-21 14:26:01 +0100203 msgb_v_put(msg, BSS_MAP_MSG_ASSIGMENT_COMPLETE);
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200204
205 /* write 3.2.2.22 */
Harald Welte65c2d362012-01-21 14:26:01 +0100206 msgb_tv_put(msg, GSM0808_IE_RR_CAUSE, rr_cause);
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200207
208 /* write cirtcuit identity code 3.2.2.2 */
209 /* write cell identifier 3.2.2.17 */
210 /* write chosen channel 3.2.2.33 when BTS picked it */
Harald Welte65c2d362012-01-21 14:26:01 +0100211 msgb_tv_put(msg, GSM0808_IE_CHOSEN_CHANNEL, chosen_channel);
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200212
213 /* write chosen encryption algorithm 3.2.2.44 */
Harald Welte65c2d362012-01-21 14:26:01 +0100214 msgb_tv_put(msg, GSM0808_IE_CHOSEN_ENCR_ALG, encr_alg_id);
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200215
216 /* write circuit pool 3.2.2.45 */
217 /* write speech version chosen: 3.2.2.51 when BTS picked it */
Harald Welte65c2d362012-01-21 14:26:01 +0100218 if (speech_mode != 0)
219 msgb_tv_put(msg, GSM0808_IE_SPEECH_VERSION, speech_mode);
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200220
221 /* write LSA identifier 3.2.2.15 */
222
Harald Welte65c2d362012-01-21 14:26:01 +0100223 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200224
Holger Hans Peter Freytherba6172a2010-04-17 06:21:49 +0200225 return msg;
226}
227
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200228struct msgb *gsm0808_create_assignment_failure(uint8_t cause, uint8_t *rr_cause)
229{
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200230 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
231 "bssmap: ass fail");
232 if (!msg)
233 return NULL;
234
Harald Welte65c2d362012-01-21 14:26:01 +0100235 msgb_v_put(msg, BSS_MAP_MSG_ASSIGMENT_FAILURE);
236 msgb_tlv_put(msg, GSM0808_IE_CAUSE, 1, &cause);
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200237
238 /* RR cause 3.2.2.22 */
Harald Welte65c2d362012-01-21 14:26:01 +0100239 if (rr_cause)
240 msgb_tv_put(msg, GSM0808_IE_RR_CAUSE, *rr_cause);
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200241
242 /* Circuit pool 3.22.45 */
243 /* Circuit pool list 3.2.2.46 */
244
245 /* update the size */
Harald Welte65c2d362012-01-21 14:26:01 +0100246 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
247
Holger Hans Peter Freyther280cd512010-04-15 10:10:39 +0200248 return msg;
249}
Holger Hans Peter Freyther7daa01c2010-04-17 05:14:36 +0200250
Holger Hans Peter Freytheraf270a42010-11-04 12:42:50 +0100251struct msgb *gsm0808_create_clear_rqst(uint8_t cause)
252{
253 struct msgb *msg;
254
255 msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
256 "bssmap: clear rqst");
257 if (!msg)
258 return NULL;
259
Harald Welte65c2d362012-01-21 14:26:01 +0100260 msgb_v_put(msg, BSS_MAP_MSG_CLEAR_RQST);
261 msgb_tlv_put(msg, GSM0808_IE_CAUSE, 1, &cause);
262 msg->l3h = msgb_tv_push(msg, BSSAP_MSG_BSS_MANAGEMENT, msgb_length(msg));
Holger Hans Peter Freytheraf270a42010-11-04 12:42:50 +0100263
Holger Hans Peter Freytheraf270a42010-11-04 12:42:50 +0100264 return msg;
265}
266
Holger Hans Peter Freyther9a3dec02010-05-16 08:15:40 +0800267void gsm0808_prepend_dtap_header(struct msgb *msg, uint8_t link_id)
268{
269 uint8_t *hh = msgb_push(msg, 3);
270 hh[0] = BSSAP_MSG_DTAP;
271 hh[1] = link_id;
272 hh[2] = msg->len - 3;
273}
274
Holger Hans Peter Freytherc25c6682010-11-04 12:26:06 +0100275struct msgb *gsm0808_create_dtap(struct msgb *msg_l3, uint8_t link_id)
276{
277 struct dtap_header *header;
278 uint8_t *data;
279 struct msgb *msg = msgb_alloc_headroom(BSSMAP_MSG_SIZE, BSSMAP_MSG_HEADROOM,
280 "dtap");
281 if (!msg)
282 return NULL;
283
284 /* DTAP header */
285 msg->l3h = msgb_put(msg, sizeof(*header));
286 header = (struct dtap_header *) &msg->l3h[0];
287 header->type = BSSAP_MSG_DTAP;
288 header->link_id = link_id;
289 header->length = msgb_l3len(msg_l3);
290
291 /* Payload */
292 data = msgb_put(msg, header->length);
293 memcpy(data, msg_l3->l3h, header->length);
294
295 return msg;
296}
297
Harald Welte92107df2014-06-21 23:16:20 +0200298/* As per 3GPP TS 48.008 version 11.7.0 Release 11 */
Holger Hans Peter Freyther7daa01c2010-04-17 05:14:36 +0200299static const struct tlv_definition bss_att_tlvdef = {
300 .def = {
Harald Welte92107df2014-06-21 23:16:20 +0200301 [GSM0808_IE_CIRCUIT_IDENTITY_CODE] = { TLV_TYPE_FIXED, 2 },
302 [GSM0808_IE_CONNECTION_RELEASE_RQSTED] = { TLV_TYPE_TV },
303 [GSM0808_IE_RESOURCE_AVAILABLE] = { TLV_TYPE_FIXED, 21 },
304 [GSM0808_IE_CAUSE] = { TLV_TYPE_TLV },
Holger Hans Peter Freyther7daa01c2010-04-17 05:14:36 +0200305 [GSM0808_IE_IMSI] = { TLV_TYPE_TLV },
306 [GSM0808_IE_TMSI] = { TLV_TYPE_TLV },
Harald Welte92107df2014-06-21 23:16:20 +0200307 [GSM0808_IE_NUMBER_OF_MSS] = { TLV_TYPE_TV },
Dmitri Soloviev29099422013-07-11 09:25:37 +0200308 [GSM0808_IE_LAYER_3_HEADER_INFORMATION] = { TLV_TYPE_TLV },
Harald Welte92107df2014-06-21 23:16:20 +0200309 [GSM0808_IE_ENCRYPTION_INFORMATION] = { TLV_TYPE_TLV },
310 [GSM0808_IE_CHANNEL_TYPE] = { TLV_TYPE_TLV },
311 [GSM0808_IE_PERIODICITY] = { TLV_TYPE_TV },
312 [GSM0808_IE_EXTENDED_RESOURCE_INDICATOR]= { TLV_TYPE_TV },
313 [GSM0808_IE_TOTAL_RESOURCE_ACCESSIBLE] = { TLV_TYPE_FIXED, 4 },
314 [GSM0808_IE_LSA_IDENTIFIER] = { TLV_TYPE_TLV },
315 [GSM0808_IE_LSA_IDENTIFIER_LIST] = { TLV_TYPE_TLV },
Holger Hans Peter Freyther715e9452014-08-21 14:17:45 +0200316 [GSM0808_IE_LSA_INFORMATION] = { TLV_TYPE_TLV },
Harald Welte92107df2014-06-21 23:16:20 +0200317 [GSM0808_IE_CELL_IDENTIFIER] = { TLV_TYPE_TLV },
318 [GSM0808_IE_PRIORITY] = { TLV_TYPE_TLV },
319 [GSM0808_IE_CLASSMARK_INFORMATION_T2] = { TLV_TYPE_TLV },
320 [GSM0808_IE_CLASSMARK_INFORMATION_T3] = { TLV_TYPE_TLV },
321 [GSM0808_IE_INTERFERENCE_BAND_TO_USE] = { TLV_TYPE_TV },
322 [GSM0808_IE_RR_CAUSE] = { TLV_TYPE_TV },
323 [GSM0808_IE_LSA_INFORMATION] = { TLV_TYPE_TLV },
324 [GSM0808_IE_LAYER_3_INFORMATION] = { TLV_TYPE_TLV },
325 [GSM0808_IE_DLCI] = { TLV_TYPE_TV },
326 [GSM0808_IE_DOWNLINK_DTX_FLAG] = { TLV_TYPE_TV },
327 [GSM0808_IE_CELL_IDENTIFIER_LIST] = { TLV_TYPE_TLV },
328 [GSM0808_IE_CELL_ID_LIST_SEGMENT] = { TLV_TYPE_TLV },
329 [GSM0808_IE_CELL_ID_LIST_SEG_EST_CELLS] = { TLV_TYPE_TLV },
330 [GSM0808_IE_CELL_ID_LIST_SEG_CELLS_TBE] = { TLV_TYPE_TLV },
331 [GSM0808_IE_CELL_ID_LIST_SEG_REL_CELLS] = { TLV_TYPE_TLV },
332 [GSM0808_IE_CELL_ID_LIST_SEG_NE_CELLS] = { TLV_TYPE_TLV },
333 [GSM0808_IE_RESPONSE_RQST] = { TLV_TYPE_T },
334 [GSM0808_IE_RESOURCE_INDICATION_METHOD] = { TLV_TYPE_TV },
335 [GSM0808_IE_CLASSMARK_INFORMATION_TYPE_1] = { TLV_TYPE_TV },
336 [GSM0808_IE_CIRCUIT_IDENTITY_CODE_LIST] = { TLV_TYPE_TLV },
337 [GSM0808_IE_DIAGNOSTIC] = { TLV_TYPE_TLV },
338 [GSM0808_IE_CHOSEN_CHANNEL] = { TLV_TYPE_TV },
339 [GSM0808_IE_CIPHER_RESPONSE_MODE] = { TLV_TYPE_TV },
340 [GSM0808_IE_LAYER_3_MESSAGE_CONTENTS] = { TLV_TYPE_TLV },
341 [GSM0808_IE_CHANNEL_NEEDED] = { TLV_TYPE_TV },
342 [GSM0808_IE_TRACE_TYPE] = { TLV_TYPE_TV },
343 [GSM0808_IE_TRIGGERID] = { TLV_TYPE_TLV },
344 [GSM0808_IE_TRACE_REFERENCE] = { TLV_TYPE_TV },
345 [GSM0808_IE_TRANSACTIONID] = { TLV_TYPE_TLV },
346 [GSM0808_IE_MOBILE_IDENTITY] = { TLV_TYPE_TLV },
347 [GSM0808_IE_OMCID] = { TLV_TYPE_TLV },
348 [GSM0808_IE_FORWARD_INDICATOR] = { TLV_TYPE_TV },
Holger Hans Peter Freytherc2b7f922010-08-04 18:50:43 +0800349 [GSM0808_IE_CHOSEN_ENCR_ALG] = { TLV_TYPE_TV },
Harald Welte92107df2014-06-21 23:16:20 +0200350 [GSM0808_IE_CIRCUIT_POOL] = { TLV_TYPE_TV },
351 [GSM0808_IE_CIRCUIT_POOL_LIST] = { TLV_TYPE_TLV },
352 [GSM0808_IE_TIME_INDICATION] = { TLV_TYPE_TV },
353 [GSM0808_IE_RESOURCE_SITUATION] = { TLV_TYPE_TLV },
354 [GSM0808_IE_CURRENT_CHANNEL_TYPE_1] = { TLV_TYPE_TV },
355 [GSM0808_IE_QUEUEING_INDICATOR] = { TLV_TYPE_TV },
356 [GSM0808_IE_SPEECH_VERSION] = { TLV_TYPE_TV },
357 [GSM0808_IE_ASSIGNMENT_REQUIREMENT] = { TLV_TYPE_TV },
358 [GSM0808_IE_TALKER_FLAG] = { TLV_TYPE_T },
359 [GSM0808_IE_GROUP_CALL_REFERENCE] = { TLV_TYPE_TLV },
360 [GSM0808_IE_EMLPP_PRIORITY] = { TLV_TYPE_TV },
361 [GSM0808_IE_CONFIG_EVO_INDI] = { TLV_TYPE_TV },
362 [GSM0808_IE_OLD_BSS_TO_NEW_BSS_INFORMATION] = { TLV_TYPE_TLV },
363 [GSM0808_IE_LCS_QOS] = { TLV_TYPE_TLV },
364 [GSM0808_IE_LSA_ACCESS_CTRL_SUPPR] = { TLV_TYPE_TV },
365 [GSM0808_IE_LCS_PRIORITY] = { TLV_TYPE_TLV },
366 [GSM0808_IE_LOCATION_TYPE] = { TLV_TYPE_TLV },
367 [GSM0808_IE_LOCATION_ESTIMATE] = { TLV_TYPE_TLV },
368 [GSM0808_IE_POSITIONING_DATA] = { TLV_TYPE_TLV },
369 [GSM0808_IE_LCS_CAUSE] = { TLV_TYPE_TLV },
370 [GSM0808_IE_APDU] = { TLV_TYPE_TLV },
371 [GSM0808_IE_NETWORK_ELEMENT_IDENTITY] = { TLV_TYPE_TLV },
372 [GSM0808_IE_GPS_ASSISTANCE_DATA] = { TLV_TYPE_TLV },
373 [GSM0808_IE_DECIPHERING_KEYS] = { TLV_TYPE_TLV },
374 [GSM0808_IE_RETURN_ERROR_RQST] = { TLV_TYPE_TLV },
375 [GSM0808_IE_RETURN_ERROR_CAUSE] = { TLV_TYPE_TLV },
376 [GSM0808_IE_SEGMENTATION] = { TLV_TYPE_TLV },
377 [GSM0808_IE_SERVICE_HANDOVER] = { TLV_TYPE_TLV },
378 [GSM0808_IE_SOURCE_RNC_TO_TARGET_RNC_TRANSPARENT_UMTS] = { TLV_TYPE_TLV },
379 [GSM0808_IE_SOURCE_RNC_TO_TARGET_RNC_TRANSPARENT_CDMA2000] = { TLV_TYPE_TLV },
380 [GSM0808_IE_GERAN_CLASSMARK] = { TLV_TYPE_TLV },
381 [GSM0808_IE_GERAN_BSC_CONTAINER] = { TLV_TYPE_TLV },
382 [GSM0808_IE_NEW_BSS_TO_OLD_BSS_INFO] = { TLV_TYPE_TLV },
383 [GSM0800_IE_INTER_SYSTEM_INFO] = { TLV_TYPE_TLV },
384 [GSM0808_IE_SNA_ACCESS_INFO] = { TLV_TYPE_TLV },
385 [GSM0808_IE_VSTK_RAND_INFO] = { TLV_TYPE_TLV },
386 [GSM0808_IE_PAGING_INFO] = { TLV_TYPE_TV },
387 [GSM0808_IE_IMEI] = { TLV_TYPE_TLV },
388 [GSM0808_IE_VELOCITY_ESTIMATE] = { TLV_TYPE_TLV },
389 [GSM0808_IE_VGCS_FEATURE_FLAGS] = { TLV_TYPE_TLV },
390 [GSM0808_IE_TALKER_PRIORITY] = { TLV_TYPE_TV },
391 [GSM0808_IE_EMERGENCY_SET_INDICATION] = { TLV_TYPE_T },
392 [GSM0808_IE_TALKER_IDENTITY] = { TLV_TYPE_TLV },
393 [GSM0808_IE_SMS_TO_VGCS] = { TLV_TYPE_TLV },
394 [GSM0808_IE_VGCS_TALKER_MODE] = { TLV_TYPE_TLV },
395 [GSM0808_IE_VGCS_VBS_CELL_STATUS] = { TLV_TYPE_TLV },
396 [GSM0808_IE_GANSS_ASSISTANCE_DATA] = { TLV_TYPE_TLV },
397 [GSM0808_IE_GANSS_POSITIONING_DATA] = { TLV_TYPE_TLV },
398 [GSM0808_IE_GANSS_LOCATION_TYPE] = { TLV_TYPE_TLV },
399 [GSM0808_IE_APP_DATA] = { TLV_TYPE_TLV },
400 [GSM0808_IE_DATA_IDENTITY] = { TLV_TYPE_TLV },
401 [GSM0808_IE_APP_DATA_INFO] = { TLV_TYPE_TLV },
402 [GSM0808_IE_MSISDN] = { TLV_TYPE_TLV },
403 [GSM0808_IE_AOIP_TRASP_ADDR] = { TLV_TYPE_TLV },
404 [GSM0808_IE_SPEECH_CODEC_LIST] = { TLV_TYPE_TLV },
405 [GSM0808_IE_SPEECH_CODEC] = { TLV_TYPE_TLV },
406 [GSM0808_IE_CALL_ID] = { TLV_TYPE_FIXED, 4 },
407 [GSM0808_IE_CALL_ID_LIST] = { TLV_TYPE_TLV },
408 [GSM0808_IE_A_IF_SEL_FOR_RESET] = { TLV_TYPE_TV },
409 [GSM0808_IE_KC_128] = { TLV_TYPE_FIXED, 16 },
410 [GSM0808_IE_CSG_IDENTIFIER] = { TLV_TYPE_TLV },
411 [GSM0808_IE_REDIR_ATTEMPT_FLAG] = { TLV_TYPE_T },
412 [GSM0808_IE_REROUTE_REJ_CAUSE] = { TLV_TYPE_TV },
413 [GSM0808_IE_SEND_SEQ_NUM] = { TLV_TYPE_TV },
414 [GSM0808_IE_REROUTE_COMPL_OUTCOME] = { TLV_TYPE_TV },
415 [GSM0808_IE_GLOBAL_CALL_REF] = { TLV_TYPE_TLV },
416 [GSM0808_IE_LCLS_CONFIG] = { TLV_TYPE_TV },
417 [GSM0808_IE_LCLS_CONN_STATUS_CTRL] = { TLV_TYPE_TV },
418 [GSM0808_IE_LCLS_CORR_NOT_NEEDED] = { TLV_TYPE_TV },
419 [GSM0808_IE_LCLS_BSS_STATUS] = { TLV_TYPE_TV },
420 [GSM0808_IE_LCLS_BREAK_REQ] = { TLV_TYPE_TV },
421 [GSM0808_IE_CSFB_INDICATION] = { TLV_TYPE_T },
422 [GSM0808_IE_CS_TO_PS_SRVCC] = { TLV_TYPE_T },
423 [GSM0808_IE_SRC_ENB_TO_TGT_ENB_TRANSP] = { TLV_TYPE_TLV },
424 [GSM0808_IE_CS_TO_PS_SRVCC_IND] = { TLV_TYPE_T },
425 [GSM0808_IE_CN_TO_MS_TRANSP_INFO] = { TLV_TYPE_TLV },
426 [GSM0808_IE_SELECTED_PLMN_ID] = { TLV_TYPE_FIXED, 3 },
427 [GSM0808_IE_LAST_USED_EUTRAN_PLMN_ID] = { TLV_TYPE_FIXED, 3 },
Holger Hans Peter Freyther7daa01c2010-04-17 05:14:36 +0200428 },
429};
430
Harald Weltef4d45ab2011-07-16 12:13:00 +0200431const struct tlv_definition *gsm0808_att_tlvdef(void)
Holger Hans Peter Freyther7daa01c2010-04-17 05:14:36 +0200432{
433 return &bss_att_tlvdef;
434}
Harald Welte9b837e62011-07-11 17:43:19 +0200435
436static const struct value_string gsm0808_msgt_names[] = {
437 { BSS_MAP_MSG_ASSIGMENT_RQST, "ASSIGNMENT REQ" },
438 { BSS_MAP_MSG_ASSIGMENT_COMPLETE, "ASSIGNMENT COMPL" },
439 { BSS_MAP_MSG_ASSIGMENT_FAILURE, "ASSIGNMENT FAIL" },
Harald Welte92107df2014-06-21 23:16:20 +0200440 { BSS_MAP_MSG_CHAN_MOD_RQST, "CHANNEL MODIFY REQUEST" },
Harald Welte9b837e62011-07-11 17:43:19 +0200441
442 { BSS_MAP_MSG_HANDOVER_RQST, "HANDOVER REQ" },
443 { BSS_MAP_MSG_HANDOVER_REQUIRED, "HANDOVER REQUIRED" },
444 { BSS_MAP_MSG_HANDOVER_RQST_ACKNOWLEDGE,"HANDOVER REQ ACK" },
445 { BSS_MAP_MSG_HANDOVER_CMD, "HANDOVER CMD" },
446 { BSS_MAP_MSG_HANDOVER_COMPLETE, "HANDOVER COMPLETE" },
447 { BSS_MAP_MSG_HANDOVER_SUCCEEDED, "HANDOVER SUCCESS" },
448 { BSS_MAP_MSG_HANDOVER_FAILURE, "HANDOVER FAILURE" },
449 { BSS_MAP_MSG_HANDOVER_PERFORMED, "HANDOVER PERFORMED" },
450 { BSS_MAP_MSG_HANDOVER_CANDIDATE_ENQUIRE, "HANDOVER CAND ENQ" },
451 { BSS_MAP_MSG_HANDOVER_CANDIDATE_RESPONSE, "HANDOVER CAND RESP" },
452 { BSS_MAP_MSG_HANDOVER_REQUIRED_REJECT, "HANDOVER REQ REJ" },
453 { BSS_MAP_MSG_HANDOVER_DETECT, "HANDOVER DETECT" },
Harald Welte92107df2014-06-21 23:16:20 +0200454 { BSS_MAP_MSG_INT_HANDOVER_REQUIRED, "INT HANDOVER REQ" },
455 { BSS_MAP_MSG_INT_HANDOVER_REQUIRED_REJ,"INT HANDOVER REQ REJ" },
456 { BSS_MAP_MSG_INT_HANDOVER_CMD, "INT HANDOVER CMD" },
457 { BSS_MAP_MSG_INT_HANDOVER_ENQUIRY, "INT HANDOVER ENQ" },
Harald Welte9b837e62011-07-11 17:43:19 +0200458
459 { BSS_MAP_MSG_CLEAR_CMD, "CLEAR COMMAND" },
460 { BSS_MAP_MSG_CLEAR_COMPLETE, "CLEAR COMPLETE" },
461 { BSS_MAP_MSG_CLEAR_RQST, "CLEAR REQUEST" },
462 { BSS_MAP_MSG_SAPI_N_REJECT, "SAPI N REJECT" },
463 { BSS_MAP_MSG_CONFUSION, "CONFUSION" },
464
465 { BSS_MAP_MSG_SUSPEND, "SUSPEND" },
466 { BSS_MAP_MSG_RESUME, "RESUME" },
467 { BSS_MAP_MSG_CONNECTION_ORIENTED_INFORMATION, "CONN ORIENT INFO" },
468 { BSS_MAP_MSG_PERFORM_LOCATION_RQST, "PERFORM LOC REQ" },
469 { BSS_MAP_MSG_LSA_INFORMATION, "LSA INFORMATION" },
470 { BSS_MAP_MSG_PERFORM_LOCATION_RESPONSE, "PERFORM LOC RESP" },
471 { BSS_MAP_MSG_PERFORM_LOCATION_ABORT, "PERFORM LOC ABORT" },
472 { BSS_MAP_MSG_COMMON_ID, "COMMON ID" },
Harald Welte92107df2014-06-21 23:16:20 +0200473 { BSS_MAP_MSG_REROUTE_CMD, "REROUTE COMMAND" },
474 { BSS_MAP_MSG_REROUTE_COMPLETE, "REROUTE COMPLETE" },
Harald Welte9b837e62011-07-11 17:43:19 +0200475
476 { BSS_MAP_MSG_RESET, "RESET" },
477 { BSS_MAP_MSG_RESET_ACKNOWLEDGE, "RESET ACK" },
478 { BSS_MAP_MSG_OVERLOAD, "OVERLOAD" },
479 { BSS_MAP_MSG_RESET_CIRCUIT, "RESET CIRCUIT" },
480 { BSS_MAP_MSG_RESET_CIRCUIT_ACKNOWLEDGE, "RESET CIRCUIT ACK" },
481 { BSS_MAP_MSG_MSC_INVOKE_TRACE, "MSC INVOKE TRACE" },
482 { BSS_MAP_MSG_BSS_INVOKE_TRACE, "BSS INVOKE TRACE" },
483 { BSS_MAP_MSG_CONNECTIONLESS_INFORMATION, "CONNLESS INFO" },
Harald Welte92107df2014-06-21 23:16:20 +0200484 { BSS_MAP_MSG_RESET_IP_RSRC, "RESET IP RESOURCE" },
485 { BSS_MAP_MSG_RESET_IP_RSRC_ACK, "RESET IP RESOURCE ACK" },
Harald Welte9b837e62011-07-11 17:43:19 +0200486
487 { BSS_MAP_MSG_BLOCK, "BLOCK" },
488 { BSS_MAP_MSG_BLOCKING_ACKNOWLEDGE, "BLOCK ACK" },
489 { BSS_MAP_MSG_UNBLOCK, "UNBLOCK" },
490 { BSS_MAP_MSG_UNBLOCKING_ACKNOWLEDGE, "UNBLOCK ACK" },
491 { BSS_MAP_MSG_CIRCUIT_GROUP_BLOCK, "CIRC GROUP BLOCK" },
492 { BSS_MAP_MSG_CIRCUIT_GROUP_BLOCKING_ACKNOWLEDGE, "CIRC GORUP BLOCK ACK" },
493 { BSS_MAP_MSG_CIRCUIT_GROUP_UNBLOCK, "CIRC GROUP UNBLOCK" },
494 { BSS_MAP_MSG_CIRCUIT_GROUP_UNBLOCKING_ACKNOWLEDGE, "CIRC GROUP UNBLOCK ACK" },
495 { BSS_MAP_MSG_UNEQUIPPED_CIRCUIT, "UNEQUIPPED CIRCUIT" },
496 { BSS_MAP_MSG_CHANGE_CIRCUIT, "CHANGE CIRCUIT" },
497 { BSS_MAP_MSG_CHANGE_CIRCUIT_ACKNOWLEDGE, "CHANGE CIRCUIT ACK" },
498
499 { BSS_MAP_MSG_RESOURCE_RQST, "RESOURCE REQ" },
500 { BSS_MAP_MSG_RESOURCE_INDICATION, "RESOURCE IND" },
501 { BSS_MAP_MSG_PAGING, "PAGING" },
502 { BSS_MAP_MSG_CIPHER_MODE_CMD, "CIPHER MODE CMD" },
503 { BSS_MAP_MSG_CLASSMARK_UPDATE, "CLASSMARK UPDATE" },
504 { BSS_MAP_MSG_CIPHER_MODE_COMPLETE, "CIPHER MODE COMPLETE" },
505 { BSS_MAP_MSG_QUEUING_INDICATION, "QUEUING INDICATION" },
506 { BSS_MAP_MSG_COMPLETE_LAYER_3, "COMPLETE LAYER 3" },
507 { BSS_MAP_MSG_CLASSMARK_RQST, "CLASSMARK REQ" },
508 { BSS_MAP_MSG_CIPHER_MODE_REJECT, "CIPHER MODE REJECT" },
509 { BSS_MAP_MSG_LOAD_INDICATION, "LOAD IND" },
510
Harald Welte92107df2014-06-21 23:16:20 +0200511 { BSS_MAP_MSG_VGCS_VBS_SETUP, "VGCS/VBS SETUP" },
512 { BSS_MAP_MSG_VGCS_VBS_SETUP_ACK, "VGCS/VBS SETUP ACK" },
513 { BSS_MAP_MSG_VGCS_VBS_SETUP_REFUSE, "VGCS/VBS SETUP REFUSE" },
514 { BSS_MAP_MSG_VGCS_VBS_ASSIGNMENT_RQST, "VGCS/VBS ASSIGN REQ" },
515 { BSS_MAP_MSG_VGCS_VBS_ASSIGNMENT_RESULT, "VGCS/VBS ASSIGN RES" },
516 { BSS_MAP_MSG_VGCS_VBS_ASSIGNMENT_FAILURE, "VGCS/VBS ASSIGN FAIL" },
517 { BSS_MAP_MSG_VGCS_VBS_QUEUING_INDICATION, "VGCS/VBS QUEUING IND" },
518 { BSS_MAP_MSG_UPLINK_RQST, "UPLINK REQ" },
519 { BSS_MAP_MSG_UPLINK_RQST_ACKNOWLEDGE, "UPLINK REQ ACK" },
520 { BSS_MAP_MSG_UPLINK_RQST_CONFIRMATION, "UPLINK REQ CONF" },
521 { BSS_MAP_MSG_UPLINK_RELEASE_INDICATION,"UPLINK REL IND" },
522 { BSS_MAP_MSG_UPLINK_REJECT_CMD, "UPLINK REJ CMD" },
523 { BSS_MAP_MSG_UPLINK_RELEASE_CMD, "UPLINK REL CMD" },
524 { BSS_MAP_MSG_UPLINK_SEIZED_CMD, "UPLINK SEIZED CMD" },
525 { BSS_MAP_MSG_VGCS_ADDL_INFO, "VGCS ADDL INFO" },
526 { BSS_MAP_MSG_NOTIFICATION_DATA, "NOTIF DATA" },
527 { BSS_MAP_MSG_UPLINK_APP_DATA, "UPLINK APP DATA" },
528
529 { BSS_MAP_MSG_LCLS_CONNECT_CTRL, "LCLS-CONNECT-CONTROL" },
530 { BSS_MAP_MSG_LCLS_CONNECT_CTRL_ACK, "CLS-CONNECT-CONTROL-ACK" },
531 { BSS_MAP_MSG_LCLS_NOTIFICATION, "LCLS-NOTIFICATION" },
Harald Welte9b837e62011-07-11 17:43:19 +0200532
533 { 0, NULL }
534};
535
536const char *gsm0808_bssmap_name(uint8_t msg_type)
537{
538 return get_value_string(gsm0808_msgt_names, msg_type);
539}
540
541static const struct value_string gsm0808_bssap_names[] = {
542 { BSSAP_MSG_BSS_MANAGEMENT, "MANAGEMENT" },
543 { BSSAP_MSG_DTAP, "DTAP" },
544};
545
546const char *gsm0808_bssap_name(uint8_t msg_type)
547{
548 return get_value_string(gsm0808_bssap_names, msg_type);
549}