pbx: Fix lack of cleanup on macrolock and context_table
authorJonathan Rose <jrose@digium.com>
Mon, 13 May 2013 19:29:56 +0000 (19:29 +0000)
committerJonathan Rose <jrose@digium.com>
Mon, 13 May 2013 19:29:56 +0000 (19:29 +0000)
(closes issue ASTERISK-21723)
Reported by: Corey Farrell
Patches:
    core-pbx-cleanup.patch uploaded by Correy Farrell (license 5909)
........

Merged revisions 388532 from http://svn.asterisk.org/svn/asterisk/branches/1.8
........

Merged revisions 388578 from http://svn.asterisk.org/svn/asterisk/branches/11

git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@388579 65c4cc65-6c06-0410-ace0-fbb531ad65f3

main/pbx.c

index 43805ce..74aeee9 100644 (file)
@@ -10435,6 +10435,7 @@ static void __ast_internal_context_destroy( struct ast_context *con)
        }
        tmp->root = NULL;
        ast_rwlock_destroy(&tmp->lock);
+       ast_mutex_destroy(&tmp->macrolock);
        ast_free(tmp);
 }
 
@@ -12142,6 +12143,10 @@ static void pbx_shutdown(void)
                ao2_ref(statecbs, -1);
                statecbs = NULL;
        }
+       if (contexts_table) {
+               ast_hashtab_destroy(contexts_table, NULL);
+       }
+       pbx_builtin_clear_globals();
 }
 
 int ast_pbx_init(void)