libosmogsm  0.12.0
Osmocom GSM library
gsup.h
Go to the documentation of this file.
1 
18 /*
19  * (C) 2014 by sysmocom - s.f.m.c. GmbH, Author: Jacob Erlbeck
20  * (C) 2016 by Harald Welte <laforge@gnumonks.org>
21  * All Rights Reserved
22  *
23  * SPDX-License-Identifier: GPL-2.0+
24  *
25  * This program is free software; you can redistribute it and/or modify
26  * it under the terms of the GNU General Public License as published by
27  * the Free Software Foundation; either version 2 of the License, or
28  * (at your option) any later version.
29  *
30  * This program is distributed in the hope that it will be useful,
31  * but WITHOUT ANY WARRANTY; without even the implied warranty of
32  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
33  * GNU General Public License for more details.
34  *
35  * You should have received a copy of the GNU General Public License
36  * along with this program. If not, see <http://www.gnu.org/licenses/>.
37  *
38  */
39 #pragma once
40 
41 #include <stdint.h>
42 #include <osmocom/core/msgb.h>
45 #include <osmocom/crypt/auth.h>
46 
47 #define OSMO_GSUP_PORT 4222
48 
50 #define OSMO_GSUP_MAX_NUM_PDP_INFO 10 /* GSM 09.02 limits this to 50 */
51 
52 #define OSMO_GSUP_MAX_NUM_AUTH_INFO 5
53 
54 #define OSMO_GSUP_MAX_MSISDN_LEN 9
55 #define OSMO_GSUP_MAX_CALLED_PARTY_BCD_LEN 43 /* TS 24.008 10.5.4.7 */
56 
57 #define OSMO_GSUP_PDP_TYPE_SIZE 2
58 
78  /* 3G support */
85 
88 
91 };
92 
98 
102 
104 
108 
112 
116 
120 
124 };
125 
126 #define OSMO_GSUP_IS_MSGT_REQUEST(msgt) (((msgt) & 0b00000011) == 0b00)
127 #define OSMO_GSUP_IS_MSGT_ERROR(msgt) (((msgt) & 0b00000011) == 0b01)
128 #define OSMO_GSUP_TO_MSGT_ERROR(msgt) (((msgt) & 0b11111100) | 0b01)
129 
130 extern const struct value_string osmo_gsup_message_type_names[];
131 static inline const char *
133 { return get_value_string(osmo_gsup_message_type_names, val); }
134 
136  OSMO_GSUP_CANCEL_TYPE_UPDATE = 1, /* on wire: 0 */
137  OSMO_GSUP_CANCEL_TYPE_WITHDRAW = 2, /* on wire: 1 */
138 };
139 
143 };
144 
155 };
156 
157 extern const struct value_string osmo_gsup_session_state_names[];
158 static inline const char *
160 { return get_value_string(osmo_gsup_session_state_names, val); }
161 
164  unsigned int context_id;
167  uint16_t pdp_type;
170  const uint8_t *apn_enc;
172  size_t apn_enc_len;
175  const uint8_t *qos_enc;
177  size_t qos_enc_len;
180  const uint8_t *pdp_charg_enc;
183 };
184 
189  enum gsm48_gmm_cause cause;
197  const uint8_t *msisdn_enc;
199  const uint8_t *hlr_enc;
200  size_t hlr_enc_len;
201  const uint8_t *auts;
202  const uint8_t *rand;
204  const uint8_t *pdp_charg_enc;
206 
211  uint32_t session_id;
212 
214  uint8_t *ss_info;
215  size_t ss_info_len;
216 };
217 
218 int osmo_gsup_decode(const uint8_t *data, size_t data_len,
219  struct osmo_gsup_message *gsup_msg);
220 int osmo_gsup_encode(struct msgb *msg, const struct osmo_gsup_message *gsup_msg);
222 
OSMO_GSUP_ACCESS_POINT_NAME_IE
@ OSMO_GSUP_ACCESS_POINT_NAME_IE
Definition: gsup.h:72
osmo_gsup_pdp_info::qos_enc_len
size_t qos_enc_len
length (in octets) of qos_enc
Definition: gsup.h:177
data
uint8_t data[0]
message payload data
Definition: gsm_03_41.h:32
OSMO_GSUP_AUTH_TUPLE_IE
@ OSMO_GSUP_AUTH_TUPLE_IE
Definition: gsup.h:63
osmo_gsup_message::cancel_type
enum osmo_gsup_cancel_type cancel_type
Definition: gsup.h:190
OSMO_GSUP_MSGT_PURGE_MS_RESULT
@ OSMO_GSUP_MSGT_PURGE_MS_RESULT
Definition: gsup.h:107
OSMO_GSUP_SESSION_STATE_NONE
@ OSMO_GSUP_SESSION_STATE_NONE
Undefined session state.
Definition: gsup.h:148
osmo_gsup_message::msisdn_enc_len
size_t msisdn_enc_len
Definition: gsup.h:198
OSMO_GSUP_IMSI_IE
@ OSMO_GSUP_IMSI_IE
Definition: gsup.h:61
osmo_gsup_session_state
osmo_gsup_session_state
TCAP-like session state.
Definition: gsup.h:146
OSMO_GSUP_SESSION_STATE_BEGIN
@ OSMO_GSUP_SESSION_STATE_BEGIN
Initiation of a new session.
Definition: gsup.h:150
OSMO_GSUP_MSGT_UPDATE_LOCATION_REQUEST
@ OSMO_GSUP_MSGT_UPDATE_LOCATION_REQUEST
Definition: gsup.h:95
OSMO_GSUP_MSGT_DELETE_DATA_REQUEST
@ OSMO_GSUP_MSGT_DELETE_DATA_REQUEST
Definition: gsup.h:113
OSMO_GSUP_MSGT_UPDATE_LOCATION_ERROR
@ OSMO_GSUP_MSGT_UPDATE_LOCATION_ERROR
Definition: gsup.h:96
OSMO_GSUP_SESSION_STATE_IE
@ OSMO_GSUP_SESSION_STATE_IE
Definition: gsup.h:87
OSMO_GSUP_MSGT_SEND_AUTH_INFO_REQUEST
@ OSMO_GSUP_MSGT_SEND_AUTH_INFO_REQUEST
Definition: gsup.h:99
OSMO_GSUP_MSGT_INSERT_DATA_RESULT
@ OSMO_GSUP_MSGT_INSERT_DATA_RESULT
Definition: gsup.h:111
OSMO_GSUP_CAUSE_IE
@ OSMO_GSUP_CAUSE_IE
Definition: gsup.h:62
OSMO_GSUP_HLR_NUMBER_IE
@ OSMO_GSUP_HLR_NUMBER_IE
Definition: gsup.h:69
gsm48_gmm_cause
gsm48_gmm_cause
Definition: gsm_04_08_gprs.h:197
OSMO_GSUP_RAND_IE
@ OSMO_GSUP_RAND_IE
Definition: gsup.h:75
OSMO_GSUP_SESSION_STATE_END
@ OSMO_GSUP_SESSION_STATE_END
Indication of the session end.
Definition: gsup.h:154
osmo_gsup_pdp_info::apn_enc
const uint8_t * apn_enc
APN information, still in encoded form.
Definition: gsup.h:170
OSMO_GSUP_CN_DOMAIN_IE
@ OSMO_GSUP_CN_DOMAIN_IE
Definition: gsup.h:84
osmo_gsup_pdp_info::pdp_charg_enc
const uint8_t * pdp_charg_enc
PDP Charging Characteristics, still in encoded form.
Definition: gsup.h:180
osmo_gsup_message::auts
const uint8_t * auts
Definition: gsup.h:201
osmo_gsup_cancel_type
osmo_gsup_cancel_type
Definition: gsup.h:135
osmo_gsup_message::auth_vectors
struct osmo_auth_vector auth_vectors[OSMO_GSUP_MAX_NUM_AUTH_INFO]
Definition: gsup.h:193
OSMO_GSUP_AUTS_IE
@ OSMO_GSUP_AUTS_IE
Definition: gsup.h:82
OSMO_GSUP_MSGT_DELETE_DATA_RESULT
@ OSMO_GSUP_MSGT_DELETE_DATA_RESULT
Definition: gsup.h:115
OSMO_GSUP_SESSION_ID_IE
@ OSMO_GSUP_SESSION_ID_IE
Definition: gsup.h:86
osmo_gsup_pdp_info::qos_enc
const uint8_t * qos_enc
QoS information, still in encoded form.
Definition: gsup.h:175
osmo_gsup_cn_domain
osmo_gsup_cn_domain
Definition: gsup.h:140
osmo_gsup_message::session_state
enum osmo_gsup_session_state session_state
Session state osmo_gsup_session_state.
Definition: gsup.h:208
osmo_gsup_pdp_info::pdp_charg_enc_len
size_t pdp_charg_enc_len
length (in octets) of pdp_charg_enc
Definition: gsup.h:182
osmo_gsup_encode
int osmo_gsup_encode(struct msgb *msg, const struct osmo_gsup_message *gsup_msg)
Encode a GSUP message.
Definition: gsup.c:529
osmo_gsup_message::hlr_enc_len
size_t hlr_enc_len
Definition: gsup.h:200
osmo_gsup_message::pdp_charg_enc
const uint8_t * pdp_charg_enc
Definition: gsup.h:204
OSMO_GSUP_PDP_TYPE_IE
@ OSMO_GSUP_PDP_TYPE_IE
Definition: gsup.h:71
GSM23003_IMSI_MAX_DIGITS
#define GSM23003_IMSI_MAX_DIGITS
Definition: gsm_23_003.h:6
osmo_gsup_message::pdp_infos
struct osmo_gsup_pdp_info pdp_infos[OSMO_GSUP_MAX_NUM_PDP_INFO]
Definition: gsup.h:195
osmo_gsup_pdp_info
parsed/decoded PDP context information
Definition: gsup.h:163
OSMO_GSUP_SRES_IE
@ OSMO_GSUP_SRES_IE
Definition: gsup.h:76
osmo_gsup_pdp_info::apn_enc_len
size_t apn_enc_len
length (in octets) of apn_enc
Definition: gsup.h:172
osmo_gsup_message_type
osmo_gsup_message_type
GSUP message type.
Definition: gsup.h:94
OSMO_GSUP_MSGT_LOCATION_CANCEL_ERROR
@ OSMO_GSUP_MSGT_LOCATION_CANCEL_ERROR
Definition: gsup.h:118
osmo_gsup_message::rand
const uint8_t * rand
Definition: gsup.h:202
OSMO_GSUP_MSGT_PROC_SS_REQUEST
@ OSMO_GSUP_MSGT_PROC_SS_REQUEST
Definition: gsup.h:121
OSMO_GSUP_MSGT_DELETE_DATA_ERROR
@ OSMO_GSUP_MSGT_DELETE_DATA_ERROR
Definition: gsup.h:114
osmo_auth_vector
Definition: auth.h:60
OSMO_GSUP_MSGT_SEND_AUTH_INFO_ERROR
@ OSMO_GSUP_MSGT_SEND_AUTH_INFO_ERROR
Definition: gsup.h:100
OSMO_GSUP_MSGT_PURGE_MS_REQUEST
@ OSMO_GSUP_MSGT_PURGE_MS_REQUEST
Definition: gsup.h:105
osmo_gsup_message::hlr_enc
const uint8_t * hlr_enc
Definition: gsup.h:199
osmo_gsup_message::ss_info
uint8_t * ss_info
ASN.1 encoded MAP payload for Supplementary Services.
Definition: gsup.h:214
OSMO_GSUP_MSGT_SEND_AUTH_INFO_RESULT
@ OSMO_GSUP_MSGT_SEND_AUTH_INFO_RESULT
Definition: gsup.h:101
OSMO_GSUP_CHARG_CHAR_IE
@ OSMO_GSUP_CHARG_CHAR_IE
Definition: gsup.h:74
OSMO_GSUP_PDP_CONTEXT_ID_IE
@ OSMO_GSUP_PDP_CONTEXT_ID_IE
Definition: gsup.h:70
OSMO_GSUP_MSGT_AUTH_FAIL_REPORT
@ OSMO_GSUP_MSGT_AUTH_FAIL_REPORT
Definition: gsup.h:103
OSMO_GSUP_CANCEL_TYPE_IE
@ OSMO_GSUP_CANCEL_TYPE_IE
Definition: gsup.h:66
osmo_gsup_iei
osmo_gsup_iei
Information Element Identifiers for GSUP IEs.
Definition: gsup.h:60
OSMO_GSUP_PDP_INFO_COMPL_IE
@ OSMO_GSUP_PDP_INFO_COMPL_IE
Definition: gsup.h:64
osmo_gsup_message
parsed/decoded GSUP protocol message
Definition: gsup.h:186
osmo_gsup_message::cn_domain
enum osmo_gsup_cn_domain cn_domain
Definition: gsup.h:203
OSMO_GSUP_MSGT_UPDATE_LOCATION_RESULT
@ OSMO_GSUP_MSGT_UPDATE_LOCATION_RESULT
Definition: gsup.h:97
OSMO_GSUP_CANCEL_TYPE_WITHDRAW
@ OSMO_GSUP_CANCEL_TYPE_WITHDRAW
Definition: gsup.h:137
OSMO_GSUP_CN_DOMAIN_PS
@ OSMO_GSUP_CN_DOMAIN_PS
Definition: gsup.h:141
osmo_gsup_session_state_name
static const char * osmo_gsup_session_state_name(enum osmo_gsup_session_state val)
Definition: gsup.h:159
OSMO_GSUP_MSGT_INSERT_DATA_REQUEST
@ OSMO_GSUP_MSGT_INSERT_DATA_REQUEST
Definition: gsup.h:109
OSMO_GSUP_MAX_NUM_PDP_INFO
#define OSMO_GSUP_MAX_NUM_PDP_INFO
Maximum nubmer of PDP inside osmo_gsup_message.
Definition: gsup.h:50
OSMO_GSUP_MSISDN_IE
@ OSMO_GSUP_MSISDN_IE
Definition: gsup.h:68
OSMO_GSUP_PDP_INFO_IE
@ OSMO_GSUP_PDP_INFO_IE
Definition: gsup.h:65
OSMO_GSUP_FREEZE_PTMSI_IE
@ OSMO_GSUP_FREEZE_PTMSI_IE
Definition: gsup.h:67
OSMO_GSUP_MAX_NUM_AUTH_INFO
#define OSMO_GSUP_MAX_NUM_AUTH_INFO
Maximum number of auth info inside osmo_gsup_message.
Definition: gsup.h:52
osmo_gsup_get_err_msg_type
int osmo_gsup_get_err_msg_type(enum osmo_gsup_message_type type_in)
return the error message type corresponding to type_in
Definition: gsup.c:84
OSMO_GSUP_SS_INFO_IE
@ OSMO_GSUP_SS_INFO_IE
Supplementary Services payload.
Definition: gsup.h:90
osmo_gsup_session_state_names
const struct value_string osmo_gsup_session_state_names[]
Definition: gsup.c:73
osmo_gsup_message::cause
enum gsm48_gmm_cause cause
Definition: gsup.h:189
osmo_gsup_message::num_auth_vectors
size_t num_auth_vectors
Definition: gsup.h:194
osmo_gsup_pdp_info::pdp_type
uint16_t pdp_type
Type of PDP context.
Definition: gsup.h:167
OSMO_GSUP_MSGT_LOCATION_CANCEL_REQUEST
@ OSMO_GSUP_MSGT_LOCATION_CANCEL_REQUEST
Definition: gsup.h:117
OSMO_GSUP_CK_IE
@ OSMO_GSUP_CK_IE
Definition: gsup.h:80
OSMO_GSUP_MSGT_PROC_SS_RESULT
@ OSMO_GSUP_MSGT_PROC_SS_RESULT
Definition: gsup.h:123
gsm_23_003.h
OSMO_GSUP_MSGT_PURGE_MS_ERROR
@ OSMO_GSUP_MSGT_PURGE_MS_ERROR
Definition: gsup.h:106
gsm_04_08_gprs.h
osmo_gsup_message::message_type
enum osmo_gsup_message_type message_type
Definition: gsup.h:187
osmo_gsup_message::num_pdp_infos
size_t num_pdp_infos
Definition: gsup.h:196
osmo_gsup_pdp_info::have_info
int have_info
Definition: gsup.h:165
OSMO_GSUP_IK_IE
@ OSMO_GSUP_IK_IE
Definition: gsup.h:79
auth.h
osmo_gsup_message_type_names
const struct value_string osmo_gsup_message_type_names[]
Definition: gsup.c:39
osmo_gsup_decode
int osmo_gsup_decode(const uint8_t *data, size_t data_len, struct osmo_gsup_message *gsup_msg)
Decode (parse) a GSUP message.
Definition: gsup.c:255
osmo_gsup_message::ss_info_len
size_t ss_info_len
Definition: gsup.h:215
osmo_gsup_message::imsi
char imsi[GSM23003_IMSI_MAX_DIGITS+2]
Definition: gsup.h:188
OSMO_GSUP_MSGT_LOCATION_CANCEL_RESULT
@ OSMO_GSUP_MSGT_LOCATION_CANCEL_RESULT
Definition: gsup.h:119
osmo_gsup_pdp_info::context_id
unsigned int context_id
Definition: gsup.h:164
OSMO_GSUP_RES_IE
@ OSMO_GSUP_RES_IE
Definition: gsup.h:83
osmo_gsup_message_type_name
static const char * osmo_gsup_message_type_name(enum osmo_gsup_message_type val)
Definition: gsup.h:132
OSMO_GSUP_CANCEL_TYPE_UPDATE
@ OSMO_GSUP_CANCEL_TYPE_UPDATE
Definition: gsup.h:136
osmo_gsup_message::pdp_charg_enc_len
size_t pdp_charg_enc_len
Definition: gsup.h:205
osmo_gsup_message::pdp_info_compl
int pdp_info_compl
Definition: gsup.h:191
OSMO_GSUP_PDP_QOS_IE
@ OSMO_GSUP_PDP_QOS_IE
Definition: gsup.h:73
osmo_gsup_message::msisdn_enc
const uint8_t * msisdn_enc
Definition: gsup.h:197
OSMO_GSUP_CN_DOMAIN_CS
@ OSMO_GSUP_CN_DOMAIN_CS
Definition: gsup.h:142
osmo_gsup_message::freeze_ptmsi
int freeze_ptmsi
Definition: gsup.h:192
OSMO_GSUP_MSGT_PROC_SS_ERROR
@ OSMO_GSUP_MSGT_PROC_SS_ERROR
Definition: gsup.h:122
OSMO_GSUP_KC_IE
@ OSMO_GSUP_KC_IE
Definition: gsup.h:77
OSMO_GSUP_MSGT_INSERT_DATA_ERROR
@ OSMO_GSUP_MSGT_INSERT_DATA_ERROR
Definition: gsup.h:110
osmo_gsup_message::session_id
uint32_t session_id
Unique session identifier and origination flag.
Definition: gsup.h:211
OSMO_GSUP_SESSION_STATE_CONTINUE
@ OSMO_GSUP_SESSION_STATE_CONTINUE
Communication of an existing session.
Definition: gsup.h:152
OSMO_GSUP_AUTN_IE
@ OSMO_GSUP_AUTN_IE
Definition: gsup.h:81