diff --git a/apps/s_cb.c b/apps/s_cb.c index 550969d704..e0d432dc75 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 1534a54f39..43340d4d49 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;