From 612fcfbd290d4dba96945c7c5bc8ea0c75ffefa1 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Bodo=20M=C3=B6ller?= Date: Mon, 5 Sep 2011 13:31:17 +0000 Subject: [PATCH] Fix d2i_SSL_SESSION. --- CHANGES | 3 +++ crypto/bn/bn_gf2m.c | 2 +- ssl/ssl.h | 10 ++++++---- ssl/ssl_asn1.c | 13 +++++++++++++ 4 files changed, 23 insertions(+), 5 deletions(-) diff --git a/CHANGES b/CHANGES index e68cc7b3c1..eb4f58d6dd 100644 --- a/CHANGES +++ b/CHANGES @@ -258,6 +258,9 @@ Changes between 1.0.0e and 1.0.1 [xx XXX xxxx] + *) Fix PSK session representation. + [Bodo Moeller] + *) Add RC4-MD5 and AESNI-SHA1 "stitched" implementations. This work was sponsored by Intel. diff --git a/crypto/bn/bn_gf2m.c b/crypto/bn/bn_gf2m.c index d0e03f87da..55a4d1a189 100644 --- a/crypto/bn/bn_gf2m.c +++ b/crypto/bn/bn_gf2m.c @@ -541,7 +541,7 @@ int BN_GF2m_mod_inv(BIGNUM *r, const BIGNUM *a, const BIGNUM *p, BN_CTX *ctx) if (BN_is_zero(u)) goto err; if (!BN_copy(v, p)) goto err; -#if 0 +#if 1 if (!BN_one(b)) goto err; while (1) diff --git a/ssl/ssl.h b/ssl/ssl.h index 871327d42a..7e3fa04835 100644 --- a/ssl/ssl.h +++ b/ssl/ssl.h @@ -447,10 +447,12 @@ struct ssl_method_st * Session_ID_context [ 4 ] EXPLICIT OCTET STRING, -- the Session ID context * Verify_result [ 5 ] EXPLICIT INTEGER, -- X509_V_... code for `Peer' * HostName [ 6 ] EXPLICIT OCTET STRING, -- optional HostName from servername TLS extension - * ECPointFormatList [ 7 ] OCTET STRING, -- optional EC point format list from TLS extension - * PSK_identity_hint [ 8 ] EXPLICIT OCTET STRING, -- optional PSK identity hint - * PSK_identity [ 9 ] EXPLICIT OCTET STRING -- optional PSK identity - * SRP_username [ 11 ] EXPLICIT OCTET STRING -- optional SRP username + * PSK_identity_hint [ 7 ] EXPLICIT OCTET STRING, -- optional PSK identity hint + * PSK_identity [ 8 ] EXPLICIT OCTET STRING, -- optional PSK identity + * Ticket_lifetime_hint [9] EXPLICIT INTEGER, -- server's lifetime hint for session ticket + * Ticket [10] EXPLICIT OCTET STRING, -- session ticket (clients only) + * Compression_meth [11] EXPLICIT OCTET STRING, -- optional compression method + * SRP_username [ 12 ] EXPLICIT OCTET STRING -- optional SRP username * } * Look in ssl/ssl_asn1.c for more details * I'm using EXPLICIT tags so I can read the damn things using asn1parse :-). diff --git a/ssl/ssl_asn1.c b/ssl/ssl_asn1.c index d02c3af53b..8fa8c669b1 100644 --- a/ssl/ssl_asn1.c +++ b/ssl/ssl_asn1.c @@ -572,6 +572,19 @@ SSL_SESSION *d2i_SSL_SESSION(SSL_SESSION **a, const unsigned char **pp, } else ret->psk_identity_hint=NULL; + + os.length=0; + os.data=NULL; + M_ASN1_D2I_get_EXP_opt(osp,d2i_ASN1_OCTET_STRING,8); + if (os.data) + { + ret->psk_identity = BUF_strndup((char *)os.data, os.length); + OPENSSL_free(os.data); + os.data = NULL; + os.length = 0; + } + else + ret->psk_identity=NULL; #endif /* OPENSSL_NO_PSK */ #ifndef OPENSSL_NO_TLSEXT -- 2.40.0