From af66f4a9c22c6f0592a4103c275d4f0ba1b7233a Mon Sep 17 00:00:00 2001 From: John Safranek Date: Fri, 16 Aug 2024 14:58:43 -0700 Subject: [PATCH] Fixup 1. Initialize a local variable DoKexInit() as a compiler complains it is getting used with a garbage value. (Not true, but hushing the compiler.) 2. In GetInputText() add braces around the error check if clauses, and give the version error its own check instead of a ternary return. 3. In GetInputData(), if the recv return was anything else, return a general socket error. --- src/internal.c | 19 +++++++++++++------ 1 file changed, 13 insertions(+), 6 deletions(-) diff --git a/src/internal.c b/src/internal.c index 99f9a4574..3e7a978b8 100644 --- a/src/internal.c +++ b/src/internal.c @@ -3046,14 +3046,17 @@ static int GetInputText(WOLFSSH* ssh, byte** pEol) in = ReceiveData(ssh, ssh->inputBuffer.buffer + ssh->inputBuffer.length, inSz); - if (in == -1) + if (in == -1) { return WS_SOCKET_ERROR_E; + } - if (in == WS_WANT_READ) + if (in == WS_WANT_READ) { return WS_WANT_READ; + } - if (in > inSz) + if (in > inSz) { return WS_RECV_OVERFLOW_E; + } ssh->inputBuffer.length += in; inSz -= in; @@ -3077,7 +3080,11 @@ static int GetInputText(WOLFSSH* ssh, byte** pEol) if (pEol) *pEol = (byte*)eol; - return (gotLine ? WS_SUCCESS : WS_VERSION_E); + if (!gotLine) { + return WS_VERSION_E; + } + + return WS_SUCCESS; } @@ -3191,7 +3198,7 @@ static int GetInputData(WOLFSSH* ssh, word32 size) } else { /* all other unexpected negative values is a failure case */ - ssh->error = WS_FATAL_ERROR; + ssh->error = WS_SOCKET_ERROR_E; return WS_FATAL_ERROR; } @@ -3852,7 +3859,7 @@ static int DoKexInit(WOLFSSH* ssh, byte* buf, word32 len, word32* idx) word32 listSz; word32 cannedListSz; word32 cannedAlgoNamesSz; - word32 skipSz; + word32 skipSz = 0; word32 begin; WLOG(WS_LOG_DEBUG, "Entering DoKexInit()");