From: Dr. Stephen Henson Date: Thu, 26 Jan 2017 14:40:59 +0000 (+0000) Subject: Support TLS 1.3 signature scheme names. X-Git-Tag: OpenSSL_1_1_1-pre1~2529 X-Git-Url: https://git.librecmc.org/?a=commitdiff_plain;h=8a43a42a02947fbff84378a9110a03f3eefeb48f;p=oweals%2Fopenssl.git Support TLS 1.3 signature scheme names. Reviewed-by: Richard Levitte Reviewed-by: Matt Caswell (Merged from https://github.com/openssl/openssl/pull/2301) --- diff --git a/ssl/t1_lib.c b/ssl/t1_lib.c index 0bc0a05c5d..fc10dc1b71 100644 --- a/ssl/t1_lib.c +++ b/ssl/t1_lib.c @@ -1750,7 +1750,7 @@ static int sig_cb(const char *elem, int len, void *arg) { sig_cb_st *sarg = arg; size_t i; - char etmp[20], *p; + char etmp[40], *p; int sig_alg = NID_undef, hash_alg = NID_undef; if (elem == NULL) return 0; @@ -1761,15 +1761,26 @@ static int sig_cb(const char *elem, int len, void *arg) memcpy(etmp, elem, len); etmp[len] = 0; p = strchr(etmp, '+'); - if (!p) - return 0; - *p = 0; - p++; - if (!*p) - return 0; - - get_sigorhash(&sig_alg, &hash_alg, etmp); - get_sigorhash(&sig_alg, &hash_alg, p); + /* See if we have a match for TLS 1.3 names */ + if (p == NULL) { + const SIGALG_LOOKUP *s; + + for (i = 0, s = sigalg_lookup_tbl; i < OSSL_NELEM(sigalg_lookup_tbl); + i++, s++) { + if (s->name != NULL && strcmp(etmp, s->name) == 0) { + sig_alg = s->sig; + hash_alg = s->hash; + break; + } + } + } else { + *p = 0; + p++; + if (*p == 0) + return 0; + get_sigorhash(&sig_alg, &hash_alg, etmp); + get_sigorhash(&sig_alg, &hash_alg, p); + } if (sig_alg == NID_undef || hash_alg == NID_undef) return 0;