Mailing Lists
|
cURL Mailing List Monthly Index Single Mail
curl-tracker Archives
[curl:bugs] #1362 Increment the initialized counter in curl_global_init_mem()
From: Daniel Stenberg <bagder_at_users.sf.net>
Date: Mon, 21 Apr 2014 18:28:58 +0000
- **assigned_to**: Daniel Stenberg
If we increase the variable there, it will effectively tell curl_global_init() to not do anything which then would make it pointless to call it - and then some things won't be initialized at all.
IOW: that's not a good fix...
--- ** [bugs:#1362] Increment the initialized counter in curl_global_init_mem()** **Status:** open **Labels:** curl_global_init_mem **Created:** Thu Apr 17, 2014 09:28 PM UTC by Tristan **Last Updated:** Fri Apr 18, 2014 02:55 PM UTC **Owner:** Daniel Stenberg Hello, I think there is an issue in easy.c, in the curl_global_init_mem() function The initialized counter is not incremented if the libcurl is already initialized. I'm currently doing two inits and two shutdowns, and here is the problem I met : 1) curl_global_init_mem(); // Actually initialize libcurl (initialized = 1) 2) curl_global_init_mem(); // Should do nothing (initialized stays to 1 instead of being incremented) 3) curl_global_cleanup(); // Actually cleanup libcurl because initialized = 1 4) curl_global_cleanup(); After step 3 the variables that were created using the custom malloc are released using the default free, which raises an assert by libc on non-matching heap : Invalid address specified to RtlValidateHeap I could fix that by modifying easy.c the following way: @@ -300,8 +300,10 @@ return CURLE_FAILED_INIT; /* Already initialized, don't do it again */ - if(initialized) + if(initialized) { + initialized++; return CURLE_OK; + } /* Call the actual init function first */ code = curl_global_init(flags); However, maybe there is a better fix than duplicating the increment from curl_global_init()? I'm using Libcurl 7.34.0, and checked quickly for a fix in 7.36.0, but I didn't find it. --- Sent from sourceforge.net because curl-tracker@cool.haxx.se is subscribed to https://sourceforge.net/p/curl/bugs/ To unsubscribe from further messages, a project admin can change settings at https://sourceforge.net/p/curl/admin/bugs/options. Or, if this is a mailing list, you can unsubscribe from the mailing list.Received on 2014-04-21 These mail archives are generated by hypermail. |
Page updated March 21, 2014.
web site info