Don't call memcmp with a NULL pointer
authorMatt Caswell <matt@openssl.org>
Sat, 4 Mar 2017 23:58:03 +0000 (23:58 +0000)
committerMatt Caswell <matt@openssl.org>
Sat, 4 Mar 2017 23:58:03 +0000 (23:58 +0000)
If early data is sent to a server, but ALPN is not used then memcmp is
called with a NULL pointer which is undefined behaviour.

Fixes #2841

Reviewed-by: Kurt Roeckx <kurt@openssl.org>
(Merged from https://github.com/openssl/openssl/pull/2845)

ssl/statem/extensions.c

index 8c4013e416e87d26d3dfcfc24225e6e29f368e89..fab9bcb3d4367deea5b47861727457375ee9b6c7 100644 (file)
@@ -1252,8 +1252,9 @@ static int final_early_data(SSL *s, unsigned int context, int sent, int *al)
             || !s->ext.early_data_ok
             || s->hello_retry_request
             || s->s3->alpn_selected_len != s->session->ext.alpn_selected_len
-            || memcmp(s->s3->alpn_selected, s->session->ext.alpn_selected,
-                      s->s3->alpn_selected_len) != 0){
+            || (s->s3->alpn_selected_len > 0
+                && memcmp(s->s3->alpn_selected, s->session->ext.alpn_selected,
+                          s->s3->alpn_selected_len) != 0)) {
         s->ext.early_data = SSL_EARLY_DATA_REJECTED;
     } else {
         s->ext.early_data = SSL_EARLY_DATA_ACCEPTED;