|
|
@ -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());
|
|
|
|