blob: 8daf4602eeaa6279433285956a1e3e85160b8a5a [file] [log] [blame]
Harald Welte381a1aa2017-10-16 18:31:20 +02001/*! \defgroup gsup Generic Subscriber Update Protocol
2 * @{
3 *
4 * The Generic Subscriber Update Protocol (GSUP) is an Osmocom-specific
5 * non-standard protocol replacing MAP as the protocol between
6 * MSC/VLR/SGSN and HLR in a 3GPP cellular communications network.
7 *
8 * It was designed around the same transactions and architecture as the
9 * MAP messages/operations, but without the complexity of TCAP and MAP,
10 * and without the need for ASN.1 encoding.
11 *
12 * The purpose is to keep protocol complexity out of OsmoSGSN and
13 * OsmoMSC, while providing a clean path to an external GSUP to MAP
14 * translator.
15 *
16 * \file gsup.h
17 * Osmocom Generic Subscriber Update Protocol message encoder/decoder. */
Neels Hofmeyr17518fe2017-06-20 04:35:06 +020018/*
19 * (C) 2014 by sysmocom s.f.m.c. GmbH, Author: Jacob Erlbeck
Harald Welte3b6fb082016-04-25 18:46:22 +020020 * (C) 2016 by Harald Welte <laforge@gnumonks.org>
21 * All Rights Reserved
22 *
23 * This program is free software; you can redistribute it and/or modify
24 * it under the terms of the GNU General Public License as published by
25 * the Free Software Foundation; either version 2 of the License, or
26 * (at your option) any later version.
27 *
28 * This program is distributed in the hope that it will be useful,
29 * but WITHOUT ANY WARRANTY; without even the implied warranty of
30 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
31 * GNU General Public License for more details.
32 *
33 * You should have received a copy of the GNU General Public License
34 * along with this program. If not, see <http://www.gnu.org/licenses/>.
35 *
36 */
37#pragma once
38
39#include <stdint.h>
40#include <osmocom/core/msgb.h>
41#include <osmocom/gsm/protocol/gsm_23_003.h>
42#include <osmocom/gsm/protocol/gsm_04_08_gprs.h>
43#include <osmocom/crypt/auth.h>
44
Neels Hofmeyrb970e102017-07-21 15:55:28 +020045#define OSMO_GSUP_PORT 4222
46
Harald Welte3b6fb082016-04-25 18:46:22 +020047/*! Maximum nubmer of PDP inside \ref osmo_gsup_message */
48#define OSMO_GSUP_MAX_NUM_PDP_INFO 10 /* GSM 09.02 limits this to 50 */
49/*! Maximum number of auth info inside \ref osmo_gsup_message */
50#define OSMO_GSUP_MAX_NUM_AUTH_INFO 5
51/*! Maximum number of octets encoding MSISDN in BCD format */
52#define OSMO_GSUP_MAX_MSISDN_LEN 9
53
54#define OSMO_GSUP_PDP_TYPE_SIZE 2
55
56/*! Information Element Identifiers for GSUP IEs */
57enum osmo_gsup_iei {
58 OSMO_GSUP_IMSI_IE = 0x01,
59 OSMO_GSUP_CAUSE_IE = 0x02,
60 OSMO_GSUP_AUTH_TUPLE_IE = 0x03,
61 OSMO_GSUP_PDP_INFO_COMPL_IE = 0x04,
62 OSMO_GSUP_PDP_INFO_IE = 0x05,
63 OSMO_GSUP_CANCEL_TYPE_IE = 0x06,
64 OSMO_GSUP_FREEZE_PTMSI_IE = 0x07,
65 OSMO_GSUP_MSISDN_IE = 0x08,
66 OSMO_GSUP_HLR_NUMBER_IE = 0x09,
67 OSMO_GSUP_PDP_CONTEXT_ID_IE = 0x10,
68 OSMO_GSUP_PDP_TYPE_IE = 0x11,
69 OSMO_GSUP_ACCESS_POINT_NAME_IE = 0x12,
70 OSMO_GSUP_PDP_QOS_IE = 0x13,
Holger Hans Peter Freythereb55c0d2017-07-07 16:53:30 +020071 OSMO_GSUP_CHARG_CHAR_IE = 0x14,
Harald Welte3b6fb082016-04-25 18:46:22 +020072 OSMO_GSUP_RAND_IE = 0x20,
73 OSMO_GSUP_SRES_IE = 0x21,
74 OSMO_GSUP_KC_IE = 0x22,
75 /* 3G support */
76 OSMO_GSUP_IK_IE = 0x23,
77 OSMO_GSUP_CK_IE = 0x24,
78 OSMO_GSUP_AUTN_IE = 0x25,
79 OSMO_GSUP_AUTS_IE = 0x26,
80 OSMO_GSUP_RES_IE = 0x27,
Harald Welte48dc1a52016-05-05 18:46:42 +020081 OSMO_GSUP_CN_DOMAIN_IE = 0x28,
Harald Welte3b6fb082016-04-25 18:46:22 +020082};
83
84/*! GSUP message type */
85enum osmo_gsup_message_type {
86 OSMO_GSUP_MSGT_UPDATE_LOCATION_REQUEST = 0b00000100,
87 OSMO_GSUP_MSGT_UPDATE_LOCATION_ERROR = 0b00000101,
88 OSMO_GSUP_MSGT_UPDATE_LOCATION_RESULT = 0b00000110,
89
90 OSMO_GSUP_MSGT_SEND_AUTH_INFO_REQUEST = 0b00001000,
91 OSMO_GSUP_MSGT_SEND_AUTH_INFO_ERROR = 0b00001001,
92 OSMO_GSUP_MSGT_SEND_AUTH_INFO_RESULT = 0b00001010,
93
Harald Weltede960cb2016-06-16 22:57:09 +020094 OSMO_GSUP_MSGT_AUTH_FAIL_REPORT = 0b00001011,
95
Harald Welte3b6fb082016-04-25 18:46:22 +020096 OSMO_GSUP_MSGT_PURGE_MS_REQUEST = 0b00001100,
97 OSMO_GSUP_MSGT_PURGE_MS_ERROR = 0b00001101,
98 OSMO_GSUP_MSGT_PURGE_MS_RESULT = 0b00001110,
99
100 OSMO_GSUP_MSGT_INSERT_DATA_REQUEST = 0b00010000,
101 OSMO_GSUP_MSGT_INSERT_DATA_ERROR = 0b00010001,
102 OSMO_GSUP_MSGT_INSERT_DATA_RESULT = 0b00010010,
103
104 OSMO_GSUP_MSGT_DELETE_DATA_REQUEST = 0b00010100,
105 OSMO_GSUP_MSGT_DELETE_DATA_ERROR = 0b00010101,
106 OSMO_GSUP_MSGT_DELETE_DATA_RESULT = 0b00010110,
107
108 OSMO_GSUP_MSGT_LOCATION_CANCEL_REQUEST = 0b00011100,
109 OSMO_GSUP_MSGT_LOCATION_CANCEL_ERROR = 0b00011101,
110 OSMO_GSUP_MSGT_LOCATION_CANCEL_RESULT = 0b00011110,
111};
112
113#define OSMO_GSUP_IS_MSGT_REQUEST(msgt) (((msgt) & 0b00000011) == 0b00)
114#define OSMO_GSUP_IS_MSGT_ERROR(msgt) (((msgt) & 0b00000011) == 0b01)
115#define OSMO_GSUP_TO_MSGT_ERROR(msgt) (((msgt) & 0b11111100) | 0b01)
116
Neels Hofmeyr10f5fb42017-02-09 02:09:09 +0100117extern const struct value_string osmo_gsup_message_type_names[];
118static inline const char *
119osmo_gsup_message_type_name(enum osmo_gsup_message_type val)
120{ return get_value_string(osmo_gsup_message_type_names, val); }
121
Harald Welte3b6fb082016-04-25 18:46:22 +0200122enum osmo_gsup_cancel_type {
123 OSMO_GSUP_CANCEL_TYPE_UPDATE = 1, /* on wire: 0 */
124 OSMO_GSUP_CANCEL_TYPE_WITHDRAW = 2, /* on wire: 1 */
125};
126
Harald Welte48dc1a52016-05-05 18:46:42 +0200127enum osmo_gsup_cn_domain {
128 OSMO_GSUP_CN_DOMAIN_PS = 1,
129 OSMO_GSUP_CN_DOMAIN_CS = 2,
130};
131
Harald Welte3b6fb082016-04-25 18:46:22 +0200132/*! parsed/decoded PDP context information */
133struct osmo_gsup_pdp_info {
134 unsigned int context_id;
135 int have_info;
136 /*! Type of PDP context */
137 uint16_t pdp_type;
138 /*! APN information, still in encoded form. Can be NULL if no
139 * APN information included */
140 const uint8_t *apn_enc;
141 /*! length (in octets) of apn_enc */
142 size_t apn_enc_len;
143 /*! QoS information, still in encoded form. Can be NULL if no
144 * QoS information included */
145 const uint8_t *qos_enc;
146 /*! length (in octets) of qos_enc */
147 size_t qos_enc_len;
Holger Hans Peter Freythereb55c0d2017-07-07 16:53:30 +0200148 /*! PDP Charging Characteristics, still in encoded form. Can be NULL if no
149 * PDP Charging Characteristics */
150 const uint8_t *pdp_charg_enc;
151 /*! length (in octets) of pdp_charg_enc */
152 size_t pdp_charg_enc_len;
Harald Welte3b6fb082016-04-25 18:46:22 +0200153};
154
155/*! parsed/decoded GSUP protocol message */
156struct osmo_gsup_message {
157 enum osmo_gsup_message_type message_type;
158 char imsi[GSM23003_IMSI_MAX_DIGITS+2];
159 enum gsm48_gmm_cause cause;
160 enum osmo_gsup_cancel_type cancel_type;
161 int pdp_info_compl;
162 int freeze_ptmsi;
163 struct osmo_auth_vector auth_vectors[OSMO_GSUP_MAX_NUM_AUTH_INFO];
164 size_t num_auth_vectors;
165 struct osmo_gsup_pdp_info pdp_infos[OSMO_GSUP_MAX_NUM_PDP_INFO];
166 size_t num_pdp_infos;
167 const uint8_t *msisdn_enc;
168 size_t msisdn_enc_len;
169 const uint8_t *hlr_enc;
170 size_t hlr_enc_len;
171 const uint8_t *auts;
Harald Welte766da862016-05-06 11:18:15 +0200172 const uint8_t *rand;
Harald Welte48dc1a52016-05-05 18:46:42 +0200173 enum osmo_gsup_cn_domain cn_domain;
Holger Hans Peter Freythereb55c0d2017-07-07 16:53:30 +0200174 const uint8_t *pdp_charg_enc;
175 size_t pdp_charg_enc_len;
Harald Welte3b6fb082016-04-25 18:46:22 +0200176};
177
178int osmo_gsup_decode(const uint8_t *data, size_t data_len,
179 struct osmo_gsup_message *gsup_msg);
180void osmo_gsup_encode(struct msgb *msg, const struct osmo_gsup_message *gsup_msg);
Harald Welte381a1aa2017-10-16 18:31:20 +0200181
182/*! @} */