diff options
author | Pauli <paul.dale@oracle.com> | 2017-07-26 02:04:05 +0200 |
---|---|---|
committer | Pauli <paul.dale@oracle.com> | 2017-07-26 02:04:05 +0200 |
commit | 0a3452520fe4cd6871ae8b7c4199c6d5d4efe912 (patch) | |
tree | c7d265c8420c1125f91e7c4f9fc6ebed38e6a0fe /apps/apps.c | |
parent | Wire SHA3 EVPs and add tests. (diff) | |
download | openssl-0a3452520fe4cd6871ae8b7c4199c6d5d4efe912.tar.xz openssl-0a3452520fe4cd6871ae8b7c4199c6d5d4efe912.zip |
Fix potential use-after-free and memory leak
In function wait_for_async(), allocated async fds is freed if
`SSL_get_all_async_fds` fails, but later `fds` is used. Interestingly,
it is not freed when everything succeeds.
Rewrite the FD set loop to make it more readable and to not modify the allocated
pointer so it can be freed.
Reviewed-by: Andy Polyakov <appro@openssl.org>
Reviewed-by: Paul Dale <paul.dale@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/3992)
Diffstat (limited to 'apps/apps.c')
-rw-r--r-- | apps/apps.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/apps/apps.c b/apps/apps.c index 4459be9c9b..ad386a116a 100644 --- a/apps/apps.c +++ b/apps/apps.c @@ -2614,6 +2614,7 @@ void wait_for_async(SSL *s) fd_set asyncfds; OSSL_ASYNC_FD *fds; size_t numfds; + size_t i; if (!SSL_get_all_async_fds(s, NULL, &numfds)) return; @@ -2622,17 +2623,17 @@ void wait_for_async(SSL *s) fds = app_malloc(sizeof(OSSL_ASYNC_FD) * numfds, "allocate async fds"); if (!SSL_get_all_async_fds(s, fds, &numfds)) { OPENSSL_free(fds); + return; } FD_ZERO(&asyncfds); - while (numfds > 0) { - if (width <= (int)*fds) - width = (int)*fds + 1; - openssl_fdset((int)*fds, &asyncfds); - numfds--; - fds++; + for (i = 0; i < numfds; i++) { + if (width <= (int)fds[i]) + width = (int)fds[i] + 1; + openssl_fdset((int)fds[i], &asyncfds); } select(width, (void *)&asyncfds, NULL, NULL, NULL); + OPENSSL_free(fds); #endif } |