[openssl-commits] [openssl] master update
Richard Levitte
levitte at openssl.org
Fri Dec 14 22:16:33 UTC 2018
The branch master has been updated
via 91c5473035aaf2c0d86e4039c2a29a5b70541905 (commit)
from 9a3b5b766421b7ed9df859956d44fcbe52c2dd82 (commit)
- Log -----------------------------------------------------------------
commit 91c5473035aaf2c0d86e4039c2a29a5b70541905
Author: Richard Levitte <levitte at openssl.org>
Date: Fri Dec 14 19:33:55 2018 +0100
ERR: preserve system error number in a few more places
It turns out that intialization may change the error number, so we
need to preserve the system error number in functions where
initialization is called for.
These are ERR_get_state() and err_shelve_state()
Fixes #7897
Reviewed-by: Matt Caswell <matt at openssl.org>
(Merged from https://github.com/openssl/openssl/pull/7902)
-----------------------------------------------------------------------
Summary of changes:
crypto/err/err.c | 5 +++++
1 file changed, 5 insertions(+)
diff --git a/crypto/err/err.c b/crypto/err/err.c
index bc671c9..c80aa6b 100644
--- a/crypto/err/err.c
+++ b/crypto/err/err.c
@@ -697,6 +697,7 @@ DEFINE_RUN_ONCE_STATIC(err_do_init)
ERR_STATE *ERR_get_state(void)
{
ERR_STATE *state;
+ int saveerrno = get_last_sys_error();
if (!OPENSSL_init_crypto(OPENSSL_INIT_BASE_ONLY, NULL))
return NULL;
@@ -728,6 +729,7 @@ ERR_STATE *ERR_get_state(void)
OPENSSL_init_crypto(OPENSSL_INIT_LOAD_CRYPTO_STRINGS, NULL);
}
+ set_sys_error(saveerrno);
return state;
}
@@ -737,6 +739,8 @@ ERR_STATE *ERR_get_state(void)
*/
int err_shelve_state(void **state)
{
+ int saveerrno = get_last_sys_error();
+
if (!OPENSSL_init_crypto(OPENSSL_INIT_BASE_ONLY, NULL))
return 0;
@@ -747,6 +751,7 @@ int err_shelve_state(void **state)
if (!CRYPTO_THREAD_set_local(&err_thread_local, (ERR_STATE*)-1))
return 0;
+ set_sys_error(saveerrno);
return 1;
}
More information about the openssl-commits
mailing list