summaryrefslogtreecommitdiffstats
path: root/lib/libssl/ssl_clnt.c
diff options
context:
space:
mode:
authorjsing <jsing@openbsd.org>2018-06-03 15:31:30 +0000
committerjsing <jsing@openbsd.org>2018-06-03 15:31:30 +0000
commitb9683bd66a78a30cf973ed771176dd02049fade2 (patch)
tree6317e39416430014adfbc1f3aec456ff8b37fa28 /lib/libssl/ssl_clnt.c
parentImplement process-shared futexes. These are now the default implementation. (diff)
downloadwireguard-openbsd-b9683bd66a78a30cf973ed771176dd02049fade2.tar.xz
wireguard-openbsd-b9683bd66a78a30cf973ed771176dd02049fade2.zip
Check the return value from DH_size() in ssl3_send_client_kex_dhe().
ok beck@ inoguchi@
Diffstat (limited to 'lib/libssl/ssl_clnt.c')
-rw-r--r--lib/libssl/ssl_clnt.c10
1 files changed, 6 insertions, 4 deletions
diff --git a/lib/libssl/ssl_clnt.c b/lib/libssl/ssl_clnt.c
index e189c82fdd2..a4d0d048bde 100644
--- a/lib/libssl/ssl_clnt.c
+++ b/lib/libssl/ssl_clnt.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: ssl_clnt.c,v 1.25 2018/05/13 17:31:06 jsing Exp $ */
+/* $OpenBSD: ssl_clnt.c,v 1.26 2018/06/03 15:31:30 jsing Exp $ */
/* Copyright (C) 1995-1998 Eric Young (eay@cryptsoft.com)
* All rights reserved.
*
@@ -2049,13 +2049,15 @@ ssl3_send_client_kex_dhe(SSL *s, SESS_CERT *sess_cert, CBB *cbb)
SSLerror(s, ERR_R_DH_LIB);
goto err;
}
- key_size = DH_size(dh_clnt);
+ if ((key_size = DH_size(dh_clnt)) <= 0) {
+ SSLerror(s, ERR_R_DH_LIB);
+ goto err;
+ }
if ((key = malloc(key_size)) == NULL) {
SSLerror(s, ERR_R_MALLOC_FAILURE);
goto err;
}
- key_len = DH_compute_key(key, dh_srvr->pub_key, dh_clnt);
- if (key_len <= 0) {
+ if ((key_len = DH_compute_key(key, dh_srvr->pub_key, dh_clnt)) <= 0) {
SSLerror(s, ERR_R_DH_LIB);
goto err;
}