提交 d9f1c639 编写于 作者: M Matt Caswell

Change return type of the new accessors

The new accessors SSL_get_client_random, SSL_get_server_random and
SSL_SESSION_get_master_key should return a size_t to match the type of the
|outlen| parameter.
Reviewed-by: NRichard Levitte <levitte@openssl.org>
上级 6b8f5d0d
...@@ -8,9 +8,9 @@ SSL_get_client_random, SSL_get_server_random, SSL_SESSION_get_master_key - retri ...@@ -8,9 +8,9 @@ SSL_get_client_random, SSL_get_server_random, SSL_SESSION_get_master_key - retri
#include <openssl/ssl.h> #include <openssl/ssl.h>
int SSL_get_client_random(const SSL *ssl, unsigned char *out, size_t outlen); size_t SSL_get_client_random(const SSL *ssl, unsigned char *out, size_t outlen);
int SSL_get_server_random(const SSL *ssl, unsigned char *out, size_t outlen); size_t SSL_get_server_random(const SSL *ssl, unsigned char *out, size_t outlen);
int SSL_SESSION_get_master_key(const SSL_SESSION *session, unsigned char *out, size_t outlen); size_t SSL_SESSION_get_master_key(const SSL_SESSION *session, unsigned char *out, size_t outlen);
=head1 DESCRIPTION =head1 DESCRIPTION
...@@ -18,8 +18,8 @@ SSL_get_client_random() extracts the random value sent from the client ...@@ -18,8 +18,8 @@ SSL_get_client_random() extracts the random value sent from the client
to the server during the initial SSL/TLS handshake. It copies as many to the server during the initial SSL/TLS handshake. It copies as many
bytes as it can of this value into the buffer provided in B<out>, bytes as it can of this value into the buffer provided in B<out>,
which must have at least B<outlen> bytes available. It returns the which must have at least B<outlen> bytes available. It returns the
total number of bytes that were actually copied. If B<outlen> is less total number of bytes that were actually copied. If B<outlen> is
than zero, SSL_get_client_random() copies nothing, and returns the zero, SSL_get_client_random() copies nothing, and returns the
total size of the client_random value. total size of the client_random value.
SSL_get_server_random() behaves the same, but extracts the random value SSL_get_server_random() behaves the same, but extracts the random value
...@@ -63,10 +63,10 @@ values based on their view of the current time. ...@@ -63,10 +63,10 @@ values based on their view of the current time.
=head1 RETURN VALUES =head1 RETURN VALUES
If B<outlen> is at least 0, these functions return the number of bytes If B<outlen> is greater than 0, these functions return the number of bytes
actually copied, which will be less than or equal to B<outlen>. actually copied, which will be less than or equal to B<outlen>.
If B<outlen> is less than 0, these functions return the maximum number If B<outlen> is 0, these functions return the maximum number
of bytes they would copy--that is, the length of the underlying field. of bytes they would copy--that is, the length of the underlying field.
=head1 SEE ALSO =head1 SEE ALSO
......
...@@ -1652,11 +1652,11 @@ void SSL_set_state(SSL *ssl, int state); ...@@ -1652,11 +1652,11 @@ void SSL_set_state(SSL *ssl, int state);
void SSL_set_verify_result(SSL *ssl, long v); void SSL_set_verify_result(SSL *ssl, long v);
__owur long SSL_get_verify_result(const SSL *ssl); __owur long SSL_get_verify_result(const SSL *ssl);
__owur int SSL_get_client_random(const SSL *ssl, unsigned char *out, __owur size_t SSL_get_client_random(const SSL *ssl, unsigned char *out,
size_t outlen); size_t outlen);
__owur int SSL_get_server_random(const SSL *ssl, unsigned char *out, __owur size_t SSL_get_server_random(const SSL *ssl, unsigned char *out,
size_t outlen); size_t outlen);
__owur int SSL_SESSION_get_master_key(const SSL_SESSION *ssl, __owur size_t SSL_SESSION_get_master_key(const SSL_SESSION *ssl,
unsigned char *out, size_t outlen); unsigned char *out, size_t outlen);
__owur int SSL_set_ex_data(SSL *ssl, int idx, void *data); __owur int SSL_set_ex_data(SSL *ssl, int idx, void *data);
......
...@@ -2897,39 +2897,39 @@ long SSL_get_verify_result(const SSL *ssl) ...@@ -2897,39 +2897,39 @@ long SSL_get_verify_result(const SSL *ssl)
return (ssl->verify_result); return (ssl->verify_result);
} }
int SSL_get_client_random(const SSL *ssl, unsigned char *out, size_t outlen) size_t SSL_get_client_random(const SSL *ssl, unsigned char *out, size_t outlen)
{ {
if (outlen == 0) if (outlen == 0)
return sizeof(ssl->s3->client_random); return sizeof(ssl->s3->client_random);
if (outlen > sizeof(ssl->s3->client_random)) if (outlen > sizeof(ssl->s3->client_random))
outlen = sizeof(ssl->s3->client_random); outlen = sizeof(ssl->s3->client_random);
memcpy(out, ssl->s3->client_random, outlen); memcpy(out, ssl->s3->client_random, outlen);
return (outlen); return outlen;
} }
int SSL_get_server_random(const SSL *ssl, unsigned char *out, size_t outlen) size_t SSL_get_server_random(const SSL *ssl, unsigned char *out, size_t outlen)
{ {
if (outlen == 0) if (outlen == 0)
return sizeof(ssl->s3->server_random); return sizeof(ssl->s3->server_random);
if (outlen > sizeof(ssl->s3->server_random)) if (outlen > sizeof(ssl->s3->server_random))
outlen = sizeof(ssl->s3->server_random); outlen = sizeof(ssl->s3->server_random);
memcpy(out, ssl->s3->server_random, outlen); memcpy(out, ssl->s3->server_random, outlen);
return (outlen); return outlen;
} }
int SSL_SESSION_get_master_key(const SSL_SESSION *session, size_t SSL_SESSION_get_master_key(const SSL_SESSION *session,
unsigned char *out, size_t outlen) unsigned char *out, size_t outlen)
{ {
if (outlen == 0)
return session->master_key_length;
if (session->master_key_length < 0) { if (session->master_key_length < 0) {
/* Should never happen */ /* Should never happen */
return 0; return 0;
} }
if (outlen == 0)
return session->master_key_length;
if (outlen > (size_t)session->master_key_length) if (outlen > (size_t)session->master_key_length)
outlen = session->master_key_length; outlen = session->master_key_length;
memcpy(out, session->master_key, outlen); memcpy(out, session->master_key, outlen);
return (outlen); return outlen;
} }
int SSL_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, int SSL_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
......
...@@ -399,3 +399,7 @@ SSL_use_certificate_chain_file 433 EXIST::FUNCTION:STDIO ...@@ -399,3 +399,7 @@ SSL_use_certificate_chain_file 433 EXIST::FUNCTION:STDIO
TLS_server_method 434 EXIST::FUNCTION: TLS_server_method 434 EXIST::FUNCTION:
TLS_method 435 EXIST::FUNCTION: TLS_method 435 EXIST::FUNCTION:
TLS_client_method 436 EXIST::FUNCTION: TLS_client_method 436 EXIST::FUNCTION:
SSL_get_server_random 437 EXIST::FUNCTION:
SSL_get_client_ciphers 438 EXIST::FUNCTION:
SSL_get_client_random 439 EXIST::FUNCTION:
SSL_SESSION_get_master_key 440 EXIST::FUNCTION:
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册