diff options
author | Daniel Stenberg <daniel@haxx.se> | 2019-11-28 16:21:58 +0100 |
---|---|---|
committer | Daniel Stenberg <daniel@haxx.se> | 2019-12-02 00:04:56 +0100 |
commit | bc5d22c3dede2f04870c37aec9a50474c4b888ad (patch) | |
tree | 0723c27f97e8ae5abd4dad14aff1188e9aba0d03 /lib/easy.c | |
parent | 0044443a020d15c262e9f6c724b29365a8148437 (diff) | |
download | curl-bc5d22c3dede2f04870c37aec9a50474c4b888ad.tar.gz |
global_init: undo the "intialized" bump in case of failure
... so that failures in the global init function don't count as a
working init and it can then be called again.
Reported-by: Paul Groke
Fixes #4636
Closes #4653
Diffstat (limited to 'lib/easy.c')
-rw-r--r-- | lib/easy.c | 14 |
1 files changed, 9 insertions, 5 deletions
diff --git a/lib/easy.c b/lib/easy.c index 1d02c0cc1..6382cee3d 100644 --- a/lib/easy.c +++ b/lib/easy.c @@ -157,20 +157,20 @@ static CURLcode global_init(long flags, bool memoryfuncs) if(!Curl_ssl_init()) { DEBUGF(fprintf(stderr, "Error: Curl_ssl_init failed\n")); - return CURLE_FAILED_INIT; + goto fail; } #ifdef WIN32 if(Curl_win32_init(flags)) { DEBUGF(fprintf(stderr, "Error: win32_init failed\n")); - return CURLE_FAILED_INIT; + goto fail; } #endif #ifdef __AMIGA__ if(!Curl_amiga_init()) { DEBUGF(fprintf(stderr, "Error: Curl_amiga_init failed\n")); - return CURLE_FAILED_INIT; + goto fail; } #endif @@ -182,14 +182,14 @@ static CURLcode global_init(long flags, bool memoryfuncs) if(Curl_resolver_global_init()) { DEBUGF(fprintf(stderr, "Error: resolver_global_init failed\n")); - return CURLE_FAILED_INIT; + goto fail; } (void)Curl_ipv6works(); #if defined(USE_SSH) if(Curl_ssh_init()) { - return CURLE_FAILED_INIT; + goto fail; } #endif @@ -201,6 +201,10 @@ static CURLcode global_init(long flags, bool memoryfuncs) Curl_version_init(); return CURLE_OK; + + fail: + initialized--; /* undo the increase */ + return CURLE_FAILED_INIT; } |