Add NR SFN from SSB assertion and fix dummy SSB scheduling

master
Xavier Arteaga 3 years ago
parent 954d6f5f8d
commit 9d4fd1c5cc

@ -388,7 +388,11 @@ bool cc_worker::measure_csi()
} }
// Check if the SFN matches // Check if the SFN matches
// ... if (mib.sfn != dl_slot_cfg.idx / SRSRAN_NSLOTS_PER_FRAME_NR(phy.cfg.carrier.scs)) {
logger.error("PBCH-MIB: NR SFN (%d) does not match current SFN (%d)",
mib.sfn,
dl_slot_cfg.idx / SRSRAN_NSLOTS_PER_FRAME_NR(phy.cfg.carrier.scs));
}
// Log MIB information // Log MIB information
if (logger.debug.enabled()) { if (logger.debug.enabled()) {

@ -515,7 +515,17 @@ public:
// Schedule SSB // Schedule SSB
for (uint32_t ssb_idx = 0; ssb_idx < SRSRAN_SSB_NOF_CANDIDATES; ssb_idx++) { for (uint32_t ssb_idx = 0; ssb_idx < SRSRAN_SSB_NOF_CANDIDATES; ssb_idx++) {
if (phy_cfg.ssb.position_in_burst[ssb_idx]) { if (phy_cfg.ssb.position_in_burst[ssb_idx]) {
srsran_mib_nr_t mib = {};
mib.ssb_idx = ssb_idx;
mib.sfn = slot_cfg.idx / SRSRAN_NSLOTS_PER_FRAME_NR(phy_cfg.carrier.scs);
mib.hrf = (slot_cfg.idx % SRSRAN_NSLOTS_PER_FRAME_NR(phy_cfg.carrier.scs)) >=
SRSRAN_NSLOTS_PER_FRAME_NR(phy_cfg.carrier.scs) / 2;
mac_interface_phy_nr::ssb_t ssb = {}; mac_interface_phy_nr::ssb_t ssb = {};
if (srsran_pbch_msg_nr_mib_pack(&mib, &ssb.pbch_msg) < SRSRAN_SUCCESS) {
logger.error("Error Packing MIB in slot %d", slot_cfg.idx);
continue;
}
ssb.pbch_msg.ssb_idx = (uint32_t)ssb_idx; ssb.pbch_msg.ssb_idx = (uint32_t)ssb_idx;
dl_sched.ssb.push_back(ssb); dl_sched.ssb.push_back(ssb);
} }

Loading…
Cancel
Save