From: Matthias Dieter Wallnöfer Date: Wed, 20 Oct 2010 12:27:04 +0000 (+0200) Subject: ldb:ldb_index.c - fix some memory leaks X-Git-Url: http://git.samba.org/?p=abartlet%2Fsamba.git%2F.git;a=commitdiff_plain;h=0941099a2839812b18c2d3db86b18e92b152f1c8 ldb:ldb_index.c - fix some memory leaks Autobuild-User: Matthias Dieter Wallnöfer Autobuild-Date: Wed Oct 20 13:11:49 UTC 2010 on sn-devel-104 --- diff --git a/source4/lib/ldb/ldb_tdb/ldb_index.c b/source4/lib/ldb/ldb_tdb/ldb_index.c index fc2d9a05aac..71cffb90b34 100644 --- a/source4/lib/ldb/ldb_tdb/ldb_index.c +++ b/source4/lib/ldb/ldb_tdb/ldb_index.c @@ -179,6 +179,7 @@ normal_index: ret = ltdb_search_dn1(module, dn, msg); if (ret != LDB_SUCCESS) { + talloc_free(msg); return ret; } @@ -412,7 +413,10 @@ static struct ldb_dn *ltdb_index_key(struct ldb_context *ldb, } if (ldb_should_b64_encode(ldb, &v)) { char *vstr = ldb_base64_encode(ldb, (char *)v.data, v.length); - if (!vstr) return NULL; + if (!vstr) { + talloc_free(attr_folded); + return NULL; + } ret = ldb_dn_new_fmt(ldb, ldb, "%s:%s::%s", LTDB_INDEX, attr_folded, vstr); talloc_free(vstr); } else { @@ -962,6 +966,7 @@ static int ltdb_index_filter(const struct dn_list *dn_list, ret = ldb_module_send_entry(ac->req, msg, NULL); if (ret != LDB_SUCCESS) { + talloc_free(msg); ac->request_terminated = true; return ret; }