added default cell_list config to the rr.conf, but commented

master
Francisco Paisana 5 years ago committed by Francisco Paisana
parent 37a9501db3
commit 56fdf047e6

@ -319,33 +319,67 @@ private:
}; };
template <typename T> template <typename T>
int parse_opt_field(T& obj, bool& flag, const char* field_name, Setting& root) struct DefaultFieldParser {
{ int operator()(T& obj, Setting& root) const
flag = root.lookupValue(field_name, obj); {
obj = (T)root;
return 0;
}
};
// specialization for uint16_t bc Setting does not have overloaded uint16_t operator
template <>
struct DefaultFieldParser<uint16_t> {
int operator()(uint16_t& obj, Setting& root) const
{
obj = (uint32_t)root;
return 0; return 0;
}
};
template <typename T, typename Parser = DefaultFieldParser<T> >
int parse_opt_field(T& obj,
Setting& root,
const char* field_name,
const Parser& field_parser = {},
bool* presence_flag = nullptr)
{
bool exists = root.exists(field_name);
if (presence_flag != nullptr) {
*presence_flag = exists;
}
return exists ? field_parser(obj, root[field_name]) : 0;
} }
template <typename T, typename Parser> //! Parse field if it exists. If not, default to "default_val"
int parse_opt_field(T& obj, bool& flag, const char* field_name, Setting& root, Parser field_parser) template <typename T, typename Parser = DefaultFieldParser<T> >
int parse_default_field(T& obj,
Setting& root,
const char* fieldname,
const T& default_val,
const Parser& field_parser = {},
bool* presence_flag = nullptr)
{ {
flag = false; bool opt_flag;
if (root.exists(field_name)) { int ret = parse_opt_field(obj, root, fieldname, field_parser, &opt_flag);
flag = true; if (not opt_flag) {
return field_parser(obj, root[field_name]); obj = default_val;
} }
return 0; if (presence_flag != nullptr) {
*presence_flag = opt_flag;
}
return ret;
} }
template <typename NumberType> template <typename T>
NumberType parse_bounded_number(Setting& fieldroot, NumberType num_min, NumberType num_max) int parse_bounded_number(T& number, Setting& fieldroot, T num_min, T num_max)
{ {
NumberType num = (NumberType)fieldroot; T num = (T)fieldroot;
if (num < num_min or num > num_max) { if (num < num_min or num > num_max) {
std::cout << "Parser Warning: Value of " << fieldroot.getName() << " must be within bound [" << num_min << ", " std::cout << "Parser Warning: Value of " << fieldroot.getName() << " must be within bound [" << num_min << ", "
<< num_max << "]\n"; << num_max << "]\n";
num = (num > num_max) ? num_max : num_min; num = (num > num_max) ? num_max : num_min;
} }
return num; return 0;
} }
namespace asn1_parsers { namespace asn1_parsers {
@ -389,7 +423,7 @@ int str_to_enum(EnumType& enum_val, Setting& root)
template <typename EnumType> template <typename EnumType>
int opt_str_to_enum(EnumType& enum_val, bool& presence_flag, Setting& root, const char* name) int opt_str_to_enum(EnumType& enum_val, bool& presence_flag, Setting& root, const char* name)
{ {
return parse_opt_field(enum_val, presence_flag, name, root, str_to_enum<EnumType>); return parse_opt_field(enum_val, root, name, str_to_enum<EnumType>, &presence_flag);
} }
template <typename EnumType> template <typename EnumType>
@ -428,7 +462,7 @@ int number_to_enum(EnumType& enum_val, Setting& root)
template <typename EnumType> template <typename EnumType>
int opt_number_to_enum(EnumType& enum_val, bool& presence_flag, Setting& root, const char* name) int opt_number_to_enum(EnumType& enum_val, bool& presence_flag, Setting& root, const char* name)
{ {
return parse_opt_field(enum_val, presence_flag, name, root, number_to_enum<EnumType>); return parse_opt_field(enum_val, root, name, number_to_enum<EnumType>, &presence_flag);
} }
} // namespace asn1_parsers } // namespace asn1_parsers

@ -97,9 +97,9 @@ struct rrc_meas_cfg_t {
struct cell_cfg_t { struct cell_cfg_t {
uint32_t rf_port; uint32_t rf_port;
uint32_t cell_id; uint32_t cell_id;
uint32_t tac; uint16_t tac;
uint32_t pci; uint32_t pci;
uint32_t root_seq_idx; uint16_t root_seq_idx;
uint32_t dl_earfcn; uint32_t dl_earfcn;
uint32_t ul_earfcn; uint32_t ul_earfcn;
std::vector<scell_cfg_t> scell_list; std::vector<scell_cfg_t> scell_list;

@ -50,8 +50,21 @@ phy_cnfg =
}; };
}; };
rrc_cnfg = cell_list =
{ (
// rf_port = 0;
// cell_id = 0x01;
// tac = 0x0001;
// pci = 1;
// root_seq_idx = 204;
// dl_earfcn = 3400;
// ul_earfcn = 474;
// CA cells
scell_list = (
{cell_id = 0x02; cross_carrier_scheduling = false; scheduling_cell_id = 0x02; ul_allowed = true};
);
// Cells available for handover // Cells available for handover
meas_cell_list = meas_cell_list =
( (
@ -70,4 +83,4 @@ rrc_cnfg =
a3_time_to_trigger = 480; a3_time_to_trigger = 480;
rsrq_config = 4; rsrq_config = 4;
}; };
}; );

@ -956,9 +956,9 @@ int enb::parse_rr(all_args_t* args_, rrc_cfg_t* rrc_cfg_)
cqi_report_cnfg.add_field(new field_sf_mapping(rrc_cfg_->cqi_cfg.sf_mapping, &rrc_cfg_->cqi_cfg.nof_subframes)); cqi_report_cnfg.add_field(new field_sf_mapping(rrc_cfg_->cqi_cfg.sf_mapping, &rrc_cfg_->cqi_cfg.nof_subframes));
/* RRC config section */ /* RRC config section */
parser::section rrc_cnfg("rrc_cnfg"); parser::section rrc_cnfg("cell_list");
rrc_cnfg.set_optional(&rrc_cfg_->meas_cfg_present); rrc_cnfg.set_optional(&rrc_cfg_->meas_cfg_present);
rrc_cnfg.add_field(new rr_sections::rrc_cnfg_section(args_, rrc_cfg_)); rrc_cnfg.add_field(new rr_sections::cell_list_section(args_, rrc_cfg_));
// Run parser with two sections // Run parser with two sections
parser p(args_->enb_files.rr_config); parser p(args_->enb_files.rr_config);
@ -1208,29 +1208,32 @@ static int parse_meas_report_desc(rrc_meas_cfg_t* meas_cfg, Setting& root)
static int parse_cell_list(all_args_t* args, rrc_cfg_t* rrc_cfg, Setting& root) static int parse_cell_list(all_args_t* args, rrc_cfg_t* rrc_cfg, Setting& root)
{ {
auto cell_id_parser = [](uint32_t& cell_id, Setting& root) { return parse_bounded_number(cell_id, root, 0u, 255u); };
uint32_t self_cellid = args->stack.s1ap.cell_id & 0xFFu;
rrc_cfg->cell_list.resize(root.getLength()); rrc_cfg->cell_list.resize(root.getLength());
for (uint32_t n = 0; n < rrc_cfg->cell_list.size(); ++n) { for (uint32_t n = 0; n < rrc_cfg->cell_list.size(); ++n) {
cell_cfg_t& cell_cfg = rrc_cfg->cell_list[n]; cell_cfg_t& cell_cfg = rrc_cfg->cell_list[n];
cell_cfg.rf_port = (uint32_t)root[n]["rf_port"];
cell_cfg.cell_id = parse_bounded_number<uint32_t>(root[n]["cell_id"], 0, 255);
cell_cfg.tac = (uint32_t)root[n]["tac"];
cell_cfg.pci = (uint32_t)root[n]["pci"];
cell_cfg.root_seq_idx = (uint32_t)root[n]["root_seq_idx"];
if (not root[n].lookupValue("dl_earfcn", cell_cfg.dl_earfcn)) { parse_opt_field(cell_cfg.rf_port, root[n], "rf_port");
cell_cfg.dl_earfcn = args->enb.dl_earfcn; // default to enb.conf parse_default_field(cell_cfg.cell_id, root[n], "cell_id", self_cellid, cell_id_parser);
} parse_default_field(cell_cfg.tac, root[n], "tac", args->stack.s1ap.tac);
if (not root[n].lookupValue("ul_earfcn", cell_cfg.ul_earfcn)) { parse_default_field(cell_cfg.pci, root[n], "pci", args->enb.pci);
cell_cfg.ul_earfcn = args->enb.ul_earfcn; parse_default_field(
} cell_cfg.root_seq_idx, root[n], "root_seq_idx", rrc_cfg->sibs[1].sib2().rr_cfg_common.prach_cfg.root_seq_idx);
parse_default_field(cell_cfg.dl_earfcn, root[n], "dl_earfcn", args->enb.dl_earfcn);
parse_default_field(cell_cfg.ul_earfcn, root[n], "ul_earfcn", args->enb.ul_earfcn);
HANDLEPARSERCODE(parse_meas_cell_list(&rrc_cfg->meas_cfg, root[n]["meas_cell_list"]));
HANDLEPARSERCODE(parse_meas_report_desc(&rrc_cfg->meas_cfg, root[n]["meas_report_desc"]));
cell_cfg.scell_list.resize(root["scell_list"].getLength()); cell_cfg.scell_list.resize(root["scell_list"].getLength());
for (uint32_t i = 0; i < cell_cfg.scell_list.size(); ++i) { for (uint32_t i = 0; i < cell_cfg.scell_list.size(); ++i) {
auto& scell = cell_cfg.scell_list[i]; auto& scell = cell_cfg.scell_list[i];
auto& scellroot = root["scell_list"][i]; auto& scellroot = root["scell_list"][i];
scell.cell_id = parse_bounded_number<uint32_t>(scellroot["cell_id"], 0, 255); cell_id_parser(scell.cell_id, scellroot["cell_id"]);
scell.cross_carrier_sched = (bool)scellroot["cross_carrier_scheduling"]; scell.cross_carrier_sched = (bool)scellroot["cross_carrier_scheduling"];
scell.sched_cell_id = parse_bounded_number<uint32_t>(scellroot["scheduling_cell_id"], 0, 255); cell_id_parser(scell.sched_cell_id, scellroot["scheduling_cell_id"]);
scell.ul_allowed = (bool)scellroot["ul_allowed"]; scell.ul_allowed = (bool)scellroot["ul_allowed"];
} }
} }
@ -1238,10 +1241,8 @@ static int parse_cell_list(all_args_t* args, rrc_cfg_t* rrc_cfg, Setting& root)
return SRSLTE_SUCCESS; return SRSLTE_SUCCESS;
} }
int rrc_cnfg_section::parse(libconfig::Setting& root) int cell_list_section::parse(libconfig::Setting& root)
{ {
HANDLEPARSERCODE(parse_meas_cell_list(&rrc_cfg->meas_cfg, root["meas_cell_list"]));
HANDLEPARSERCODE(parse_meas_report_desc(&rrc_cfg->meas_cfg, root["meas_report_desc"]));
HANDLEPARSERCODE(parse_cell_list(args, rrc_cfg, root["cell_list"])); HANDLEPARSERCODE(parse_cell_list(args, rrc_cfg, root["cell_list"]));
return 0; return 0;
} }

@ -115,10 +115,10 @@ namespace rr_sections {
// rrc_cnfg // rrc_cnfg
class rrc_cnfg_section final : public parser::field_itf class cell_list_section final : public parser::field_itf
{ {
public: public:
explicit rrc_cnfg_section(all_args_t* all_args_, rrc_cfg_t* rrc_cfg_) : args(all_args_), rrc_cfg(rrc_cfg_) {} explicit cell_list_section(all_args_t* all_args_, rrc_cfg_t* rrc_cfg_) : args(all_args_), rrc_cfg(rrc_cfg_) {}
int parse(Setting& root) override; int parse(Setting& root) override;

Loading…
Cancel
Save