diff options
author | Bodo Möller <bodo@openssl.org> | 2001-10-16 00:56:04 +0000 |
---|---|---|
committer | Bodo Möller <bodo@openssl.org> | 2001-10-16 00:56:04 +0000 |
commit | 9ba3ec91766e559f96248fe10c77551a4e017ec3 (patch) | |
tree | feadfa859bf7753cf616993a7e64e950b295f3dc /ssl/s23_srvr.c | |
parent | 8f71fb8d9817b7947c68ea93971eb8b6223ae40d (diff) |
The message header for fake SSL 3.0/TLS 1.0 client hellos created from
SSL 2.0 client hellos added with the previous commit was totally wrong --
it must start with the message type, not the protocol version.
(Not that this particular header is actually used anywhere ...)
Diffstat (limited to 'ssl/s23_srvr.c')
-rw-r--r-- | ssl/s23_srvr.c | 11 |
1 files changed, 5 insertions, 6 deletions
diff --git a/ssl/s23_srvr.c b/ssl/s23_srvr.c index 342d145c23..563531f120 100644 --- a/ssl/s23_srvr.c +++ b/ssl/s23_srvr.c @@ -365,12 +365,11 @@ int ssl23_get_client_hello(SSL *s) goto err; } - /* record header: version ... */ - *(d++) = SSL3_VERSION_MAJOR; /* == v[0] */ - *(d++) = v[1]; + /* record header: msg_type ... */ + *(d++) = SSL3_MT_CLIENT_HELLO; /* ... and length (actual value will be written later) */ - d_len = d++; - d++; + d_len = d; + d += 3; /* client_version */ *(d++) = SSL3_VERSION_MAJOR; /* == v[0] */ @@ -404,7 +403,7 @@ int ssl23_get_client_hello(SSL *s) *(d++)=0; i=(d-(unsigned char *)s->init_buf->data); - s2n(i, d_len); + l2n3((long)i, d_len); /* get the data reused from the init_buf */ s->s3->tmp.reuse_message=1; |