summaryrefslogtreecommitdiff
path: root/main
diff options
context:
space:
mode:
authorJoshua Colp <jcolp@digium.com>2016-09-06 10:59:18 -0500
committerGerrit Code Review <gerrit2@gerrit.digium.api>2016-09-06 10:59:18 -0500
commite455036e9e66a37dae9bf2905f31dea3625f0bb4 (patch)
treee8a919ee443aa59a077b5116fa28a14296d8ff17 /main
parentdec772d46cfd4cb97f5917cd2263fe10e4074d62 (diff)
parente65f170d9c5966d33b32eab57b7e67196126cdc7 (diff)
Merge "sorcery: Create function ast_sorcery_lockable_alloc." into 14
Diffstat (limited to 'main')
-rw-r--r--main/sorcery.c19
1 files changed, 18 insertions, 1 deletions
diff --git a/main/sorcery.c b/main/sorcery.c
index 55ee830b7..9f8c35c3b 100644
--- a/main/sorcery.c
+++ b/main/sorcery.c
@@ -1736,9 +1736,26 @@ static void sorcery_object_destructor(void *object)
ast_free(details->object->id);
}
+void *ast_sorcery_lockable_alloc(size_t size, ao2_destructor_fn destructor, void *lockobj)
+{
+ void *object = ao2_alloc_with_lockobj(size + sizeof(struct ast_sorcery_object),
+ sorcery_object_destructor, lockobj, "");
+ struct ast_sorcery_object_details *details = object;
+
+ if (!object) {
+ return NULL;
+ }
+
+ details->object = object + size;
+ details->object->destructor = destructor;
+
+ return object;
+}
+
void *ast_sorcery_generic_alloc(size_t size, ao2_destructor_fn destructor)
{
- void *object = ao2_alloc_options(size + sizeof(struct ast_sorcery_object), sorcery_object_destructor, AO2_ALLOC_OPT_LOCK_NOLOCK);
+ void *object = ao2_alloc_options(size + sizeof(struct ast_sorcery_object),
+ sorcery_object_destructor, AO2_ALLOC_OPT_LOCK_NOLOCK);
struct ast_sorcery_object_details *details = object;
if (!object) {