Fix problems when TA timer is set to infinity

master
David Rupprecht 6 years ago committed by Andre Puschmann
parent 22503541b1
commit a9032bb91a

@ -245,10 +245,11 @@ bool demux::process_ce(srslte::sch_subh *subh) {
case srslte::sch_subh::TA_CMD: case srslte::sch_subh::TA_CMD:
phy_h->set_timeadv(subh->get_ta_cmd()); phy_h->set_timeadv(subh->get_ta_cmd());
Info("Received TA=%d\n", subh->get_ta_cmd()); Info("Received TA=%d\n", subh->get_ta_cmd());
// Start or restart timeAlignmentTimer only if running
// Start or restart timeAlignmentTimer if (time_alignment_timer->is_running()) {
time_alignment_timer->reset(); time_alignment_timer->reset();
time_alignment_timer->run(); time_alignment_timer->run();
}
break; break;
case srslte::sch_subh::PADDING: case srslte::sch_subh::PADDING:
break; break;

@ -64,6 +64,10 @@ bool mac::init(phy_interface_mac *phy, rlc_interface_mac *rlc, rrc_interface_mac
timer_alignment = timers.get_unique_id(); timer_alignment = timers.get_unique_id();
contention_resolution_timer = timers.get_unique_id(); contention_resolution_timer = timers.get_unique_id();
log_h->debug("Timer Timing Alignment ID 0x%x\n", timer_alignment);
log_h->debug("Timer Contention Resolution ID 0x%x\n",
contention_resolution_timer);
bsr_procedure.init( rlc_h, log_h, &config, &timers); bsr_procedure.init( rlc_h, log_h, &config, &timers);
phr_procedure.init(phy_h, log_h, &config, &timers); phr_procedure.init(phy_h, log_h, &config, &timers);
mux_unit.init ( rlc_h, log_h, &bsr_procedure, &phr_procedure); mux_unit.init ( rlc_h, log_h, &bsr_procedure, &phr_procedure);
@ -364,9 +368,14 @@ void mac::setup_timers()
// stop currently running time alignment timer // stop currently running time alignment timer
if (timers.get(timer_alignment)->is_running()) { if (timers.get(timer_alignment)->is_running()) {
timers.get(timer_alignment)->stop(); timers.get(timer_alignment)->stop();
log_h->debug("Stop running MAC Time Alignment Timer with ID 0x%x\n",
timer_alignment);
} }
int value = liblte_rrc_time_alignment_timer_num[config.main.time_alignment_timer]; int value =
liblte_rrc_time_alignment_timer_num[config.main.time_alignment_timer];
log_h->info("Set MAC Time Alignment Timer (0x%x) to: %d value: %d \n",
timer_alignment, config.main.time_alignment_timer, value);
if (value > 0) { if (value > 0) {
timers.get(timer_alignment)->set(this, value); timers.get(timer_alignment)->set(this, value);
} }
@ -382,9 +391,11 @@ void mac::timer_expired(uint32_t timer_id)
} }
/* Function called on expiry of TimeAlignmentTimer */ /* Function called on expiry of TimeAlignmentTimer */
void mac::timer_alignment_expire() void mac::timer_alignment_expire() {
{ log_h->console("TimeAlignment timer has expired value=%d ms\n",
printf("TimeAlignment timer has expired value=%d ms\n", timers.get(timer_alignment)->get_timeout()); timers.get(timer_alignment)->get_timeout());
log_h->warning("TimeAlignment timer has expired value=%d ms\n",
timers.get(timer_alignment)->get_timeout());
rrc_h->release_pucch_srs(); rrc_h->release_pucch_srs();
dl_harq.reset(); dl_harq.reset();
ul_harq.reset(); ul_harq.reset();

@ -179,8 +179,11 @@ void ra_proc::process_timeadv_cmd(uint32_t ta) {
if (preambleIndex == 0) { if (preambleIndex == 0) {
// Preamble not selected by UE MAC // Preamble not selected by UE MAC
phy_h->set_timeadv_rar(ta); phy_h->set_timeadv_rar(ta);
// Only if timer is running reset the timer
if (time_alignment_timer->is_running()) {
time_alignment_timer->reset(); time_alignment_timer->reset();
time_alignment_timer->run(); time_alignment_timer->run();
}
Debug("Applying RAR TA CMD %d\n", ta); Debug("Applying RAR TA CMD %d\n", ta);
} else { } else {
// Preamble selected by UE MAC // Preamble selected by UE MAC

Loading…
Cancel
Save