Author: sgriepentrog
Date: Fri Feb  6 15:26:46 2015
New Revision: 431584

URL: http://svnview.digium.com/svn/asterisk?view=rev&rev=431584
Log:
various: cleanup issues found during leak hunt

In this collection of small patches to prevent
Valgrind errors are: fixes for reference leaks
in config hooks, evaluating a parameter beyond
bounds, and accessing a structure after a lock
where it could have been already free'd.

Review: https://reviewboard.asterisk.org/r/4407/
........

Merged revisions 431583 from http://svn.asterisk.org/svn/asterisk/branches/13

Modified:
    trunk/   (props changed)
    trunk/main/config.c
    trunk/main/utils.c
    trunk/res/res_pjsip.c

Propchange: trunk/
------------------------------------------------------------------------------
Binary property 'branch-13-merged' - no diff available.

Modified: trunk/main/config.c
URL: 
http://svnview.digium.com/svn/asterisk/trunk/main/config.c?view=diff&rev=431584&r1=431583&r2=431584
==============================================================================
--- trunk/main/config.c (original)
+++ trunk/main/config.c Fri Feb  6 15:26:46 2015
@@ -3821,6 +3821,9 @@
        AST_LIST_UNLOCK(&cfmtime_head);
 
        ast_cli_unregister_multiple(cli_config, ARRAY_LEN(cli_config));
+
+       ao2_cleanup(cfg_hooks);
+       cfg_hooks = NULL;
 }
 
 int register_config_cli(void)
@@ -3909,5 +3912,6 @@
        hook->module = ast_strdup(module);
 
        ao2_link(cfg_hooks, hook);
+       ao2_ref(hook, -1);
        return 0;
 }

Modified: trunk/main/utils.c
URL: 
http://svnview.digium.com/svn/asterisk/trunk/main/utils.c?view=diff&rev=431584&r1=431583&r2=431584
==============================================================================
--- trunk/main/utils.c (original)
+++ trunk/main/utils.c Fri Feb  6 15:26:46 2015
@@ -1856,7 +1856,7 @@
        /* Join words into a string */
        if (!s)
                return;
-       for (x = 0; ofs < len && w[x] && x < size; x++) {
+       for (x = 0; ofs < len && x < size && w[x] ; x++) {
                if (x > 0)
                        s[ofs++] = delim;
                for (src = w[x]; *src && ofs < len; src++)

Modified: trunk/res/res_pjsip.c
URL: 
http://svnview.digium.com/svn/asterisk/trunk/res/res_pjsip.c?view=diff&rev=431584&r1=431583&r2=431584
==============================================================================
--- trunk/res/res_pjsip.c (original)
+++ trunk/res/res_pjsip.c Fri Feb  6 15:26:46 2015
@@ -2971,13 +2971,16 @@
 static int sync_task(void *data)
 {
        struct sync_task_data *std = data;
+       int ret;
+
        std->fail = std->task(std->task_data);
 
        ast_mutex_lock(&std->lock);
        std->complete = 1;
        ast_cond_signal(&std->cond);
+       ret = std->fail;
        ast_mutex_unlock(&std->lock);
-       return std->fail;
+       return ret;
 }
 
 int ast_sip_push_task_synchronous(struct ast_taskprocessor *serializer, int 
(*sip_task)(void *), void *task_data)


-- 
_____________________________________________________________________
-- Bandwidth and Colocation Provided by http://www.api-digital.com --

svn-commits mailing list
To UNSUBSCRIBE or update options visit:
   http://lists.digium.com/mailman/listinfo/svn-commits

Reply via email to