diff options
author | 2017-11-06 23:01:42 +0100 | |
---|---|---|
committer | 2017-11-06 23:01:42 +0100 | |
commit | f26355dd547b32124ce6439ad48487cb71278c76 (patch) | |
tree | 57e081178ca609ee2f75e71752254e5d698e204f /src/afb-trace.c | |
parent | 5bffa91c6c719b828a317adfb913ce57dbb2c6f0 (diff) |
afb-session: fix reference counting
Change-Id: If36c9210f0982ba35299de52f0c8fd96e7c836e2
Signed-off-by: José Bollo <jose.bollo@iot.bzh>
Diffstat (limited to 'src/afb-trace.c')
-rw-r--r-- | src/afb-trace.c | 12 |
1 files changed, 8 insertions, 4 deletions
diff --git a/src/afb-trace.c b/src/afb-trace.c index f0efd5f3..021ab5af 100644 --- a/src/afb-trace.c +++ b/src/afb-trace.c @@ -1211,17 +1211,19 @@ static void addhook(struct desc *desc, enum trace_type type) /* create the hook handler */ switch (type) { case Trace_Type_Xreq: - if (desc->session) { + if (!desc->session) + session = afb_session_addref(bind); + else { session = trace_get_session_by_uuid(trace, desc->session, 1); if (!session) { ctxt_error(&desc->context->errors, "allocation of session failed"); free(hook); return; } - bind = session; } - hook->handler = afb_hook_create_xreq(desc->api, desc->verb, bind, + hook->handler = afb_hook_create_xreq(desc->api, desc->verb, session, desc->flags[type], &hook_xreq_itf, hook); + afb_session_unref(session); break; case Trace_Type_Ditf: hook->handler = afb_hook_create_ditf(desc->api, desc->flags[type], &hook_ditf_itf, hook); @@ -1423,8 +1425,10 @@ static void drop_session(void *closure, struct json_object *object) session = trace_get_session_by_uuid(context->trace, uuid, 0); if (!session) ctxt_error(&context->errors, "session %s not found", uuid); - else + else { trace_unhook(context->trace, NULL, NULL, session); + afb_session_unref(session); + } } } |