|
|
@ -957,12 +957,10 @@ srslte::proc_outcome_t rrc::connection_reconf_no_ho_proc::init(const asn1::rrc::
|
|
|
|
if (rrc_ptr->reestablishment_successful) {
|
|
|
|
if (rrc_ptr->reestablishment_successful) {
|
|
|
|
// Reestablish PDCP and RLC for SRB2 and all DRB
|
|
|
|
// Reestablish PDCP and RLC for SRB2 and all DRB
|
|
|
|
// TODO: Which is the maximum LCID?
|
|
|
|
// TODO: Which is the maximum LCID?
|
|
|
|
rrc_ptr->reestablishment_successful = false;
|
|
|
|
|
|
|
|
for (int i = 2; i < SRSLTE_N_RADIO_BEARERS; i++) {
|
|
|
|
for (int i = 2; i < SRSLTE_N_RADIO_BEARERS; i++) {
|
|
|
|
if (rrc_ptr->rlc->has_bearer(i)) {
|
|
|
|
if (rrc_ptr->rlc->has_bearer(i)) {
|
|
|
|
rrc_ptr->rlc->reestablish(i);
|
|
|
|
rrc_ptr->rlc->reestablish(i);
|
|
|
|
rrc_ptr->pdcp->reestablish(i);
|
|
|
|
rrc_ptr->pdcp->reestablish(i);
|
|
|
|
rrc_ptr->pdcp->send_status_report(i);
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
@ -974,6 +972,16 @@ srslte::proc_outcome_t rrc::connection_reconf_no_ho_proc::init(const asn1::rrc::
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (rrc_ptr->reestablishment_successful) {
|
|
|
|
|
|
|
|
// Send status report if necessary.
|
|
|
|
|
|
|
|
rrc_ptr->reestablishment_successful = false;
|
|
|
|
|
|
|
|
for (int i = 2; i < SRSLTE_N_RADIO_BEARERS; i++) {
|
|
|
|
|
|
|
|
if (rrc_ptr->rlc->has_bearer(i)) {
|
|
|
|
|
|
|
|
rrc_ptr->pdcp->send_status_report(i);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// Apply Scell RR configurations (call is non-blocking). Make a copy since can be changed inside
|
|
|
|
// Apply Scell RR configurations (call is non-blocking). Make a copy since can be changed inside
|
|
|
|
// apply_scell_config() Note that apply_scell_config() calls set_scell() and set_config() which run in the
|
|
|
|
// apply_scell_config() Note that apply_scell_config() calls set_scell() and set_config() which run in the
|
|
|
|
// background.
|
|
|
|
// background.
|
|
|
@ -1324,9 +1332,9 @@ proc_outcome_t rrc::connection_reest_proc::init(asn1::rrc::reest_cause_e cause)
|
|
|
|
reest_cellid = rrc_ptr->meas_cells.find_cell(reest_source_freq, reest_source_pci)->get_cell_id();
|
|
|
|
reest_cellid = rrc_ptr->meas_cells.find_cell(reest_source_freq, reest_source_pci)->get_cell_id();
|
|
|
|
|
|
|
|
|
|
|
|
Info("Starting... cause: \"%s\", UE context: {C-RNTI=0x%x, PCI=%d, CELL ID=%d}",
|
|
|
|
Info("Starting... cause: \"%s\", UE context: {C-RNTI=0x%x, PCI=%d, CELL ID=%d}",
|
|
|
|
reest_cause == asn1::rrc::reest_cause_opts::recfg_fail
|
|
|
|
reest_cause == asn1::rrc::reest_cause_opts::recfg_fail ? "Reconfiguration failure"
|
|
|
|
? "Reconfiguration failure"
|
|
|
|
: cause == asn1::rrc::reest_cause_opts::ho_fail ? "Handover failure"
|
|
|
|
: cause == asn1::rrc::reest_cause_opts::ho_fail ? "Handover failure" : "Other failure",
|
|
|
|
: "Other failure",
|
|
|
|
reest_rnti,
|
|
|
|
reest_rnti,
|
|
|
|
reest_source_pci,
|
|
|
|
reest_source_pci,
|
|
|
|
reest_cellid);
|
|
|
|
reest_cellid);
|
|
|
|