summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--main/config.c4
-rw-r--r--main/utils.c2
-rw-r--r--res/res_pjsip.c5
3 files changed, 9 insertions, 2 deletions
diff --git a/main/config.c b/main/config.c
index 0aa6bbefc..7e5141398 100644
--- a/main/config.c
+++ b/main/config.c
@@ -3821,6 +3821,9 @@ static void config_shutdown(void)
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 @@ int ast_config_hook_register(const char *name,
hook->module = ast_strdup(module);
ao2_link(cfg_hooks, hook);
+ ao2_ref(hook, -1);
return 0;
}
diff --git a/main/utils.c b/main/utils.c
index 7032631f8..578a01e26 100644
--- a/main/utils.c
+++ b/main/utils.c
@@ -1856,7 +1856,7 @@ void ast_join_delim(char *s, size_t len, const char * const w[], unsigned int si
/* 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++)
diff --git a/res/res_pjsip.c b/res/res_pjsip.c
index 58d9826b8..6db84b417 100644
--- a/res/res_pjsip.c
+++ b/res/res_pjsip.c
@@ -2971,13 +2971,16 @@ struct sync_task_data {
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)