-
Notifications
You must be signed in to change notification settings - Fork 24
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Add shutdown_socket()
function for follow up of #505
#506
base: main
Are you sure you want to change the base?
Conversation
shutdown_socket()
function.shutdown_socket()
function.
shutdown_socket()
function.shutdown_socket()
function for follow up of #505
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Very nice refactoring. Just left minor suggestions.
core/federated/RTI/rti_remote.c
Outdated
@@ -1030,9 +1009,7 @@ void send_reject(int* socket_id, unsigned char error_code) { | |||
lf_print_warning("RTI failed to write MSG_TYPE_REJECT message on the socket."); | |||
} | |||
// Close the socket. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Minor: how about adding more information for this call? For example, "Close the socket without reading until EOF."
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you, I fixed it as suggested.
core/federated/RTI/rti_remote.c
Outdated
@@ -1418,9 +1395,7 @@ void lf_connect_to_federates(int socket_descriptor) { | |||
if (!authenticate_federate(&socket_id)) { | |||
lf_print_warning("RTI failed to authenticate the incoming federate."); | |||
// Close the socket. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ditto.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you, I fixed it as suggested.
core/federated/RTI/rti_remote.c
Outdated
@@ -1488,8 +1463,7 @@ void* respond_to_erroneous_connections(void* nothing) { | |||
lf_print_warning("RTI failed to write FEDERATION_ID_DOES_NOT_MATCH to erroneous incoming connection."); | |||
} | |||
// Close the socket. |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Here as well.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Thank you, I fixed it as suggested.
The macOS test is not passing for some unknown reason. The CI test log seems to not work starting from The reason for not passing is that the program blocks on the final shutdown phase. First, this is how the LF code is intended to work.
This normally works on Linux, thus passing all tests. However, this fails on Mac. I also checked that the
The RTI(15045) is in This error can be reproduced by the lingua-franca's repo on branch @hokeun @edwardalee Could anyone help investigating this problem? |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Very nice and clean!
@edwardalee Would you please review this? |
LF_MUTEX_UNLOCK(&env->mutex); | ||
return -1; |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Please check description on PR.
core/federated/federate.c
Outdated
} | ||
close(_fed.sockets_for_inbound_p2p_connections[fed_id]); | ||
_fed.sockets_for_inbound_p2p_connections[fed_id] = -1; | ||
shutdown_socket(&_fed.sockets_for_inbound_p2p_connections[fed_id], true); |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
This changes logic to read()
the incoming bytes, then close()
. Please check PR descriptions.
This PR follow ups #505
New Integrated Function:
shutdown_socket()
int shutdown_socket(int* socket, bool read_before_closing);
Arguments
socket
: A pointer to the socket descriptor that needs to be shut down and closed.read_before_closing
: A boolean indicating whether the socket should read any remaining incoming data before closing:FIN
packet (SHUT_WR
) and waits forEOF
(0-length message) from the peer.SHUT_RDWR
).Return Values
0
: Indicates successful shutdown and closure of the socket.-1
: Indicates a failure during shutdown or closure, with errno set to describe the specific error.Function Description
This function gracefully shuts down and closes a socket.
shutdown(SHUT_RDWR)
to immediately stop both sending and receiving data. Then callsclose()
.shutdown(SHUT_WR)
to signal the end of writing but allows reading to continue.EOF
(indicated byread()
returning 0), and discards all received bytes.Refactoring on
close_inbound_socket()
andclose_outbound_socket()
fromfederate.c
close_inbound_socket()
The original code looked not updated. There were no use case when the argument
flag
was not 1. I removed theflag
argument, and all unused code.close_outbound_socket()
The original flags were only set by this one line code.
int flag = _lf_normal_termination ? 1 : -1;
So it depends on
_lf_normal_termination
. However, this function can directly use_lf_normal_termination
, so I removed theflag
, and directly used_lf_normal_termination
.Minor implementation details for macOS.
When the federate sends the
MSG_TYPE_RESIGN
signal, the RTI callsshutdown(SHUT_WR)
. Then, in the federate side, the thread fromlisten_to_rti_TCP()
'sread_from_netdrv()
'sread()
returns with a EOF. Then, it callsshutdown_socket()
.However, the
shutdown()
fails, with anerrno
Socket is not connected
. Even though the connection is half open, thisshutdown()
fails only on MacOS. However, since the connection is half closed, the federate should still send aFIN_ACK
packet to the RTI, because the RTI is blocked on theread()
.Thus, the federate does not return on failure of
shutdown()
, and calls theclose()
, to ensure theFIN_ACK
packet is sent.Minor addition of logic in
federate.c
'shandle_tagged_message()
In
federate.c
'shandle_tagged_message()
, when the received message already missed the tag, it closes the inbound socket, however does not return -1. This is added.