FS-5838 fix segfaults in unload of mod_format_cdr

This commit is contained in:
Nathan Neulinger 2013-10-02 16:42:49 -05:00
parent 1825b5bc89
commit fa45e08d0b
1 changed files with 7 additions and 6 deletions

View File

@ -557,6 +557,8 @@ switch_status_t mod_format_cdr_load_profile_xml(switch_xml_t xprofile)
} }
profile = switch_core_alloc(pool, sizeof(cdr_profile_t)); profile = switch_core_alloc(pool, sizeof(cdr_profile_t));
memset(profile, 0, sizeof(cdr_profile_t));
profile->pool = pool; profile->pool = pool;
profile->name = switch_core_strdup(profile->pool, profile_name); profile->name = switch_core_strdup(profile->pool, profile_name);
@ -768,9 +770,9 @@ void mod_format_cdr_profile_shutdown(cdr_profile_t *profile)
switch_safe_free(profile->log_dir); switch_safe_free(profile->log_dir);
switch_core_destroy_memory_pool(&profile->pool);
switch_thread_rwlock_destroy(profile->log_path_lock); switch_thread_rwlock_destroy(profile->log_path_lock);
switch_core_destroy_memory_pool(&profile->pool);
} }
SWITCH_MODULE_SHUTDOWN_FUNCTION(mod_format_cdr_shutdown) SWITCH_MODULE_SHUTDOWN_FUNCTION(mod_format_cdr_shutdown)
@ -788,13 +790,12 @@ SWITCH_MODULE_SHUTDOWN_FUNCTION(mod_format_cdr_shutdown)
switch_hash_this(hi, NULL, NULL, &val); switch_hash_this(hi, NULL, NULL, &val);
profile = (cdr_profile_t *) val; profile = (cdr_profile_t *) val;
if ( profile ) {
mod_format_cdr_profile_shutdown(profile); mod_format_cdr_profile_shutdown(profile);
} }
}
switch_core_hash_destroy(&globals.profile_hash); switch_core_hash_destroy(&globals.profile_hash);
switch_core_destroy_memory_pool(&globals.pool);
memset(&globals, 0, sizeof(globals));
return SWITCH_STATUS_SUCCESS; return SWITCH_STATUS_SUCCESS;
} }