Trigger switch_off in NAS

This commit is contained in:
Bedran Karakoc 2021-09-23 02:31:47 +02:00 committed by Bedran Karakoc
parent 441251bdd1
commit 193ec4abfa
2 changed files with 20 additions and 9 deletions

View File

@ -131,7 +131,7 @@ private:
int send_pdu_session_establishment_request(uint32_t transaction_identity, int send_pdu_session_establishment_request(uint32_t transaction_identity,
uint16_t pdu_session_id, uint16_t pdu_session_id,
const pdu_session_cfg_t& pdu_session); const pdu_session_cfg_t& pdu_session);
int send_deregistration_request_ue_originating(); int send_deregistration_request_ue_originating(bool switch_off);
int send_identity_response(srsran::nas_5g::identity_type_5gs_t::identity_types_::options requested_identity_type); int send_identity_response(srsran::nas_5g::identity_type_5gs_t::identity_types_::options requested_identity_type);
void fill_security_caps(srsran::nas_5g::ue_security_capability_t& sec_caps); void fill_security_caps(srsran::nas_5g::ue_security_capability_t& sec_caps);

View File

@ -24,7 +24,6 @@
#include <fstream> #include <fstream>
#include <iomanip> #include <iomanip>
#include <iostream>
#include <unistd.h> #include <unistd.h>
#define MAC_5G_OFFSET 2 #define MAC_5G_OFFSET 2
@ -135,8 +134,6 @@ void nas_5g::run_tti()
case mm5g_state_t::state_t::registered: case mm5g_state_t::state_t::registered:
break; break;
case mm5g_state_t::state_t::deregistered_initiated: case mm5g_state_t::state_t::deregistered_initiated:
logger.debug("UE detaching...");
send_deregistration_request_ue_originating();
break; break;
default: default:
break; break;
@ -592,7 +589,7 @@ int nas_5g::send_pdu_session_establishment_request(uint32_t tran
return SRSRAN_SUCCESS; return SRSRAN_SUCCESS;
} }
int nas_5g::send_deregistration_request_ue_originating() int nas_5g::send_deregistration_request_ue_originating(bool switch_off)
{ {
unique_byte_buffer_t pdu = srsran::make_byte_buffer(); unique_byte_buffer_t pdu = srsran::make_byte_buffer();
if (!pdu) { if (!pdu) {
@ -607,13 +604,22 @@ int nas_5g::send_deregistration_request_ue_originating()
// Note 5.5.2.2.2 : AMF does not send a Deregistration Accept NAS message if De-registration type IE indicates "switch // Note 5.5.2.2.2 : AMF does not send a Deregistration Accept NAS message if De-registration type IE indicates "switch
// off" // off"
if (switch_off) {
deregistration_request.de_registration_type.switch_off.value =
de_registration_type_t::switch_off_type_::options::switch_off;
state.set_deregistered(mm5g_state_t::deregistered_substate_t::null);
} else {
deregistration_request.de_registration_type.switch_off.value = deregistration_request.de_registration_type.switch_off.value =
de_registration_type_t::switch_off_type_::options::normal_de_registration; de_registration_type_t::switch_off_type_::options::normal_de_registration;
// In this case we need to wait for the response by the core
state.set_deregistered_initiated();
}
mobile_identity_5gs_t::suci_s& suci = deregistration_request.mobile_identity_5gs.set_suci(); mobile_identity_5gs_t::suci_s& suci = deregistration_request.mobile_identity_5gs.set_suci();
suci.supi_format = mobile_identity_5gs_t::suci_s::supi_format_type_::options::imsi; suci.supi_format = mobile_identity_5gs_t::suci_s::supi_format_type_::options::imsi;
usim->get_home_mcc_bytes(suci.mcc.data(), suci.mcc.size()); usim->get_home_mcc_bytes(suci.mcc.data(), suci.mcc.size());
usim->get_home_mnc_bytes(suci.mnc.data(), suci.mnc.size()); usim->get_home_mnc_bytes(suci.mnc.data(), suci.mnc.size());
suci.scheme_output.resize(5);
deregistration_request.ng_ksi.nas_key_set_identifier.value = deregistration_request.ng_ksi.nas_key_set_identifier.value =
key_set_identifier_t::nas_key_set_identifier_type_::options::no_key_is_available_or_reserved; key_set_identifier_t::nas_key_set_identifier_type_::options::no_key_is_available_or_reserved;
@ -924,7 +930,12 @@ int nas_5g::handle_n1_sm_information(std::vector<uint8_t> payload_container_cont
int nas_5g::handle_deregistration_accept_ue_originating( int nas_5g::handle_deregistration_accept_ue_originating(
srsran::nas_5g::deregistration_accept_ue_originating_t& deregistration_accept_ue_originating) srsran::nas_5g::deregistration_accept_ue_originating_t& deregistration_accept_ue_originating)
{ {
logger.info("Received Deregistration Request (UE Originating)"); logger.info("Received Deregistration Accept (UE Originating)");
if (state.get_state() != mm5g_state_t::state_t::deregistered_initiated) {
logger.warning("Received deregistration accept while not in deregistered initiated state");
}
state.set_deregistered(mm5g_state_t::deregistered_substate_t::null);
return SRSASN_SUCCESS; return SRSASN_SUCCESS;
} }
@ -954,7 +965,7 @@ int nas_5g::switch_on()
int nas_5g::switch_off() int nas_5g::switch_off()
{ {
logger.info("Switching off"); logger.info("Switching off");
state.set_deregistered_initiated(); send_deregistration_request_ue_originating(true);
return SRSRAN_SUCCESS; return SRSRAN_SUCCESS;
} }