|
|
@ -50,48 +50,49 @@ cell_info_common_list::cell_info_common_list(const rrc_cfg_t& cfg_) : cfg(cfg_)
|
|
|
|
cell_list.reserve(cfg.cell_list.size());
|
|
|
|
cell_list.reserve(cfg.cell_list.size());
|
|
|
|
|
|
|
|
|
|
|
|
// Store the SIB cfg of each carrier
|
|
|
|
// Store the SIB cfg of each carrier
|
|
|
|
for (size_t ccidx = 0; ccidx < cfg.cell_list.size(); ++ccidx) {
|
|
|
|
for (uint32_t ccidx = 0; ccidx < cfg.cell_list.size(); ++ccidx) {
|
|
|
|
cell_list.emplace_back(ccidx, cfg.cell_list[ccidx]);
|
|
|
|
cell_list.emplace_back(std::unique_ptr<cell_info_common>{new cell_info_common{ccidx, cfg.cell_list[ccidx]}});
|
|
|
|
auto& cell_ctxt = cell_list.back();
|
|
|
|
cell_info_common* cell_ctxt = cell_list.back().get();
|
|
|
|
|
|
|
|
|
|
|
|
// Set Cell MIB
|
|
|
|
// Set Cell MIB
|
|
|
|
asn1::number_to_enum(cell_ctxt.mib.dl_bw, cfg.cell.nof_prb);
|
|
|
|
asn1::number_to_enum(cell_ctxt->mib.dl_bw, cfg.cell.nof_prb);
|
|
|
|
cell_ctxt.mib.phich_cfg.phich_res.value = (phich_cfg_s::phich_res_opts::options)cfg.cell.phich_resources;
|
|
|
|
cell_ctxt->mib.phich_cfg.phich_res.value = (phich_cfg_s::phich_res_opts::options)cfg.cell.phich_resources;
|
|
|
|
cell_ctxt.mib.phich_cfg.phich_dur.value = (phich_cfg_s::phich_dur_opts::options)cfg.cell.phich_length;
|
|
|
|
cell_ctxt->mib.phich_cfg.phich_dur.value = (phich_cfg_s::phich_dur_opts::options)cfg.cell.phich_length;
|
|
|
|
|
|
|
|
|
|
|
|
// Set Cell SIB1
|
|
|
|
// Set Cell SIB1
|
|
|
|
cell_ctxt.sib1 = cfg.sib1;
|
|
|
|
cell_ctxt->sib1 = cfg.sib1;
|
|
|
|
// Update cellId
|
|
|
|
// Update cellId
|
|
|
|
sib_type1_s::cell_access_related_info_s_* cell_access = &cell_ctxt.sib1.cell_access_related_info;
|
|
|
|
sib_type1_s::cell_access_related_info_s_* cell_access = &cell_ctxt->sib1.cell_access_related_info;
|
|
|
|
cell_access->cell_id.from_number((cfg.enb_id << 8u) + cell_ctxt.cell_cfg.cell_id);
|
|
|
|
cell_access->cell_id.from_number((cfg.enb_id << 8u) + cell_ctxt->cell_cfg.cell_id);
|
|
|
|
cell_access->tac.from_number(cell_ctxt.cell_cfg.tac);
|
|
|
|
cell_access->tac.from_number(cell_ctxt->cell_cfg.tac);
|
|
|
|
// Update DL EARFCN
|
|
|
|
// Update DL EARFCN
|
|
|
|
cell_ctxt.sib1.freq_band_ind = (uint8_t)srslte_band_get_band(cell_ctxt.cell_cfg.dl_earfcn);
|
|
|
|
cell_ctxt->sib1.freq_band_ind = (uint8_t)srslte_band_get_band(cell_ctxt->cell_cfg.dl_earfcn);
|
|
|
|
|
|
|
|
|
|
|
|
// Set Cell SIB2
|
|
|
|
// Set Cell SIB2
|
|
|
|
// update PRACH root seq index for this cell
|
|
|
|
// update PRACH root seq index for this cell
|
|
|
|
cell_ctxt.sib2 = cfg.sibs[1].sib2();
|
|
|
|
cell_ctxt->sib2 = cfg.sibs[1].sib2();
|
|
|
|
cell_ctxt.sib2.rr_cfg_common.prach_cfg.root_seq_idx = cell_ctxt.cell_cfg.root_seq_idx;
|
|
|
|
cell_ctxt->sib2.rr_cfg_common.prach_cfg.root_seq_idx = cell_ctxt->cell_cfg.root_seq_idx;
|
|
|
|
// update carrier freq
|
|
|
|
// update carrier freq
|
|
|
|
if (cell_ctxt.sib2.freq_info.ul_carrier_freq_present) {
|
|
|
|
if (cell_ctxt->sib2.freq_info.ul_carrier_freq_present) {
|
|
|
|
cell_ctxt.sib2.freq_info.ul_carrier_freq = cell_ctxt.cell_cfg.ul_earfcn;
|
|
|
|
cell_ctxt->sib2.freq_info.ul_carrier_freq = cell_ctxt->cell_cfg.ul_earfcn;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const cell_info_common* cell_info_common_list::get_cell_id(uint32_t cell_id) const
|
|
|
|
const cell_info_common* cell_info_common_list::get_cell_id(uint32_t cell_id) const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
auto it = std::find_if(cell_list.begin(), cell_list.end(), [cell_id](const cell_info_common& c) {
|
|
|
|
auto it = std::find_if(cell_list.begin(), cell_list.end(), [cell_id](const std::unique_ptr<cell_info_common>& c) {
|
|
|
|
return c.cell_cfg.cell_id == cell_id;
|
|
|
|
return c->cell_cfg.cell_id == cell_id;
|
|
|
|
});
|
|
|
|
});
|
|
|
|
return it == cell_list.end() ? nullptr : &(*it);
|
|
|
|
return it == cell_list.end() ? nullptr : it->get();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
const cell_info_common* cell_info_common_list::get_pci(uint32_t pci) const
|
|
|
|
const cell_info_common* cell_info_common_list::get_pci(uint32_t pci) const
|
|
|
|
{
|
|
|
|
{
|
|
|
|
auto it = std::find_if(
|
|
|
|
auto it = std::find_if(cell_list.begin(), cell_list.end(), [pci](const std::unique_ptr<cell_info_common>& c) {
|
|
|
|
cell_list.begin(), cell_list.end(), [pci](const cell_info_common& c) { return c.cell_cfg.pci == pci; });
|
|
|
|
return c->cell_cfg.pci == pci;
|
|
|
|
return it == cell_list.end() ? nullptr : &(*it);
|
|
|
|
});
|
|
|
|
|
|
|
|
return it == cell_list.end() ? nullptr : it->get();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*************************
|
|
|
|
/*************************
|
|
|
|