blob: 0494df0ed6e23f30dedf344cc784bcbde03c849c [file] [log] [blame]
Harald Welteb77c6972010-05-01 11:28:43 +02001#ifndef _GB_PROXY_H
2#define _GB_PROXY_H
3
Harald Welteb77c6972010-05-01 11:28:43 +02004
Pablo Neira Ayuso136f4532011-03-22 16:47:59 +01005#include <osmocom/core/msgb.h>
Harald Welteb77c6972010-05-01 11:28:43 +02006
Harald Welteea34a4e2012-06-16 14:59:56 +08007#include <osmocom/gprs/gprs_ns.h>
Harald Welte4b037e42010-05-19 19:45:32 +02008#include <osmocom/vty/command.h>
Harald Welteb77c6972010-05-01 11:28:43 +02009
Holger Hans Peter Freyther3fa26442014-08-04 16:27:11 +020010#include <sys/types.h>
11#include <regex.h>
12
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +020013struct rate_ctr_group;
Jacob Erlbeck9114bee2014-08-19 12:21:01 +020014struct gprs_gb_parse_context;
Jacob Erlbeck5f1faa32014-08-21 10:01:30 +020015struct tlv_parsed;
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +020016
Jacob Erlbeck9114bee2014-08-19 12:21:01 +020017enum gbproxy_global_ctr {
18 GBPROX_GLOB_CTR_INV_BVCI,
19 GBPROX_GLOB_CTR_INV_LAI,
20 GBPROX_GLOB_CTR_INV_RAI,
21 GBPROX_GLOB_CTR_INV_NSEI,
22 GBPROX_GLOB_CTR_PROTO_ERR_BSS,
23 GBPROX_GLOB_CTR_PROTO_ERR_SGSN,
24 GBPROX_GLOB_CTR_NOT_SUPPORTED_BSS,
25 GBPROX_GLOB_CTR_NOT_SUPPORTED_SGSN,
26 GBPROX_GLOB_CTR_RESTART_RESET_SGSN,
27 GBPROX_GLOB_CTR_TX_ERR_SGSN,
28 GBPROX_GLOB_CTR_OTHER_ERR,
29 GBPROX_GLOB_CTR_PATCH_PEER_ERR,
30};
31
32enum gbproxy_peer_ctr {
33 GBPROX_PEER_CTR_BLOCKED,
34 GBPROX_PEER_CTR_UNBLOCKED,
35 GBPROX_PEER_CTR_DROPPED,
36 GBPROX_PEER_CTR_INV_NSEI,
37 GBPROX_PEER_CTR_TX_ERR,
38 GBPROX_PEER_CTR_RAID_PATCHED_BSS,
39 GBPROX_PEER_CTR_RAID_PATCHED_SGSN,
40 GBPROX_PEER_CTR_APN_PATCHED,
41 GBPROX_PEER_CTR_TLLI_PATCHED_BSS,
42 GBPROX_PEER_CTR_TLLI_PATCHED_SGSN,
43 GBPROX_PEER_CTR_PTMSI_PATCHED_BSS,
44 GBPROX_PEER_CTR_PTMSI_PATCHED_SGSN,
45 GBPROX_PEER_CTR_PATCH_CRYPT_ERR,
46 GBPROX_PEER_CTR_PATCH_ERR,
47 GBPROX_PEER_CTR_ATTACH_REQS,
48 GBPROX_PEER_CTR_ATTACH_REJS,
49 GBPROX_PEER_CTR_TLLI_UNKNOWN,
50 GBPROX_PEER_CTR_TLLI_CACHE_SIZE,
51};
52
Jacob Erlbeck7430da62014-09-12 15:09:56 +020053enum gbproxy_keep_mode {
54 GBPROX_KEEP_NEVER,
55 GBPROX_KEEP_REATTACH,
56 GBPROX_KEEP_IDENTIFIED,
57 GBPROX_KEEP_ALWAYS,
58};
59
Harald Welteb77c6972010-05-01 11:28:43 +020060struct gbproxy_config {
61 /* parsed from config file */
Holger Hans Peter Freytherc42ad8b2011-04-18 17:04:00 +020062 uint16_t nsip_sgsn_nsei;
Harald Welteb77c6972010-05-01 11:28:43 +020063
64 /* misc */
65 struct gprs_ns_inst *nsi;
Jacob Erlbeck67a44452014-05-19 10:14:58 +020066
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +020067 /* Linked list of all Gb peers (except SGSN) */
68 struct llist_head bts_peers;
69
Holger Hans Peter Freythera7027a02014-08-04 11:19:56 +020070 /* Counter */
71 struct rate_ctr_group *ctrg;
72
Jacob Erlbeck67a44452014-05-19 10:14:58 +020073 /* force mcc/mnc */
74 int core_mnc;
75 int core_mcc;
Jacob Erlbeck73685282014-05-23 20:48:07 +020076 uint8_t* core_apn;
77 size_t core_apn_size;
Jacob Erlbeck7c101d92014-06-06 18:49:23 +020078 char * match_re;
Jacob Erlbeck7c101d92014-06-06 18:49:23 +020079 int tlli_max_age;
80 int tlli_max_len;
Jacob Erlbeck5f4ef322014-08-22 17:10:01 +020081
82 /* Experimental config */
Jacob Erlbeck9057bc32014-08-12 16:30:30 +020083 int patch_ptmsi;
Jacob Erlbeck5f4ef322014-08-22 17:10:01 +020084 int acquire_imsi;
Jacob Erlbeckf4d60c82014-08-26 14:47:15 +020085 int route_to_sgsn2;
86 uint16_t nsip_sgsn2_nsei;
Jacob Erlbeck7430da62014-09-12 15:09:56 +020087 enum gbproxy_keep_mode keep_tlli_infos;
Holger Hans Peter Freyther3fa26442014-08-04 16:27:11 +020088
89 /* IMSI checking/matching */
90 int check_imsi;
91 regex_t imsi_re_comp;
Jacob Erlbeck0d376712014-08-11 19:12:24 +020092
93 /* Used to generate identifiers */
94 unsigned bss_ptmsi_state;
95 unsigned sgsn_tlli_state;
Harald Welteb77c6972010-05-01 11:28:43 +020096};
97
Holger Hans Peter Freyther1ddd9e52014-08-04 11:35:32 +020098struct gbproxy_patch_state {
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +020099 int local_mnc;
100 int local_mcc;
101
102 /* List of TLLIs for which patching is enabled */
103 struct llist_head enabled_tllis;
104 int enabled_tllis_count;
105};
106
Holger Hans Peter Freyther1ddd9e52014-08-04 11:35:32 +0200107struct gbproxy_peer {
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +0200108 struct llist_head list;
109
Holger Hans Peter Freythereece6272014-08-04 15:42:36 +0200110 /* point back to the config */
111 struct gbproxy_config *cfg;
112
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +0200113 /* NSEI of the peer entity */
114 uint16_t nsei;
115
116 /* BVCI used for Point-to-Point to this peer */
117 uint16_t bvci;
118 int blocked;
119
120 /* Routeing Area that this peer is part of (raw 04.08 encoding) */
121 uint8_t ra[6];
122
123 /* Counter */
124 struct rate_ctr_group *ctrg;
125
Holger Hans Peter Freyther1ddd9e52014-08-04 11:35:32 +0200126 struct gbproxy_patch_state patch_state;
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +0200127};
128
Jacob Erlbeck9057bc32014-08-12 16:30:30 +0200129struct gbproxy_tlli_state {
130 uint32_t current;
131 uint32_t assigned;
132 int bss_validated;
133 int net_validated;
134
135 uint32_t ptmsi;
136};
137
Holger Hans Peter Freyther1ddd9e52014-08-04 11:35:32 +0200138struct gbproxy_tlli_info {
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +0200139 struct llist_head list;
140
Jacob Erlbeck9057bc32014-08-12 16:30:30 +0200141 struct gbproxy_tlli_state tlli;
142 struct gbproxy_tlli_state sgsn_tlli;
Jacob Erlbeck91a0e862014-09-17 10:56:38 +0200143 uint32_t sgsn_nsei;
Jacob Erlbeck9057bc32014-08-12 16:30:30 +0200144
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +0200145 time_t timestamp;
Jacob Erlbeck2fd1ba42014-09-11 14:57:03 +0200146 uint8_t *imsi;
147 size_t imsi_len;
Jacob Erlbeck89d3d342014-08-06 18:55:15 +0200148
Jacob Erlbeck5f4ef322014-08-22 17:10:01 +0200149 int imsi_acq_pending;
150 struct llist_head stored_msgs;
Jacob Erlbeck31591142014-09-03 11:59:48 +0200151 int imsi_acq_retries;
Jacob Erlbeck9057bc32014-08-12 16:30:30 +0200152
Jacob Erlbeck7430da62014-09-12 15:09:56 +0200153 int is_deregistered;
154
Jacob Erlbeck8992f302014-09-19 13:17:55 +0200155 int imsi_matches;
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +0200156};
157
158
Harald Welteb77c6972010-05-01 11:28:43 +0200159/* gb_proxy_vty .c */
160
161int gbproxy_vty_init(void);
162int gbproxy_parse_config(const char *config_file, struct gbproxy_config *cfg);
163
164
165/* gb_proxy.c */
Holger Hans Peter Freyther18739ea2014-08-04 11:10:09 +0200166int gbproxy_init_config(struct gbproxy_config *cfg);
Harald Welteb77c6972010-05-01 11:28:43 +0200167
168/* Main input function for Gb proxy */
Holger Hans Peter Freythereece6272014-08-04 15:42:36 +0200169int gbprox_rcvmsg(struct gbproxy_config *cfg, struct msgb *msg, uint16_t nsei, uint16_t ns_bvci, uint16_t nsvci);
Harald Welteb77c6972010-05-01 11:28:43 +0200170
Harald Weltec1c1dd22010-05-11 06:34:24 +0200171int gbprox_signal(unsigned int subsys, unsigned int signal,
172 void *handler_data, void *signal_data);
Harald Welte1ccbf442010-05-14 11:53:08 +0000173
174/* Reset all persistent NS-VC's */
175int gbprox_reset_persistent_nsvcs(struct gprs_ns_inst *nsi);
176
Holger Hans Peter Freythereece6272014-08-04 15:42:36 +0200177void gbprox_reset(struct gbproxy_config *cfg);
Jacob Erlbeck73685282014-05-23 20:48:07 +0200178
Jacob Erlbeck9a7b0d52014-09-19 13:30:14 +0200179/* TLLI info handling */
180void gbproxy_delete_tlli_infos(struct gbproxy_peer *peer);
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200181struct gbproxy_tlli_info *gbproxy_update_tlli_state_ul(
182 struct gbproxy_peer *peer, time_t now,
183 struct gprs_gb_parse_context *parse_ctx);
184struct gbproxy_tlli_info *gbproxy_update_tlli_state_dl(
185 struct gbproxy_peer *peer, time_t now,
186 struct gprs_gb_parse_context *parse_ctx);
187void gbproxy_update_tlli_state_after(
188 struct gbproxy_peer *peer, struct gbproxy_tlli_info *tlli_info,
189 time_t now, struct gprs_gb_parse_context *parse_ctx);
Jacob Erlbeck9a7b0d52014-09-19 13:30:14 +0200190int gbproxy_remove_stale_tlli_infos(struct gbproxy_peer *peer, time_t now);
191void gbproxy_delete_tlli_info(struct gbproxy_peer *peer,
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200192 struct gbproxy_tlli_info *tlli_info);
Jacob Erlbeck31591142014-09-03 11:59:48 +0200193void gbproxy_tlli_info_discard_messages(struct gbproxy_tlli_info *tlli_info);
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200194
Jacob Erlbecka42fe9f2014-09-12 14:15:02 +0200195void gbproxy_attach_tlli_info(struct gbproxy_peer *peer, time_t now,
196 struct gbproxy_tlli_info *tlli_info);
197void gbproxy_update_tlli_info(struct gbproxy_tlli_info *tlli_info,
198 const uint8_t *imsi, size_t imsi_len);
199void gbproxy_detach_tlli_info(struct gbproxy_peer *peer,
200 struct gbproxy_tlli_info *tlli_info);
201struct gbproxy_tlli_info *gbproxy_tlli_info_alloc( struct gbproxy_peer *peer);
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200202
Jacob Erlbeck9a7b0d52014-09-19 13:30:14 +0200203struct gbproxy_tlli_info *gbproxy_tlli_info_by_tlli(
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200204 struct gbproxy_peer *peer, uint32_t tlli);
Jacob Erlbeck9a7b0d52014-09-19 13:30:14 +0200205struct gbproxy_tlli_info *gbproxy_tlli_info_by_imsi(
Jacob Erlbeck2fd1ba42014-09-11 14:57:03 +0200206 struct gbproxy_peer *peer, const uint8_t *imsi, size_t imsi_len);
Jacob Erlbeck9a7b0d52014-09-19 13:30:14 +0200207struct gbproxy_tlli_info *gbproxy_tlli_info_by_any_sgsn_tlli(
Jacob Erlbeck91a0e862014-09-17 10:56:38 +0200208 struct gbproxy_peer *peer, uint32_t tlli);
Jacob Erlbeck9a7b0d52014-09-19 13:30:14 +0200209struct gbproxy_tlli_info *gbproxy_tlli_info_by_sgsn_tlli(
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200210 struct gbproxy_peer *peer,
Jacob Erlbeck91a0e862014-09-17 10:56:38 +0200211 uint32_t tlli, uint32_t sgsn_nsei);
Jacob Erlbeck9a7b0d52014-09-19 13:30:14 +0200212struct gbproxy_tlli_info *gbproxy_tlli_info_by_ptmsi(
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200213 struct gbproxy_peer *peer,
214 uint32_t ptmsi);
215
Jacob Erlbeck9a7b0d52014-09-19 13:30:14 +0200216int gbproxy_imsi_matches(
217 struct gbproxy_peer *peer,
218 struct gbproxy_tlli_info *tlli_info);
219uint32_t gbproxy_map_tlli(
220 uint32_t other_tlli, struct gbproxy_tlli_info *tlli_info, int to_bss);
221
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200222/* needed by gb_proxy_tlli.h */
223uint32_t gbproxy_make_bss_ptmsi(struct gbproxy_peer *peer, uint32_t sgsn_ptmsi);
224uint32_t gbproxy_make_sgsn_tlli(
225 struct gbproxy_peer *peer, struct gbproxy_tlli_info *tlli_info,
226 uint32_t bss_tlli);
227int gbproxy_check_imsi(
228 struct gbproxy_peer *peer, const uint8_t *imsi, size_t imsi_len);
229
230/* Message patching */
231void gbproxy_patch_bssgp(
232 struct msgb *msg, uint8_t *bssgp, size_t bssgp_len,
233 struct gbproxy_peer *peer, struct gbproxy_tlli_info *tlli_info,
Jacob Erlbeck48bb3a32014-09-01 11:55:11 +0200234 int *len_change, struct gprs_gb_parse_context *parse_ctx);
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200235
236int gbproxy_patch_llc(
237 struct msgb *msg, uint8_t *llc, size_t llc_len,
238 struct gbproxy_peer *peer, struct gbproxy_tlli_info *tlli_info,
Jacob Erlbeck48bb3a32014-09-01 11:55:11 +0200239 int *len_change, struct gprs_gb_parse_context *parse_ctx);
Jacob Erlbeck9114bee2014-08-19 12:21:01 +0200240
241int gbproxy_set_patch_filter(
242 struct gbproxy_config *cfg, const char *filter, const char **err_msg);
243void gbproxy_clear_patch_filter(struct gbproxy_config *cfg);
244int gbproxy_check_imsi(
245 struct gbproxy_peer *peer, const uint8_t *imsi, size_t imsi_len);
246
Jacob Erlbeck5f1faa32014-08-21 10:01:30 +0200247/* Peer handling */
248struct gbproxy_peer *gbproxy_peer_by_bvci(
Jacob Erlbeck48bb3a32014-09-01 11:55:11 +0200249 struct gbproxy_config *cfg, uint16_t bvci);
Jacob Erlbeck5f1faa32014-08-21 10:01:30 +0200250struct gbproxy_peer *gbproxy_peer_by_nsei(
Jacob Erlbeck48bb3a32014-09-01 11:55:11 +0200251 struct gbproxy_config *cfg, uint16_t nsei);
Jacob Erlbeck5f1faa32014-08-21 10:01:30 +0200252struct gbproxy_peer *gbproxy_peer_by_rai(
Jacob Erlbeck48bb3a32014-09-01 11:55:11 +0200253 struct gbproxy_config *cfg, const uint8_t *ra);
Jacob Erlbeck5f1faa32014-08-21 10:01:30 +0200254struct gbproxy_peer *gbproxy_peer_by_lai(
Jacob Erlbeck48bb3a32014-09-01 11:55:11 +0200255 struct gbproxy_config *cfg, const uint8_t *la);
Jacob Erlbeck7fb26c22014-09-04 11:08:50 +0200256struct gbproxy_peer *gbproxy_peer_by_lac(
257 struct gbproxy_config *cfg, const uint8_t *la);
Jacob Erlbeck5f1faa32014-08-21 10:01:30 +0200258struct gbproxy_peer *gbproxy_peer_by_bssgp_tlv(
Jacob Erlbeck48bb3a32014-09-01 11:55:11 +0200259 struct gbproxy_config *cfg, struct tlv_parsed *tp);
260struct gbproxy_peer *gbproxy_peer_alloc(struct gbproxy_config *cfg, uint16_t bvci);
261void gbproxy_peer_free(struct gbproxy_peer *peer);
262int gbproxy_cleanup_peers(struct gbproxy_config *cfg, uint16_t nsei, uint16_t bvci);
Jacob Erlbeck5f1faa32014-08-21 10:01:30 +0200263
Harald Welteb77c6972010-05-01 11:28:43 +0200264#endif