mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-10-22 12:52:33 +00:00 
			
		
		
		
	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 git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@431584 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		| @@ -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; | ||||
| } | ||||
|   | ||||
| @@ -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++) | ||||
|   | ||||
| @@ -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) | ||||
|   | ||||
		Reference in New Issue
	
	Block a user