Make sure that S1 Setup request is restarted regardless of which error made the procedure fail.

master
Pedro Alvarez 4 years ago
parent 8c4ed489e8
commit dde8157bf1

@ -474,14 +474,7 @@ public:
bool ret = true; bool ret = true;
pdu->N_bytes = static_cast<uint32_t>(n_recv); pdu->N_bytes = static_cast<uint32_t>(n_recv);
if (flags & MSG_NOTIFICATION) { // SCTP notifications handled in callback.
// Received notification
union sctp_notification* notification = (union sctp_notification*)pdu->msg;
if (notification->sn_header.sn_type == SCTP_SHUTDOWN_EVENT) {
// Socket Shutdown
ret = false;
}
}
func(std::move(pdu), from, sri, flags); func(std::move(pdu), from, sri, flags);
return ret; return ret;
} }

@ -174,11 +174,7 @@ srslte::proc_outcome_t s1ap::s1_setup_proc_t::start_mme_connection()
} }
if (not s1ap_ptr->connect_mme()) { if (not s1ap_ptr->connect_mme()) {
procInfo("Failed to initiate SCTP socket. Attempting reconnection in %d seconds", procInfo("Could not connect to MME");
s1ap_ptr->mme_connect_timer.duration() / 1000);
srslte::console("Failed to initiate SCTP socket. Attempting reconnection in %d seconds\n",
s1ap_ptr->mme_connect_timer.duration() / 1000);
s1ap_ptr->mme_connect_timer.run();
return srslte::proc_outcome_t::error; return srslte::proc_outcome_t::error;
} }
@ -203,7 +199,7 @@ srslte::proc_outcome_t s1ap::s1_setup_proc_t::react(const srsenb::s1ap::s1_setup
procInfo("S1Setup procedure completed successfully"); procInfo("S1Setup procedure completed successfully");
return srslte::proc_outcome_t::success; return srslte::proc_outcome_t::success;
} }
procError("S1Setup failed. Exiting..."); procError("S1Setup failed.");
srslte::console("S1setup failed\n"); srslte::console("S1setup failed\n");
return srslte::proc_outcome_t::error; return srslte::proc_outcome_t::error;
} }
@ -211,8 +207,15 @@ srslte::proc_outcome_t s1ap::s1_setup_proc_t::react(const srsenb::s1ap::s1_setup
void s1ap::s1_setup_proc_t::then(const srslte::proc_state_t& result) const void s1ap::s1_setup_proc_t::then(const srslte::proc_state_t& result) const
{ {
if (result.is_error()) { if (result.is_error()) {
procInfo("Failed to initiate S1 connection. Attempting reconnection in %d seconds",
s1ap_ptr->mme_connect_timer.duration() / 1000);
srslte::console("Failed to initiate S1 connection. Attempting reconnection in %d seconds\n",
s1ap_ptr->mme_connect_timer.duration() / 1000);
s1ap_ptr->mme_connect_timer.run();
s1ap_ptr->stack->remove_mme_socket(s1ap_ptr->s1ap_socket.get_socket());
s1ap_ptr->s1ap_socket.reset(); s1ap_ptr->s1ap_socket.reset();
procInfo("S1AP socket closed."); procInfo("S1AP socket closed.");
// Try again with in 10 seconds
} }
} }
@ -429,11 +432,13 @@ bool s1ap::connect_mme()
&s1ap_socket, srslte::net_utils::socket_type::seqpacket, args.s1c_bind_addr.c_str())) { &s1ap_socket, srslte::net_utils::socket_type::seqpacket, args.s1c_bind_addr.c_str())) {
return false; return false;
} }
logger.info("SCTP socket opened. fd=%d", s1ap_socket.fd());
// Connect to the MME address // Connect to the MME address
if (not s1ap_socket.connect_to(args.mme_addr.c_str(), MME_PORT, &mme_addr)) { if (not s1ap_socket.connect_to(args.mme_addr.c_str(), MME_PORT, &mme_addr)) {
return false; return false;
} }
logger.info("SCTP socket connected with MME. fd=%d", s1ap_socket.fd());
// Assign a handler to rx MME packets (going to run in a different thread) // Assign a handler to rx MME packets (going to run in a different thread)
stack->add_mme_socket(s1ap_socket.fd()); stack->add_mme_socket(s1ap_socket.fd());

Loading…
Cancel
Save