It's saddening for the problem to exist in the first place but it's
more when no body gives it the time of the day.
But that's life.
I went and fixed the problem on my own:

in crypto.h i declared:

    void CRYPTO_cleanup();


and in cryptlib.c i wrote:

    void CRYPTO_cleanup()
    {
        if(dyn_locks)
            sk_CRYPTO_dynlock_free(dyn_locks);
        if(app_locks)
            sk_OPENSSL_STRING_free(app_locks);

    }


and i my own application I added a call to the newly added method:
    ENGINE_cleanup();
    EVP_cleanup();
    CRYPTO_cleanup_all_ex_data();
    ERR_free_strings();
    OBJ_NAME_cleanup(-1);
>>> CRYPTO_cleanup();


Running my application with Valgrind produces the following output.
That's what we'd like to see:
==3959==
==3959== HEAP SUMMARY:
==3959==     in use at exit: 0 bytes in 0 blocks
==3959==   total heap usage: 4,496 allocs, 4,496 frees, 137,484 bytes
allocated
==3959==
>>> ==3959== All heap blocks were freed -- no leaks are possible


On 10-08-18 04:28 PM, Jeff Saremi wrote:
>  any takers from the openssl team? true, false? known issue, user error?
> anything?
>
> On 10-08-17 04:23 PM, Jeff Saremi wrote:
>> I apologize if this shows up more than once. I've been having problems
>> sending emails out, all day.
>>
>>  First I encountered this with valgrind but then I decided to have
>> openssl print the leaks and it was also confirmed.
>> I have reduced my code to the following two lines. Prior to this if
>> course initilization of openssl and then the cleanup. Either there's a
>> call that I'm missing or the the dynamic locks don't get cleaned up upon
>> exit. Looking at the code in cryptlib.c, i don't see anywhere freeing up
>> the memory allocated to the following stacks:
>>
>> static STACK_OF(OPENSSL_STRING) *app_locks=NULL;
>> static STACK_OF(CRYPTO_dynlock) *dyn_locks=NULL;
>>
>> And here's my sample code:
>>     int l = CRYPTO_get_new_dynlockid();
>>     CRYPTO_destroy_dynlockid(l);
>>
>> Before this I have a bunch of lines like:
>>     CRYPTO_malloc_debug_init();
>>     CRYPTO_set_mem_debug_options(V_CRYPTO_MDEBUG_ALL);
>>     CRYPTO_mem_ctrl(CRYPTO_MEM_CHECK_ON);
>>
>>     SSL_library_init();
>>     OpenSSL_add_all_digests();
>>     CRYPTO_set_id_callback(..);
>>     CRYPTO_set_locking_callback(...);
>>     CRYPTO_set_dynlock_create_callback(...);
>>     CRYPTO_set_dynlock_lock_callback(...);
>>     CRYPTO_set_dynlock_destroy_callback(...);
>>
>> And at the end of the code I have something like:
>>     CRYPTO_set_id_callback(NULL);
>>     CRYPTO_set_locking_callback(NULL);
>>     CRYPTO_set_dynlock_create_callback(NULL);
>>     CRYPTO_set_dynlock_lock_callback(NULL);
>>     CRYPTO_set_dynlock_destroy_callback(NULL);
>>
>>     ENGINE_cleanup();
>>     EVP_cleanup();
>>     CRYPTO_cleanup_all_ex_data();
>>     ERR_free_strings();
>>     OBJ_NAME_cleanup(-1);
>>     ERR_remove_thread_state(NULL);
>>     SSL_free_comp_methods();
>>     CRYPTO_mem_leaks_fp(stderr);
>>
>> As you can see I have included every cleanup call I could find.
>> Running the code produces the following output:
>> [19:49:10]   188 file=stack.c, line=125, thread=19596, number=20,
>> address=08DF0E50
>> [19:49:10]   189 file=stack.c, line=127, thread=19596, number=16,
>> address=08DF0F78
>> 36 bytes leaked in 2 chunks
>>
>>
>>
>>
>> ______________________________________________________________________
>> OpenSSL Project                                 http://www.openssl.org
>> User Support Mailing List                    openssl-users@openssl.org
>> Automated List Manager                           majord...@openssl.org
> ______________________________________________________________________
> OpenSSL Project                                 http://www.openssl.org
> User Support Mailing List                    openssl-users@openssl.org
> Automated List Manager                           majord...@openssl.org

Reply via email to