From 845e49781f07882f063f9c444a490db362d6458b Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Moise=CC=81s=20Guimara=CC=83es?= Date: Fri, 17 Oct 2014 16:44:42 -0300 Subject: [PATCH] internal.c: refactoring DoServerHello to reduce stack usage: --- variable clSuites removed (sizeof(Suites) saved) ps.: TLSX_Parse() does not requires the suites parameter at client side. --- src/internal.c | 3 +-- src/tls.c | 2 +- 2 files changed, 2 insertions(+), 3 deletions(-) diff --git a/src/internal.c b/src/internal.c index 4ccda921a..85f817fe3 100644 --- a/src/internal.c +++ b/src/internal.c @@ -9275,7 +9275,6 @@ static void PickHashSigAlgo(CYASSL* ssl, if (TLSX_SupportExtensions(ssl)) { int ret = 0; word16 totalExtSz; - Suites clSuites; /* just for compatibility right now */ if ((i - begin) + OPAQUE16_LEN > helloSz) return BUFFER_ERROR; @@ -9287,7 +9286,7 @@ static void PickHashSigAlgo(CYASSL* ssl, return BUFFER_ERROR; if ((ret = TLSX_Parse(ssl, (byte *) input + i, - totalExtSz, 0, &clSuites))) + totalExtSz, 0, NULL))) return ret; i += totalExtSz; diff --git a/src/tls.c b/src/tls.c index 93e8dcf32..6b67711e6 100644 --- a/src/tls.c +++ b/src/tls.c @@ -2149,7 +2149,7 @@ int TLSX_Parse(CYASSL* ssl, byte* input, word16 length, byte isRequest, int ret = 0; word16 offset = 0; - if (!ssl || !input || !suites) + if (!ssl || !input || (isRequest && !suites)) return BAD_FUNC_ARG; while (ret == 0 && offset < length) {