aboutsummaryrefslogtreecommitdiffstats
path: root/src/bts.h
diff options
context:
space:
mode:
authorPau Espin Pedrol <pespin@sysmocom.de>2021-01-13 18:54:38 +0100
committerpespin <pespin@sysmocom.de>2021-01-18 10:37:05 +0000
commitac3fd120268a38fb4794982823c6abc8e964cfe8 (patch)
treebc88fdd84f73ace721b35db63efac5935848a952 /src/bts.h
parent695ce771676732045ac89ac03b43ba071befeafb (diff)
Split PCU global PCU object from BTS object
Currently the BTS object (and gprs_rlcmac_bts struct) are used to hold both PCU global fields and BTS specific fields, all mangled together. The BTS is even accessed in lots of places by means of a singleton. This patch introduces a new struct gprs_pcu object aimed at holding all global state, and several fields are already moved from BTS to it. The new object can be accessed as global variable "the_pcu", reusing and including an already exisitng "the_pcu" global variable only used for bssgp related purposes so far. This is only a first step towards having a complete split global pcu and BTS, some fields are still kept in BTS and will be moved over follow-up smaller patches in the future (since this patch is already quite big). So far, the code still only supports one BTS, which can be accessed using the_pcu->bts. In the future that field will be replaced with a list, and the BTS singletons will be removed. The cur_fn output changes in TbfTest are actually a side effect fix, since the singleton main_bts() now points internally to the_pcu->bts, hence the same we allocate and assign in the test. Beforehand, "the_bts" was allocated in the stack while main_bts() still returned an unrelated singleton BTS object instance. Related: OS#4935 Change-Id: I88e3c6471b80245ce3798223f1a61190f14aa840
Diffstat (limited to 'src/bts.h')
-rw-r--r--src/bts.h53
1 files changed, 10 insertions, 43 deletions
diff --git a/src/bts.h b/src/bts.h
index f10542f4..fdd8536e 100644
--- a/src/bts.h
+++ b/src/bts.h
@@ -35,6 +35,7 @@ extern "C" {
#include <osmocom/gsm/gsm48.h>
#include "mslot_class.h"
#include "gsm_rlcmac.h"
+#include "gprs_pcu.h"
#ifdef __cplusplus
}
#endif
@@ -52,32 +53,6 @@ extern "C" {
#include <stdint.h>
#include <stdbool.h>
-#define LLC_CODEL_DISABLE 0
-#define LLC_CODEL_USE_DEFAULT (-1)
-
-#define MAX_EDGE_MCS 9
-#define MAX_GPRS_CS 4
-
-/* see bts->gsmtap_categ_mask */
-enum pcu_gsmtap_category {
- PCU_GSMTAP_C_DL_UNKNOWN = 0, /* unknown or undecodable downlink blocks */
- PCU_GSMTAP_C_DL_DUMMY = 1, /* downlink dummy blocks */
- PCU_GSMTAP_C_DL_CTRL = 2, /* downlink control blocks */
- PCU_GSMTAP_C_DL_DATA_GPRS = 3, /* downlink GPRS data blocks */
- PCU_GSMTAP_C_DL_DATA_EGPRS = 4, /* downlink EGPRS data blocks */
- PCU_GSMTAP_C_DL_PTCCH = 5, /* downlink PTCCH blocks */
- PCU_GSMTAP_C_DL_AGCH = 6, /* downlink AGCH blocks */
- PCU_GSMTAP_C_DL_PCH = 7, /* downlink PCH blocks */
-
- PCU_GSMTAP_C_UL_UNKNOWN = 15, /* unknown or undecodable uplink blocks */
- PCU_GSMTAP_C_UL_DUMMY = 16, /* uplink dummy blocks */
- PCU_GSMTAP_C_UL_CTRL = 17, /* uplink control blocks */
- PCU_GSMTAP_C_UL_DATA_GPRS = 18, /* uplink GPRS data blocks */
- PCU_GSMTAP_C_UL_DATA_EGPRS = 19, /* uplink EGPRS data blocks */
- PCU_GSMTAP_C_UL_RACH = 20, /* uplink RACH bursts */
- PCU_GSMTAP_C_UL_PTCCH = 21, /* uplink PTCCH bursts */
-};
-
struct BTS;
struct GprsMs;
@@ -120,12 +95,6 @@ struct gprs_rlcmac_bts {
uint16_t mcs_mask; /* Allowed MCS mask from BTS */
uint8_t initial_cs_dl, initial_cs_ul;
uint8_t initial_mcs_dl, initial_mcs_ul;
- struct { /* Config Values set by VTY */
- bool force_initial_cs; /* false=use from BTS true=use from VTY */
- bool force_initial_mcs; /* false=use from BTS true=use from VTY */
- uint8_t max_cs_dl, max_cs_ul;
- uint8_t max_mcs_dl, max_mcs_ul;
- } vty;
uint16_t force_llc_lifetime; /* overrides lifetime from SGSN */
uint32_t llc_discard_csec;
uint32_t llc_idle_ack_csec;
@@ -136,11 +105,7 @@ struct gprs_rlcmac_bts {
uint8_t n3101;
uint8_t n3103;
uint8_t n3105;
- struct gsmtap_inst *gsmtap;
- uint32_t gsmtap_categ_mask;
struct gprs_rlcmac_trx trx[8];
- int (*alloc_algorithm)(struct gprs_rlcmac_bts *bts, struct GprsMs *ms, struct gprs_rlcmac_tbf *tbf,
- bool single, int8_t use_tbf);
uint8_t force_two_phase;
uint8_t alpha, gamma;
@@ -171,9 +136,6 @@ struct gprs_rlcmac_bts {
*/
struct BTS *bts;
- /* Path to be used for the pcu-bts socket */
- char *pcu_sock_path;
-
/* Are we talking Gb with IP-SNS (true) or classic Gb? */
enum gprs_ns2_dialect ns_dialect;
@@ -182,7 +144,6 @@ struct gprs_rlcmac_bts {
struct msgb *app_info;
uint32_t app_info_pending; /* Count of MS with active TBF, to which we did not send app_info yet */
- struct gprs_ns2_inst *nsi;
/* main nsei */
struct gprs_ns2_nse *nse;
};
@@ -304,7 +265,7 @@ struct chan_req_params {
*/
struct BTS {
public:
- BTS();
+ BTS(struct gprs_pcu *pcu);
~BTS();
void cleanup();
@@ -373,7 +334,11 @@ public:
LListHead<gprs_rlcmac_tbf>& dl_tbfs();
struct gprs_rlcmac_bts m_bts;
+
+ /* back pointer to PCU object */
+ struct gprs_pcu *pcu;
private:
+
int m_cur_fn;
int m_cur_blk_fn;
uint8_t m_max_cs_dl, m_max_cs_ul;
@@ -453,6 +418,8 @@ inline void BTS::stat_item_add(unsigned int stat_id, int inc) {
osmo_stat_item_set(m_statg->items[stat_id], val + inc);
}
+struct gprs_pcu;
+struct BTS* bts_alloc(struct gprs_pcu *pcu);
#endif
#ifdef __cplusplus
@@ -463,8 +430,8 @@ extern "C" {
struct gprs_rlcmac_bts *bts_main_data();
struct rate_ctr_group *bts_main_data_stats();
struct osmo_stat_item_group *bts_main_data_stat_items();
- void bts_set_max_cs(struct gprs_rlcmac_bts *bts, uint8_t cs_dl, uint8_t cs_ul);
- void bts_set_max_mcs(struct gprs_rlcmac_bts *bts, uint8_t mcs_dl, uint8_t mcs_ul);
+ void bts_recalc_max_cs(struct gprs_rlcmac_bts *bts);
+ void bts_recalc_max_mcs(struct gprs_rlcmac_bts *bts);
struct GprsMs *bts_ms_by_imsi(struct BTS *bts, const char *imsi);
uint8_t bts_max_cs_dl(const struct BTS *bts);
uint8_t bts_max_cs_ul(const struct BTS *bts);