|
|
@ -337,21 +337,22 @@ void nas::timer_expired(uint32_t timeout_id)
|
|
|
|
{
|
|
|
|
{
|
|
|
|
if (timeout_id == t3402.id()) {
|
|
|
|
if (timeout_id == t3402.id()) {
|
|
|
|
nas_log->info("Timer T3402 expired: trying to attach again\n");
|
|
|
|
nas_log->info("Timer T3402 expired: trying to attach again\n");
|
|
|
|
|
|
|
|
attach_attempt_counter = 0; // Sec. 5.5.1.1
|
|
|
|
start_attach_request(nullptr, srslte::establishment_cause_t::mo_sig);
|
|
|
|
start_attach_request(nullptr, srslte::establishment_cause_t::mo_sig);
|
|
|
|
} else if (timeout_id == t3410.id()) {
|
|
|
|
} else if (timeout_id == t3410.id()) {
|
|
|
|
// Section 5.5.1.2.6 case c)
|
|
|
|
// Section 5.5.1.2.6 case c)
|
|
|
|
attach_attempt_counter++;
|
|
|
|
attach_attempt_counter++;
|
|
|
|
|
|
|
|
|
|
|
|
nas_log->info("Timer T3410 expired after attach attempt %d/%d: starting T3411\n",
|
|
|
|
|
|
|
|
attach_attempt_counter,
|
|
|
|
|
|
|
|
max_attach_attempts);
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
if (attach_attempt_counter < max_attach_attempts) {
|
|
|
|
if (attach_attempt_counter < max_attach_attempts) {
|
|
|
|
|
|
|
|
nas_log->info("Timer T3410 expired after attach attempt %d/%d: starting T3411\n",
|
|
|
|
|
|
|
|
attach_attempt_counter,
|
|
|
|
|
|
|
|
max_attach_attempts);
|
|
|
|
|
|
|
|
|
|
|
|
// start T3411, ToDo: EMM-DEREGISTERED.ATTEMPTING-TO-ATTACH isn't fully implemented yet
|
|
|
|
// start T3411, ToDo: EMM-DEREGISTERED.ATTEMPTING-TO-ATTACH isn't fully implemented yet
|
|
|
|
t3411.run();
|
|
|
|
t3411.run();
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
|
// maximum attach attempts reached
|
|
|
|
// maximum attach attempts reached
|
|
|
|
enter_emm_deregistered();
|
|
|
|
nas_log->info("Timer T3410 expired. Maximum attempts reached. Starting T3402\n");
|
|
|
|
t3402.run();
|
|
|
|
t3402.run();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
} else if (timeout_id == t3411.id()) {
|
|
|
|
} else if (timeout_id == t3411.id()) {
|
|
|
@ -470,9 +471,8 @@ void nas::enter_emm_deregistered()
|
|
|
|
|
|
|
|
|
|
|
|
eps_bearer.clear();
|
|
|
|
eps_bearer.clear();
|
|
|
|
|
|
|
|
|
|
|
|
plmn_is_selected = false;
|
|
|
|
plmn_is_selected = false;
|
|
|
|
attach_attempt_counter = 0;
|
|
|
|
state = EMM_STATE_DEREGISTERED;
|
|
|
|
state = EMM_STATE_DEREGISTERED;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void nas::left_rrc_connected() {}
|
|
|
|
void nas::left_rrc_connected() {}
|
|
|
@ -541,6 +541,11 @@ void nas::select_plmn()
|
|
|
|
plmn_is_selected = true;
|
|
|
|
plmn_is_selected = true;
|
|
|
|
current_plmn = known_plmns[0];
|
|
|
|
current_plmn = known_plmns[0];
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// reset attach attempt counter (Sec. 5.2.2.3.4)
|
|
|
|
|
|
|
|
if (plmn_is_selected) {
|
|
|
|
|
|
|
|
attach_attempt_counter = 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void nas::write_pdu(uint32_t lcid, unique_byte_buffer_t pdu)
|
|
|
|
void nas::write_pdu(uint32_t lcid, unique_byte_buffer_t pdu)
|
|
|
@ -1151,6 +1156,8 @@ void nas::parse_attach_accept(uint32_t lcid, unique_byte_buffer_t pdu)
|
|
|
|
// bearer added successfully
|
|
|
|
// bearer added successfully
|
|
|
|
state = EMM_STATE_REGISTERED;
|
|
|
|
state = EMM_STATE_REGISTERED;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
attach_attempt_counter = 0; // reset according to 5.5.1.1
|
|
|
|
|
|
|
|
|
|
|
|
// send attach complete
|
|
|
|
// send attach complete
|
|
|
|
send_attach_complete(transaction_id, bearer.eps_bearer_id);
|
|
|
|
send_attach_complete(transaction_id, bearer.eps_bearer_id);
|
|
|
|
} else {
|
|
|
|
} else {
|
|
|
@ -1182,6 +1189,17 @@ void nas::parse_attach_reject(uint32_t lcid, unique_byte_buffer_t pdu)
|
|
|
|
t3410.stop();
|
|
|
|
t3410.stop();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
// Reset attach attempt counter according to 5.5.1.1
|
|
|
|
|
|
|
|
if (attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_PLMN_NOT_ALLOWED ||
|
|
|
|
|
|
|
|
attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_TRACKING_AREA_NOT_ALLOWED ||
|
|
|
|
|
|
|
|
attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_ROAMING_NOT_ALLOWED_IN_THIS_TRACKING_AREA ||
|
|
|
|
|
|
|
|
attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_EPS_SERVICES_NOT_ALLOWED_IN_THIS_PLMN ||
|
|
|
|
|
|
|
|
attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_NO_SUITABLE_CELLS_IN_TRACKING_AREA ||
|
|
|
|
|
|
|
|
attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_NOT_AUTHORIZED_FOR_THIS_CSG) {
|
|
|
|
|
|
|
|
// delete security context
|
|
|
|
|
|
|
|
attach_attempt_counter = 0;
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
// 5.5.1.2.5
|
|
|
|
// 5.5.1.2.5
|
|
|
|
if (attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_ILLEGAL_UE ||
|
|
|
|
if (attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_ILLEGAL_UE ||
|
|
|
|
attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_ILLEGAL_ME ||
|
|
|
|
attach_rej.emm_cause == LIBLTE_MME_EMM_CAUSE_ILLEGAL_ME ||
|
|
|
@ -1865,6 +1883,7 @@ void nas::send_detach_request(bool switch_off)
|
|
|
|
state = EMM_STATE_DEREGISTERED_INITIATED;
|
|
|
|
state = EMM_STATE_DEREGISTERED_INITIATED;
|
|
|
|
|
|
|
|
|
|
|
|
// start T3421
|
|
|
|
// start T3421
|
|
|
|
|
|
|
|
nas_log->info("Starting T3421\n");
|
|
|
|
t3421.run();
|
|
|
|
t3421.run();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|