mirror of
				https://github.com/asterisk/asterisk.git
				synced 2025-11-03 20:38:59 +00:00 
			
		
		
		
	Properly account for memory allocated for channels and datastores
As in previous commits, when channels are allocated (with ast_channel_alloc) or datastores are allocated (with ast_datastore_alloc) properly account for the memory being owned by the caller, instead of the allocator function itself. git-svn-id: https://origsvn.digium.com/svn/asterisk/trunk@192318 65c4cc65-6c06-0410-ace0-fbb531ad65f3
This commit is contained in:
		@@ -28,7 +28,8 @@ ASTERISK_FILE_VERSION(__FILE__, "$Revision$")
 | 
			
		||||
#include "asterisk/datastore.h"
 | 
			
		||||
#include "asterisk/utils.h"
 | 
			
		||||
 | 
			
		||||
struct ast_datastore *ast_datastore_alloc(const struct ast_datastore_info *info, const char *uid)
 | 
			
		||||
struct ast_datastore *__ast_datastore_alloc(const struct ast_datastore_info *info, const char *uid,
 | 
			
		||||
					    const char *file, int line, const char *function)
 | 
			
		||||
{
 | 
			
		||||
	struct ast_datastore *datastore = NULL;
 | 
			
		||||
 | 
			
		||||
@@ -37,11 +38,15 @@ struct ast_datastore *ast_datastore_alloc(const struct ast_datastore_info *info,
 | 
			
		||||
		return NULL;
 | 
			
		||||
	}
 | 
			
		||||
 | 
			
		||||
	/* Allocate memory for datastore and clear it */
 | 
			
		||||
	datastore = ast_calloc(1, sizeof(*datastore));
 | 
			
		||||
	if (!datastore) {
 | 
			
		||||
#if defined(__AST_DEBUG_MALLOC)
 | 
			
		||||
	if (!(datastore = __ast_calloc(1, sizeof(*datastore), file, line, function))) {
 | 
			
		||||
		return NULL;
 | 
			
		||||
	}
 | 
			
		||||
#else
 | 
			
		||||
	if (!(datastore = ast_calloc(1, sizeof(*datastore)))) {
 | 
			
		||||
		return NULL;
 | 
			
		||||
	}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
	datastore->info = info;
 | 
			
		||||
 | 
			
		||||
@@ -71,3 +76,19 @@ int ast_datastore_free(struct ast_datastore *datastore)
 | 
			
		||||
 | 
			
		||||
	return res;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
/* DO NOT PUT ADDITIONAL FUNCTIONS BELOW THIS BOUNDARY
 | 
			
		||||
 *
 | 
			
		||||
 * ONLY FUNCTIONS FOR PROVIDING BACKWARDS ABI COMPATIBILITY BELONG HERE
 | 
			
		||||
 *
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
/* Provide binary compatibility for modules that call ast_datastore_alloc() directly;
 | 
			
		||||
 * newly compiled modules will call __ast_datastore_alloc() via the macros in datastore.h
 | 
			
		||||
 */
 | 
			
		||||
#undef ast_datastore_alloc
 | 
			
		||||
struct ast_datastore *ast_datastore_alloc(const struct ast_datastore_info *info, const char *uid);
 | 
			
		||||
struct ast_datastore *ast_datastore_alloc(const struct ast_datastore_info *info, const char *uid)
 | 
			
		||||
{
 | 
			
		||||
	return __ast_datastore_alloc(info, uid, __FILE__, __LINE__, __FUNCTION__);
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user