blob: 660ffd48a24501f0023cf59de003e07e3294cf4b [file] [log] [blame]
Harald Welte3b6fb082016-04-25 18:46:22 +02001/* Osmocom Subscriber Update Protocol message encoder/decoder */
2
3/* (C) 2014 by Sysmocom s.f.m.c. GmbH, Author: Jacob Erlbeck
4 * (C) 2016 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
18 * along with this program. If not, see <http://www.gnu.org/licenses/>.
19 *
20 */
21#pragma once
22
23#include <stdint.h>
24#include <osmocom/core/msgb.h>
25#include <osmocom/gsm/protocol/gsm_23_003.h>
26#include <osmocom/gsm/protocol/gsm_04_08_gprs.h>
27#include <osmocom/crypt/auth.h>
28
29/*! Maximum nubmer of PDP inside \ref osmo_gsup_message */
30#define OSMO_GSUP_MAX_NUM_PDP_INFO 10 /* GSM 09.02 limits this to 50 */
31/*! Maximum number of auth info inside \ref osmo_gsup_message */
32#define OSMO_GSUP_MAX_NUM_AUTH_INFO 5
33/*! Maximum number of octets encoding MSISDN in BCD format */
34#define OSMO_GSUP_MAX_MSISDN_LEN 9
35
36#define OSMO_GSUP_PDP_TYPE_SIZE 2
37
38/*! Information Element Identifiers for GSUP IEs */
39enum osmo_gsup_iei {
40 OSMO_GSUP_IMSI_IE = 0x01,
41 OSMO_GSUP_CAUSE_IE = 0x02,
42 OSMO_GSUP_AUTH_TUPLE_IE = 0x03,
43 OSMO_GSUP_PDP_INFO_COMPL_IE = 0x04,
44 OSMO_GSUP_PDP_INFO_IE = 0x05,
45 OSMO_GSUP_CANCEL_TYPE_IE = 0x06,
46 OSMO_GSUP_FREEZE_PTMSI_IE = 0x07,
47 OSMO_GSUP_MSISDN_IE = 0x08,
48 OSMO_GSUP_HLR_NUMBER_IE = 0x09,
49 OSMO_GSUP_PDP_CONTEXT_ID_IE = 0x10,
50 OSMO_GSUP_PDP_TYPE_IE = 0x11,
51 OSMO_GSUP_ACCESS_POINT_NAME_IE = 0x12,
52 OSMO_GSUP_PDP_QOS_IE = 0x13,
53 OSMO_GSUP_RAND_IE = 0x20,
54 OSMO_GSUP_SRES_IE = 0x21,
55 OSMO_GSUP_KC_IE = 0x22,
56 /* 3G support */
57 OSMO_GSUP_IK_IE = 0x23,
58 OSMO_GSUP_CK_IE = 0x24,
59 OSMO_GSUP_AUTN_IE = 0x25,
60 OSMO_GSUP_AUTS_IE = 0x26,
61 OSMO_GSUP_RES_IE = 0x27,
Harald Welte48dc1a52016-05-05 18:46:42 +020062 OSMO_GSUP_CN_DOMAIN_IE = 0x28,
Harald Welte3b6fb082016-04-25 18:46:22 +020063};
64
65/*! GSUP message type */
66enum osmo_gsup_message_type {
67 OSMO_GSUP_MSGT_UPDATE_LOCATION_REQUEST = 0b00000100,
68 OSMO_GSUP_MSGT_UPDATE_LOCATION_ERROR = 0b00000101,
69 OSMO_GSUP_MSGT_UPDATE_LOCATION_RESULT = 0b00000110,
70
71 OSMO_GSUP_MSGT_SEND_AUTH_INFO_REQUEST = 0b00001000,
72 OSMO_GSUP_MSGT_SEND_AUTH_INFO_ERROR = 0b00001001,
73 OSMO_GSUP_MSGT_SEND_AUTH_INFO_RESULT = 0b00001010,
74
75 OSMO_GSUP_MSGT_PURGE_MS_REQUEST = 0b00001100,
76 OSMO_GSUP_MSGT_PURGE_MS_ERROR = 0b00001101,
77 OSMO_GSUP_MSGT_PURGE_MS_RESULT = 0b00001110,
78
79 OSMO_GSUP_MSGT_INSERT_DATA_REQUEST = 0b00010000,
80 OSMO_GSUP_MSGT_INSERT_DATA_ERROR = 0b00010001,
81 OSMO_GSUP_MSGT_INSERT_DATA_RESULT = 0b00010010,
82
83 OSMO_GSUP_MSGT_DELETE_DATA_REQUEST = 0b00010100,
84 OSMO_GSUP_MSGT_DELETE_DATA_ERROR = 0b00010101,
85 OSMO_GSUP_MSGT_DELETE_DATA_RESULT = 0b00010110,
86
87 OSMO_GSUP_MSGT_LOCATION_CANCEL_REQUEST = 0b00011100,
88 OSMO_GSUP_MSGT_LOCATION_CANCEL_ERROR = 0b00011101,
89 OSMO_GSUP_MSGT_LOCATION_CANCEL_RESULT = 0b00011110,
90};
91
92#define OSMO_GSUP_IS_MSGT_REQUEST(msgt) (((msgt) & 0b00000011) == 0b00)
93#define OSMO_GSUP_IS_MSGT_ERROR(msgt) (((msgt) & 0b00000011) == 0b01)
94#define OSMO_GSUP_TO_MSGT_ERROR(msgt) (((msgt) & 0b11111100) | 0b01)
95
96enum osmo_gsup_cancel_type {
97 OSMO_GSUP_CANCEL_TYPE_UPDATE = 1, /* on wire: 0 */
98 OSMO_GSUP_CANCEL_TYPE_WITHDRAW = 2, /* on wire: 1 */
99};
100
Harald Welte48dc1a52016-05-05 18:46:42 +0200101enum osmo_gsup_cn_domain {
102 OSMO_GSUP_CN_DOMAIN_PS = 1,
103 OSMO_GSUP_CN_DOMAIN_CS = 2,
104};
105
Harald Welte3b6fb082016-04-25 18:46:22 +0200106/*! parsed/decoded PDP context information */
107struct osmo_gsup_pdp_info {
108 unsigned int context_id;
109 int have_info;
110 /*! Type of PDP context */
111 uint16_t pdp_type;
112 /*! APN information, still in encoded form. Can be NULL if no
113 * APN information included */
114 const uint8_t *apn_enc;
115 /*! length (in octets) of apn_enc */
116 size_t apn_enc_len;
117 /*! QoS information, still in encoded form. Can be NULL if no
118 * QoS information included */
119 const uint8_t *qos_enc;
120 /*! length (in octets) of qos_enc */
121 size_t qos_enc_len;
122};
123
124/*! parsed/decoded GSUP protocol message */
125struct osmo_gsup_message {
126 enum osmo_gsup_message_type message_type;
127 char imsi[GSM23003_IMSI_MAX_DIGITS+2];
128 enum gsm48_gmm_cause cause;
129 enum osmo_gsup_cancel_type cancel_type;
130 int pdp_info_compl;
131 int freeze_ptmsi;
132 struct osmo_auth_vector auth_vectors[OSMO_GSUP_MAX_NUM_AUTH_INFO];
133 size_t num_auth_vectors;
134 struct osmo_gsup_pdp_info pdp_infos[OSMO_GSUP_MAX_NUM_PDP_INFO];
135 size_t num_pdp_infos;
136 const uint8_t *msisdn_enc;
137 size_t msisdn_enc_len;
138 const uint8_t *hlr_enc;
139 size_t hlr_enc_len;
140 const uint8_t *auts;
Harald Welte766da862016-05-06 11:18:15 +0200141 const uint8_t *rand;
Harald Welte48dc1a52016-05-05 18:46:42 +0200142 enum osmo_gsup_cn_domain cn_domain;
Harald Welte3b6fb082016-04-25 18:46:22 +0200143};
144
145int osmo_gsup_decode(const uint8_t *data, size_t data_len,
146 struct osmo_gsup_message *gsup_msg);
147void osmo_gsup_encode(struct msgb *msg, const struct osmo_gsup_message *gsup_msg);