blob: 46decc0ecb54cdf84c7df2322419ecc12a7c3544 [file] [log] [blame]
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +02001#ifndef _GB_PROXY_H
2#define _GB_PROXY_H
3
4
5#include <osmocom/core/msgb.h>
Alexander Couzens951e1332020-09-22 13:21:46 +02006#include <osmocom/core/timer.h>
Harald Weltee5209642020-12-05 19:59:45 +01007#include <osmocom/core/fsm.h>
Harald Welted2fef952020-12-05 00:31:07 +01008#include <osmocom/core/hashtable.h>
Neels Hofmeyr6179f0c2018-02-21 00:39:36 +01009#include <osmocom/gsm/gsm23003.h>
Daniel Willmannee834af2020-12-14 16:22:39 +010010#include <osmocom/gsm/gsm23236.h>
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020011
Alexander Couzens951e1332020-09-22 13:21:46 +020012#include <osmocom/gprs/gprs_ns2.h>
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020013#include <osmocom/vty/command.h>
14
15#include <sys/types.h>
16#include <regex.h>
Harald Weltebec70412019-03-22 09:44:42 +010017#include <stdbool.h>
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020018
19#define GBPROXY_INIT_VU_GEN_TX 256
Daniel Willmannee834af2020-12-14 16:22:39 +010020#define GBPROXY_MAX_NR_SGSN 16
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020021
Daniel Willmann8f407b12020-12-02 19:33:50 +010022/* BVCI uses 16 bits */
23#define BVC_LOG_CTX_FLAG (1<<17)
24
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020025struct rate_ctr_group;
26struct gprs_gb_parse_context;
27struct tlv_parsed;
28
29enum gbproxy_global_ctr {
30 GBPROX_GLOB_CTR_INV_BVCI,
31 GBPROX_GLOB_CTR_INV_LAI,
32 GBPROX_GLOB_CTR_INV_RAI,
33 GBPROX_GLOB_CTR_INV_NSEI,
34 GBPROX_GLOB_CTR_PROTO_ERR_BSS,
35 GBPROX_GLOB_CTR_PROTO_ERR_SGSN,
36 GBPROX_GLOB_CTR_NOT_SUPPORTED_BSS,
37 GBPROX_GLOB_CTR_NOT_SUPPORTED_SGSN,
38 GBPROX_GLOB_CTR_RESTART_RESET_SGSN,
39 GBPROX_GLOB_CTR_TX_ERR_SGSN,
40 GBPROX_GLOB_CTR_OTHER_ERR,
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020041};
42
Harald Welte560bdb32020-12-04 22:24:47 +010043enum gbproxy_bvc_ctr {
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020044 GBPROX_PEER_CTR_BLOCKED,
45 GBPROX_PEER_CTR_UNBLOCKED,
46 GBPROX_PEER_CTR_DROPPED,
47 GBPROX_PEER_CTR_INV_NSEI,
48 GBPROX_PEER_CTR_TX_ERR,
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020049 GBPROX_PEER_CTR_LAST,
50};
51
Harald Welte4a8769a2019-03-22 08:26:45 +010052/* global gb-proxy configuration */
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020053struct gbproxy_config {
Harald Welte4a8769a2019-03-22 08:26:45 +010054 /* NS instance of libosmogb */
Alexander Couzens951e1332020-09-22 13:21:46 +020055 struct gprs_ns2_inst *nsi;
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020056
Harald Welte209dc9f2020-12-12 19:02:16 +010057 struct {
58 /* percentage of BVC flow control advertised to each SGSN in the pool */
59 uint8_t bvc_fc_ratio;
Daniel Willmannee834af2020-12-14 16:22:39 +010060 /* NRI bitlen and usable NULL-NRI ranges */
61 uint8_t nri_bitlen;
62 struct osmo_nri_ranges *null_nri_ranges;
Harald Welte209dc9f2020-12-12 19:02:16 +010063 } pool;
64
Daniel Willmannee834af2020-12-14 16:22:39 +010065 /* hash table of all BSS side Gb peers */
Harald Welted2fef952020-12-05 00:31:07 +010066 DECLARE_HASHTABLE(bss_nses, 8);
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020067
Harald Weltee5209642020-12-05 19:59:45 +010068 /* hash table of all SGSN-side Gb peers */
69 DECLARE_HASHTABLE(sgsn_nses, 8);
70
71 /* hash table of all gbproxy_cell */
72 DECLARE_HASHTABLE(cells, 8);
73
Daniel Willmannee834af2020-12-14 16:22:39 +010074 /* List of all SGSNs */
75 struct llist_head sgsns;
76
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020077 /* Counter */
78 struct rate_ctr_group *ctrg;
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +020079};
80
Harald Weltee5209642020-12-05 19:59:45 +010081/* One Cell within the BSS: Links BSS-side BVC to SGSN-side BVCs */
82struct gbproxy_cell {
83 /* linked to gbproxy_config.cells hashtable */
84 struct hlist_node list;
85
86 /* point back to the config */
87 struct gbproxy_config *cfg;
88
89 /* BVCI of PTP BVCs associated to this cell */
90 uint16_t bvci;
91
92 /* Routing Area that this BVC is part of (raw 04.08 encoding) */
93 uint8_t ra[6];
94
95 /* pointer to the BSS-side BVC */
96 struct gbproxy_bvc *bss_bvc;
97
98 /* pointers to SGSN-side BVC (one for each pool member) */
Daniel Willmannee834af2020-12-14 16:22:39 +010099 struct gbproxy_bvc *sgsn_bvc[GBPROXY_MAX_NR_SGSN];
Harald Weltee5209642020-12-05 19:59:45 +0100100};
101
Daniel Willmanne50550e2020-11-26 18:19:21 +0100102/* One BVC inside an NSE */
Harald Welte560bdb32020-12-04 22:24:47 +0100103struct gbproxy_bvc {
104 /* linked to gbproxy_nse.bvcs */
Harald Welte8b4c7942020-12-05 10:14:49 +0100105 struct hlist_node list;
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200106
Harald Welte560bdb32020-12-04 22:24:47 +0100107 /* The NSE this BVC belongs to */
Daniel Willmanne50550e2020-11-26 18:19:21 +0100108 struct gbproxy_nse *nse;
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200109
Harald Welte560bdb32020-12-04 22:24:47 +0100110 /* PTP BVCI of this BVC */
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200111 uint16_t bvci;
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200112
Harald Welte560bdb32020-12-04 22:24:47 +0100113 /* Routing Area that this BVC is part of (raw 04.08 encoding) */
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200114 uint8_t ra[6];
115
116 /* Counter */
117 struct rate_ctr_group *ctrg;
Harald Weltee5209642020-12-05 19:59:45 +0100118
119 /* the cell to which this BVC belongs */
120 struct gbproxy_cell *cell;
121
122 /* per-BVC FSM instance */
123 struct osmo_fsm_inst *fi;
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200124};
125
Harald Welte560bdb32020-12-04 22:24:47 +0100126/* one NS Entity that we interact with (BSS/PCU) */
Daniel Willmanne50550e2020-11-26 18:19:21 +0100127struct gbproxy_nse {
Harald Welte2b7b1bb2020-12-04 23:58:20 +0100128 /* linked to gbproxy_config.bss_nses */
Harald Welted2fef952020-12-05 00:31:07 +0100129 struct hlist_node list;
Daniel Willmanne50550e2020-11-26 18:19:21 +0100130
131 /* point back to the config */
132 struct gbproxy_config *cfg;
133
Harald Welte560bdb32020-12-04 22:24:47 +0100134 /* NSEI of the NSE */
Daniel Willmanne50550e2020-11-26 18:19:21 +0100135 uint16_t nsei;
136
Harald Weltee5209642020-12-05 19:59:45 +0100137 /* Are we facing towards a SGSN (true) or BSS (false) */
138 bool sgsn_facing;
139
Daniel Willmanne50550e2020-11-26 18:19:21 +0100140 /* List of all BVCs in this NSE */
Harald Welte8b4c7942020-12-05 10:14:49 +0100141 DECLARE_HASHTABLE(bvcs, 10);
Daniel Willmanne50550e2020-11-26 18:19:21 +0100142};
143
Daniel Willmannee834af2020-12-14 16:22:39 +0100144/* SGSN configuration such as pool options (only for NSE where sgsn_facing == true) */
145struct gbproxy_sgsn {
146 /* linked to gbproxy_config.sgsns */
147 struct llist_head list;
148
149 /* The NSE belonging to this SGSN */
150 struct gbproxy_nse *nse;
151
152 /* Pool configuration for the sgsn (only valid if sgsn_facing == true) */
153 struct {
154 bool allow_attach;
155 struct osmo_nri_ranges *nri_ranges;
156 } pool;
157};
158
Daniel Willmann066c4cb2020-12-01 16:36:29 +0100159/* Convenience logging macros for NSE/BVC */
160#define LOGPNSE_CAT(NSE, SUBSYS, LEVEL, FMT, ARGS...) \
Harald Weltee5209642020-12-05 19:59:45 +0100161 LOGP(SUBSYS, LEVEL, "NSE(%05u/%s) " FMT, (NSE)->nsei, \
162 (NSE)->sgsn_facing ? "SGSN" : "BSS", ## ARGS)
Daniel Willmann066c4cb2020-12-01 16:36:29 +0100163#define LOGPNSE(NSE, LEVEL, FMT, ARGS...) \
164 LOGPNSE_CAT(NSE, DGPRS, LEVEL, FMT, ## ARGS)
165
166#define LOGPBVC_CAT(BVC, SUBSYS, LEVEL, FMT, ARGS...) \
Harald Weltee5209642020-12-05 19:59:45 +0100167 LOGP(SUBSYS, LEVEL, "NSE(%05u/%s)-BVC(%05u/%s) " FMT, (BVC)->nse->nsei, \
168 (BVC)->nse->sgsn_facing ? "SGSN" : "BSS", (BVC)->bvci, \
169 osmo_fsm_inst_state_name((BVC)->fi), ## ARGS)
Daniel Willmann066c4cb2020-12-01 16:36:29 +0100170#define LOGPBVC(BVC, LEVEL, FMT, ARGS...) \
171 LOGPBVC_CAT(BVC, DGPRS, LEVEL, FMT, ## ARGS)
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200172
Harald Weltecfc7e8e2020-12-07 12:03:10 +0100173#define LOGPCELL_CAT(CELL, SUBSYS, LEVEL, FMT, ARGS...) \
174 LOGP(SUBSYS, LEVEL, "CELL(%05u) " FMT, (CELL)->bvci, ## ARGS)
175#define LOGPCELL(CELL, LEVEL, FMT, ARGS...) \
176 LOGPCELL_CAT(CELL, DGPRS, LEVEL, FMT, ## ARGS)
177
Daniel Willmannee834af2020-12-14 16:22:39 +0100178#define LOGPSGSN_CAT(SGSN, SUBSYS, LEVEL, FMT, ARGS...) \
179 LOGP(SUBSYS, LEVEL, "NSE(%05u)-SGSN " FMT, (SGSN)->nse->nsei, ## ARGS)
180#define LOGPSGSN(SGSN, LEVEL, FMT, ARGS...) \
181 LOGPSGSN_CAT(SGSN, DGPRS, LEVEL, FMT, ## ARGS)
182
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200183/* gb_proxy_vty .c */
184
185int gbproxy_vty_init(void);
186int gbproxy_parse_config(const char *config_file, struct gbproxy_config *cfg);
187
Daniel Willmann13404b72018-06-01 07:21:20 +0200188/* gb_proxy_ctrl.c */
189int gb_ctrl_cmds_install(void);
190
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200191
192/* gb_proxy.c */
193int gbproxy_init_config(struct gbproxy_config *cfg);
194
195/* Main input function for Gb proxy */
Alexander Couzens951e1332020-09-22 13:21:46 +0200196int gbprox_rcvmsg(void *ctx, struct msgb *msg);
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200197
198int gbprox_signal(unsigned int subsys, unsigned int signal,
199 void *handler_data, void *signal_data);
200
Alexander Couzens951e1332020-09-22 13:21:46 +0200201
202int gprs_ns2_prim_cb(struct osmo_prim_hdr *oph, void *ctx);
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200203
204void gbprox_reset(struct gbproxy_config *cfg);
205
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200206/* Peer handling */
Harald Weltee5209642020-12-05 19:59:45 +0100207#define NSE_F_SGSN 0x0001
208#define NSE_F_BSS 0x0002
209
210struct gbproxy_bvc *gbproxy_bvc_by_bvci(struct gbproxy_nse *nse, uint16_t bvci);
Harald Welte560bdb32020-12-04 22:24:47 +0100211struct gbproxy_bvc *gbproxy_bvc_alloc(struct gbproxy_nse *nse, uint16_t bvci);
212void gbproxy_bvc_free(struct gbproxy_bvc *bvc);
Harald Weltee5209642020-12-05 19:59:45 +0100213int gbproxy_cleanup_bvcs(struct gbproxy_nse *nse, uint16_t bvci);
214
215struct gbproxy_cell *gbproxy_cell_alloc(struct gbproxy_config *cfg, uint16_t bvci);
216struct gbproxy_cell *gbproxy_cell_by_bvci(struct gbproxy_config *cfg, uint16_t bvci);
217void gbproxy_cell_free(struct gbproxy_cell *cell);
218bool gbproxy_cell_add_sgsn_bvc(struct gbproxy_cell *cell, struct gbproxy_bvc *bvc);
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200219
Daniel Willmanne50550e2020-11-26 18:19:21 +0100220/* NSE handling */
Harald Weltee5209642020-12-05 19:59:45 +0100221struct gbproxy_nse *gbproxy_nse_alloc(struct gbproxy_config *cfg, uint16_t nsei, bool sgsn_facing);
Daniel Willmanne50550e2020-11-26 18:19:21 +0100222void gbproxy_nse_free(struct gbproxy_nse *nse);
Harald Weltee5209642020-12-05 19:59:45 +0100223struct gbproxy_nse *gbproxy_nse_by_nsei(struct gbproxy_config *cfg, uint16_t nsei, uint32_t flags);
224struct gbproxy_nse *gbproxy_nse_by_nsei_or_new(struct gbproxy_config *cfg, uint16_t nsei, bool sgsn_facing);
Daniel Willmanne50550e2020-11-26 18:19:21 +0100225
Daniel Willmannee834af2020-12-14 16:22:39 +0100226/* SGSN handling */
227struct gbproxy_sgsn *gbproxy_sgsn_alloc(struct gbproxy_config *cfg, uint16_t nsei);
228void gbproxy_sgsn_free(struct gbproxy_sgsn *sgsn);
229struct gbproxy_sgsn *gbproxy_sgsn_by_nsei(struct gbproxy_config *cfg, uint16_t nsei);
230struct gbproxy_sgsn *gbproxy_sgsn_by_nsei_or_new(struct gbproxy_config *cfg, uint16_t nsei);
231struct gbproxy_sgsn *gbproxy_sgsn_by_nri(struct gbproxy_config *cfg, uint16_t nri, bool *null_nri);
232
Neels Hofmeyr4b4c5862017-09-04 15:13:25 +0200233#endif