提交 b7727ee6 编写于 作者: G Geoff Thorpe

The indexes returned by ***_get_ex_new_index() functions are used when

setting stack (actually, array) values in ex_data. So only increment the
global counters if the underlying CRYPTO_get_ex_new_index() call succeeds.
This change doesn't make "ex_data" right (see the comment at the head of
ex_data.c to know why), but at least makes the source code marginally less
frustrating.
上级 f0446ca8
...@@ -142,9 +142,10 @@ ASN1_METHOD *X509_asn1_meth(void) ...@@ -142,9 +142,10 @@ ASN1_METHOD *X509_asn1_meth(void)
int X509_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, int X509_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func)
{ {
x509_meth_num++; if(CRYPTO_get_ex_new_index(x509_meth_num, &x509_meth, argl, argp,
return(CRYPTO_get_ex_new_index(x509_meth_num-1, new_func, dup_func, free_func) < 0)
&x509_meth,argl,argp,new_func,dup_func,free_func)); return -1;
return (x509_meth_num++);
} }
int X509_set_ex_data(X509 *r, int idx, void *arg) int X509_set_ex_data(X509 *r, int idx, void *arg)
......
...@@ -512,9 +512,10 @@ void BIO_copy_next_retry(BIO *b) ...@@ -512,9 +512,10 @@ void BIO_copy_next_retry(BIO *b)
int BIO_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, int BIO_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func)
{ {
bio_meth_num++; if(CRYPTO_get_ex_new_index(bio_meth_num, &bio_meth, argl, argp,
return(CRYPTO_get_ex_new_index(bio_meth_num-1,&bio_meth, new_func, dup_func, free_func) < 0)
argl,argp,new_func,dup_func,free_func)); return -1;
return (bio_meth_num++);
} }
int BIO_set_ex_data(BIO *bio, int idx, void *data) int BIO_set_ex_data(BIO *bio, int idx, void *data)
......
...@@ -222,9 +222,10 @@ void DH_free(DH *r) ...@@ -222,9 +222,10 @@ void DH_free(DH *r)
int DH_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, int DH_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func)
{ {
dh_meth_num++; if(CRYPTO_get_ex_new_index(dh_meth_num, &dh_meth, argl, argp,
return(CRYPTO_get_ex_new_index(dh_meth_num-1, new_func, dup_func, free_func) < 0)
&dh_meth,argl,argp,new_func,dup_func,free_func)); return -1;
return (dh_meth_num++);
} }
int DH_set_ex_data(DH *d, int idx, void *arg) int DH_set_ex_data(DH *d, int idx, void *arg)
......
...@@ -250,9 +250,10 @@ int DSA_size(const DSA *r) ...@@ -250,9 +250,10 @@ int DSA_size(const DSA *r)
int DSA_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, int DSA_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func)
{ {
dsa_meth_num++; if(CRYPTO_get_ex_new_index(dsa_meth_num, &dsa_meth, argl, argp,
return(CRYPTO_get_ex_new_index(dsa_meth_num-1, new_func, dup_func, free_func) < 0)
&dsa_meth,argl,argp,new_func,dup_func,free_func)); return -1;
return (dsa_meth_num++);
} }
int DSA_set_ex_data(DSA *d, int idx, void *arg) int DSA_set_ex_data(DSA *d, int idx, void *arg)
......
...@@ -251,9 +251,10 @@ void RSA_free(RSA *r) ...@@ -251,9 +251,10 @@ void RSA_free(RSA *r)
int RSA_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, int RSA_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func)
{ {
rsa_meth_num++; if(CRYPTO_get_ex_new_index(rsa_meth_num, &rsa_meth, argl, argp,
return(CRYPTO_get_ex_new_index(rsa_meth_num-1, new_func, dup_func, free_func) < 0)
&rsa_meth,argl,argp,new_func,dup_func,free_func)); return -1;
return (rsa_meth_num++);
} }
int RSA_set_ex_data(RSA *r, int idx, void *arg) int RSA_set_ex_data(RSA *r, int idx, void *arg)
......
...@@ -574,9 +574,10 @@ int UI_ctrl(UI *ui, int cmd, long i, void *p, void (*f)()) ...@@ -574,9 +574,10 @@ int UI_ctrl(UI *ui, int cmd, long i, void *p, void (*f)())
int UI_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, int UI_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func)
{ {
ui_meth_num++; if(CRYPTO_get_ex_new_index(ui_meth_num, &ui_meth, argl, argp,
return(CRYPTO_get_ex_new_index(ui_meth_num-1, new_func, dup_func, free_func) < 0)
&ui_meth,argl,argp,new_func,dup_func,free_func)); return -1;
return (ui_meth_num++);
} }
int UI_set_ex_data(UI *r, int idx, void *arg) int UI_set_ex_data(UI *r, int idx, void *arg)
......
...@@ -895,10 +895,10 @@ int X509_STORE_CTX_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_fu ...@@ -895,10 +895,10 @@ int X509_STORE_CTX_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_fu
* That function uses locking, so we don't (usually) * That function uses locking, so we don't (usually)
* have to worry about locking here. For the whole cruel * have to worry about locking here. For the whole cruel
* truth, see crypto/ex_data.c */ * truth, see crypto/ex_data.c */
x509_store_ctx_num++; if(CRYPTO_get_ex_new_index(x509_store_ctx_num, &x509_store_ctx_method,
return CRYPTO_get_ex_new_index(x509_store_ctx_num-1, argl, argp, new_func, dup_func, free_func) < 0)
&x509_store_ctx_method, return -1;
argl,argp,new_func,dup_func,free_func); return (x509_store_ctx_num++);
} }
int X509_STORE_CTX_set_ex_data(X509_STORE_CTX *ctx, int idx, void *data) int X509_STORE_CTX_set_ex_data(X509_STORE_CTX *ctx, int idx, void *data)
......
...@@ -2051,9 +2051,10 @@ long SSL_get_verify_result(SSL *ssl) ...@@ -2051,9 +2051,10 @@ long SSL_get_verify_result(SSL *ssl)
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,
CRYPTO_EX_dup *dup_func,CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func,CRYPTO_EX_free *free_func)
{ {
ssl_meth_num++; if(CRYPTO_get_ex_new_index(ssl_meth_num, &ssl_meth, argl, argp,
return(CRYPTO_get_ex_new_index(ssl_meth_num-1, new_func, dup_func, free_func) < 0)
&ssl_meth,argl,argp,new_func,dup_func,free_func)); return -1;
return (ssl_meth_num++);
} }
int SSL_set_ex_data(SSL *s,int idx,void *arg) int SSL_set_ex_data(SSL *s,int idx,void *arg)
...@@ -2069,9 +2070,10 @@ void *SSL_get_ex_data(SSL *s,int idx) ...@@ -2069,9 +2070,10 @@ void *SSL_get_ex_data(SSL *s,int idx)
int SSL_CTX_get_ex_new_index(long argl,void *argp,CRYPTO_EX_new *new_func, int SSL_CTX_get_ex_new_index(long argl,void *argp,CRYPTO_EX_new *new_func,
CRYPTO_EX_dup *dup_func,CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func,CRYPTO_EX_free *free_func)
{ {
ssl_ctx_meth_num++; if(CRYPTO_get_ex_new_index(ssl_ctx_meth_num, &ssl_ctx_meth, argl, argp,
return(CRYPTO_get_ex_new_index(ssl_ctx_meth_num-1, new_func, dup_func, free_func) < 0)
&ssl_ctx_meth,argl,argp,new_func,dup_func,free_func)); return -1;
return (ssl_ctx_meth_num++);
} }
int SSL_CTX_set_ex_data(SSL_CTX *s,int idx,void *arg) int SSL_CTX_set_ex_data(SSL_CTX *s,int idx,void *arg)
......
...@@ -91,10 +91,10 @@ SSL_SESSION *SSL_get1_session(SSL *ssl) ...@@ -91,10 +91,10 @@ SSL_SESSION *SSL_get1_session(SSL *ssl)
int SSL_SESSION_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func, int SSL_SESSION_get_ex_new_index(long argl, void *argp, CRYPTO_EX_new *new_func,
CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func) CRYPTO_EX_dup *dup_func, CRYPTO_EX_free *free_func)
{ {
ssl_session_num++; if(CRYPTO_get_ex_new_index(ssl_session_num, &ssl_session_meth, argl,
return(CRYPTO_get_ex_new_index(ssl_session_num-1, argp, new_func, dup_func, free_func) < 0)
&ssl_session_meth, return -1;
argl,argp,new_func,dup_func,free_func)); return (ssl_session_num++);
} }
int SSL_SESSION_set_ex_data(SSL_SESSION *s, int idx, void *arg) int SSL_SESSION_set_ex_data(SSL_SESSION *s, int idx, void *arg)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册