diff --git a/apps/s_cb.c b/apps/s_cb.c index 550969d70495d9ad82d92d2df14a5c26cf0b9751..e0d432dc75586c16a32280da9cdd941e1ac58f19 100644 --- a/apps/s_cb.c +++ b/apps/s_cb.c @@ -239,7 +239,7 @@ static int do_print_sigalgs(BIO *out, SSL *s, int shared) int i, nsig, client; client = SSL_is_server(s) ? 0 : 1; if (shared) - nsig = SSL_get_shared_sigalgs(s, -1, NULL, NULL, NULL, NULL, NULL); + nsig = SSL_get_shared_sigalgs(s, 0, NULL, NULL, NULL, NULL, NULL); else nsig = SSL_get_sigalgs(s, -1, NULL, NULL, NULL, NULL, NULL); if (nsig == 0) diff --git a/ssl/t1_lib.c b/ssl/t1_lib.c index 1534a54f39fab8382fd9de63fde670148b398be3..43340d4d49f272eb37ff1a261dadc481e2b139c9 100644 --- a/ssl/t1_lib.c +++ b/ssl/t1_lib.c @@ -1684,6 +1684,7 @@ int SSL_get_shared_sigalgs(SSL *s, int idx, { const SIGALG_LOOKUP *shsigalgs; if (s->cert->shared_sigalgs == NULL + || idx < 0 || idx >= (int)s->cert->shared_sigalgslen || s->cert->shared_sigalgslen > INT_MAX) return 0;