Fix the DTLS1_COOKIE_LENGTH value
authorMatt Caswell <matt@openssl.org>
Wed, 17 Jun 2020 10:34:49 +0000 (11:34 +0100)
committerMatt Caswell <matt@openssl.org>
Fri, 19 Jun 2020 10:25:35 +0000 (11:25 +0100)
The DTLS1_COOKIE_LENGTH value was incorrect in the header files. We
couldn't change it before due to ABI concerns. However 3.0 is not ABI
compatible so we can now fix it.

Reviewed-by: Paul Dale <paul.dale@oracle.com>
(Merged from https://github.com/openssl/openssl/pull/12179)

include/openssl/dtls1.h
ssl/statem/statem_srvr.c

index bfc2d6e38f2857bc1fccd120290328e3e0095839..a68cffd1d4eb03121fa5d84ddeef95ff8dc779be 100644 (file)
@@ -36,11 +36,8 @@ extern "C" {
 # define DTLS_ANY_VERSION                0x1FFFF
 
 /* lengths of messages */
-/*
- * Actually the max cookie length in DTLS is 255. But we can't change this now
- * due to compatibility concerns.
- */
-# define DTLS1_COOKIE_LENGTH                     256
+
+# define DTLS1_COOKIE_LENGTH                     255
 
 # define DTLS1_RT_HEADER_LENGTH                  13
 
index d3913e1b7d40af097245af62a2da1ff19fbc52b9..abffbd6326afaf78f565647eef593ef91a35e49b 100644 (file)
@@ -1312,7 +1312,7 @@ int dtls_construct_hello_verify_request(SSL *s, WPACKET *pkt)
     if (s->ctx->app_gen_cookie_cb == NULL ||
         s->ctx->app_gen_cookie_cb(s, s->d1->cookie,
                                   &cookie_leni) == 0 ||
-        cookie_leni > 255) {
+        cookie_leni > DTLS1_COOKIE_LENGTH) {
         SSLfatal(s, SSL_AD_NO_ALERT, SSL_F_DTLS_CONSTRUCT_HELLO_VERIFY_REQUEST,
                  SSL_R_COOKIE_GEN_CALLBACK_FAILURE);
         return 0;