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
2021-01-13 17:54:38 +00:00
|
|
|
/*
|
|
|
|
* Copyright (C) 2013 by Holger Hans Peter Freyther
|
|
|
|
* Copyright (C) 2021 by sysmocom - s.f.m.c. GmbH <info@sysmocom.de>
|
|
|
|
* Author: Pau Espin Pedrol <pespin@sysmocom.de>
|
|
|
|
*
|
|
|
|
* All Rights Reserved
|
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or modify
|
|
|
|
* it under the terms of the GNU Affero General Public License as published by
|
|
|
|
* the Free Software Foundation; either version 3 of the License, or
|
|
|
|
* (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU Affero General Public License
|
|
|
|
* along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
#include <stdbool.h>
|
|
|
|
|
|
|
|
#include <osmocom/core/gsmtap_util.h>
|
|
|
|
|
|
|
|
#include "gprs_bssgp_pcu.h"
|
2021-01-14 12:08:02 +00:00
|
|
|
#include "coding_scheme.h"
|
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
2021-01-13 17:54:38 +00:00
|
|
|
|
|
|
|
#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 gprs_rlcmac_bts;
|
|
|
|
struct GprsMs;
|
|
|
|
struct gprs_rlcmac_tbf;
|
|
|
|
|
|
|
|
typedef int (*alloc_algorithm_func_t)(struct gprs_rlcmac_bts *bts,
|
|
|
|
struct GprsMs *ms,
|
|
|
|
struct gprs_rlcmac_tbf *tbf,
|
|
|
|
bool single, int8_t use_tbf);
|
|
|
|
|
|
|
|
struct gprs_pcu {
|
|
|
|
|
|
|
|
/* Path to be used for the pcu-bts socket */
|
|
|
|
char *pcu_sock_path;
|
|
|
|
|
|
|
|
struct { /* Config Values set by VTY */
|
2021-01-14 13:03:17 +00:00
|
|
|
uint8_t fc_interval;
|
|
|
|
uint16_t fc_bucket_time;
|
|
|
|
uint32_t fc_bvc_bucket_size;
|
|
|
|
uint32_t fc_bvc_leak_rate;
|
|
|
|
uint32_t fc_ms_bucket_size;
|
|
|
|
uint32_t fc_ms_leak_rate;
|
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
2021-01-13 17:54:38 +00:00
|
|
|
bool force_initial_cs; /* false=use from BTS true=use from VTY */
|
|
|
|
bool force_initial_mcs; /* false=use from BTS true=use from VTY */
|
2021-01-14 15:20:57 +00:00
|
|
|
uint8_t initial_cs_dl, initial_cs_ul;
|
|
|
|
uint8_t initial_mcs_dl, initial_mcs_ul;
|
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
2021-01-13 17:54:38 +00:00
|
|
|
uint8_t max_cs_dl, max_cs_ul;
|
|
|
|
uint8_t max_mcs_dl, max_mcs_ul;
|
2021-01-14 11:48:50 +00:00
|
|
|
uint8_t force_two_phase;
|
2021-01-14 11:53:53 +00:00
|
|
|
uint8_t alpha, gamma;
|
2021-01-14 11:56:58 +00:00
|
|
|
bool dl_tbf_preemptive_retransmission;
|
2021-01-14 12:08:02 +00:00
|
|
|
enum egprs_arq_type dl_arq_type; /* EGPRS_ARQ1 to support resegmentation in DL, EGPRS_ARQ2 for no reseg */
|
2021-01-14 12:17:01 +00:00
|
|
|
bool cs_adj_enabled; /* whether cs_adj_{upper,lower}_limit are used to adjust DL CS */
|
|
|
|
uint8_t cs_adj_upper_limit; /* downgrade DL CS if error rate above its value */
|
|
|
|
uint8_t cs_adj_lower_limit; /* upgrade DL CS if error rate below its value */
|
2021-01-14 12:20:55 +00:00
|
|
|
/* downgrade DL CS when less than specified octets are left in tx queue. Optimization, see paper:
|
|
|
|
"Theoretical Analysis of GPRS Throughput and Delay" */
|
|
|
|
uint16_t cs_downgrade_threshold;
|
2021-01-14 12:30:04 +00:00
|
|
|
/* Link quality range for each UL (M)CS. Below or above, next/prev (M)CS is selected. */
|
|
|
|
struct {int16_t low; int16_t high; } cs_lqual_ranges[MAX_GPRS_CS];
|
|
|
|
struct {int16_t low; int16_t high; } mcs_lqual_ranges[MAX_EDGE_MCS];
|
2021-01-14 12:36:02 +00:00
|
|
|
enum gprs_ns2_dialect ns_dialect; /* Are we talking Gb with IP-SNS (true) or classic Gb? */
|
2021-01-14 13:30:03 +00:00
|
|
|
uint16_t ws_base;
|
|
|
|
uint16_t ws_pdch; /* increase WS by this value per PDCH */
|
2021-01-14 13:45:14 +00:00
|
|
|
uint16_t force_llc_lifetime; /* overrides lifetime from SGSN */
|
|
|
|
uint32_t llc_discard_csec;
|
|
|
|
uint32_t llc_idle_ack_csec;
|
|
|
|
uint32_t llc_codel_interval_msec; /* 0=disabled, -1=use default interval */
|
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
2021-01-13 17:54:38 +00:00
|
|
|
} vty;
|
|
|
|
|
|
|
|
struct gsmtap_inst *gsmtap;
|
|
|
|
uint32_t gsmtap_categ_mask;
|
|
|
|
|
2021-01-18 16:14:14 +00:00
|
|
|
struct llist_head bts_list; /* list of gprs_rlcmac_tbf */
|
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
2021-01-13 17:54:38 +00:00
|
|
|
|
|
|
|
struct gprs_ns2_inst *nsi;
|
|
|
|
|
|
|
|
alloc_algorithm_func_t alloc_algorithm;
|
|
|
|
|
|
|
|
struct gprs_bssgp_pcu bssgp;
|
2021-01-14 11:01:42 +00:00
|
|
|
|
|
|
|
struct osmo_tdef *T_defs; /* timers controlled by PCU */
|
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
2021-01-13 17:54:38 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
extern struct gprs_pcu *the_pcu;
|
|
|
|
|
|
|
|
struct gprs_pcu *gprs_pcu_alloc(void *ctx);
|
|
|
|
|
2021-01-18 16:14:14 +00:00
|
|
|
struct gprs_rlcmac_bts *gprs_pcu_get_bts_by_nr(struct gprs_pcu *pcu, uint8_t bts_nr);
|
|
|
|
|
2021-01-14 15:20:57 +00:00
|
|
|
void gprs_pcu_set_initial_cs(struct gprs_pcu *pcu, uint8_t cs_dl, uint8_t cs_ul);
|
|
|
|
void gprs_pcu_set_initial_mcs(struct gprs_pcu *pcu, uint8_t mcs_dl, uint8_t mcs_ul);
|
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
2021-01-13 17:54:38 +00:00
|
|
|
void gprs_pcu_set_max_cs(struct gprs_pcu *pcu, uint8_t cs_dl, uint8_t cs_ul);
|
|
|
|
void gprs_pcu_set_max_mcs(struct gprs_pcu *pcu, uint8_t mcs_dl, uint8_t mcs_ul);
|