Fix memory leaks

(closes issue ASTERISK-22368)
Reported by: Corey Farrell
Patches:
     issueA22368_mixmonitor_free_filename.patch uploaded by wdoekes (license 5674)
........

Merged revisions 398004 from http://svn.asterisk.org/svn/asterisk/branches/10


git-svn-id: https://origsvn.digium.com/svn/asterisk/branches/11@398011 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
Kevin Harwell
2013-08-30 16:20:21 +00:00
parent 3e0157c46f
commit 3eb037cbb5

View File

@@ -497,12 +497,14 @@ static void mixmonitor_free(struct mixmonitor *mixmonitor)
if (mixmonitor->mixmonitor_ds) { if (mixmonitor->mixmonitor_ds) {
ast_mutex_destroy(&mixmonitor->mixmonitor_ds->lock); ast_mutex_destroy(&mixmonitor->mixmonitor_ds->lock);
ast_cond_destroy(&mixmonitor->mixmonitor_ds->destruction_condition); ast_cond_destroy(&mixmonitor->mixmonitor_ds->destruction_condition);
ast_free(mixmonitor->filename_write);
ast_free(mixmonitor->filename_read);
ast_free(mixmonitor->mixmonitor_ds); ast_free(mixmonitor->mixmonitor_ds);
}
ast_free(mixmonitor->name); ast_free(mixmonitor->name);
ast_free(mixmonitor->post_process); ast_free(mixmonitor->post_process);
} ast_free(mixmonitor->filename);
ast_free(mixmonitor->filename_write);
ast_free(mixmonitor->filename_read);
/* Free everything in the recipient list */ /* Free everything in the recipient list */
clear_mixmonitor_recipient_list(mixmonitor); clear_mixmonitor_recipient_list(mixmonitor);
@@ -513,6 +515,7 @@ static void mixmonitor_free(struct mixmonitor *mixmonitor)
if (mixmonitor->callid) { if (mixmonitor->callid) {
ast_callid_unref(mixmonitor->callid); ast_callid_unref(mixmonitor->callid);
} }
ast_free(mixmonitor); ast_free(mixmonitor);
} }
} }
@@ -1363,7 +1366,6 @@ static int unload_module(void)
res |= ast_manager_unregister("MixMonitorMute"); res |= ast_manager_unregister("MixMonitorMute");
res |= ast_manager_unregister("MixMonitor"); res |= ast_manager_unregister("MixMonitor");
res |= ast_manager_unregister("StopMixMonitor"); res |= ast_manager_unregister("StopMixMonitor");
return res; return res;
} }