Skip to content

Commit

Permalink
Merge pull request #721 from lealem47/zd18257
Browse files Browse the repository at this point in the history
Don't exit wolfSSHd daemon on recoverable fcntl failure
  • Loading branch information
JacobBarthelmeh authored Jul 16, 2024
2 parents 0f9e873 + 5ea74bc commit 94ebc62
Showing 1 changed file with 21 additions and 6 deletions.
27 changes: 21 additions & 6 deletions apps/wolfsshd/wolfsshd.c
Original file line number Diff line number Diff line change
Expand Up @@ -2413,19 +2413,34 @@ static int StartSSHD(int argc, char** argv)
#ifdef USE_WINDOWS_API
unsigned long blocking = 1;
if (ioctlsocket(conn->fd, FIONBIO, &blocking)
== SOCKET_ERROR)
err_sys("ioctlsocket failed");
== SOCKET_ERROR) {
WLOG(WS_LOG_DEBUG, "wolfSSH non-fatal error: "
"ioctlsocket failed");
WCLOSESOCKET(conn->fd);
WFREE(conn, NULL, DYNTYPE_SSHD);
continue;
}
#elif defined(WOLFSSL_MDK_ARM) || defined(WOLFSSL_KEIL_TCP_NET) \
|| defined (WOLFSSL_TIRTOS)|| defined(WOLFSSL_VXWORKS) || \
defined(WOLFSSL_NUCLEUS)
/* non blocking not supported, for now */
#else
int flags = fcntl(conn->fd, F_GETFL, 0);
if (flags < 0)
err_sys("fcntl get failed");
if (flags < 0) {
WLOG(WS_LOG_DEBUG, "wolfSSH non-fatal error: "
"fcntl get failed");
WCLOSESOCKET(conn->fd);
WFREE(conn, NULL, DYNTYPE_SSHD);
continue;
}
flags = fcntl(conn->fd, F_SETFL, flags | O_NONBLOCK);
if (flags < 0)
err_sys("fcntl set failed");
if (flags < 0) {
WLOG(WS_LOG_DEBUG, "wolfSSH non-fatal error: "
"fcntl set failed");
WCLOSESOCKET(conn->fd);
WFREE(conn, NULL, DYNTYPE_SSHD);
continue;
}
#endif
}
ret = NewConnection(conn);
Expand Down

0 comments on commit 94ebc62

Please sign in to comment.