From 12936bee690e5be8d34f7da288a8620d8b50c676 Mon Sep 17 00:00:00 2001 From: Andrew Tridgell Date: Fri, 25 Sep 2009 15:12:52 -0700 Subject: s4-samdb: free the linked_attributes list on prepare commit failure --- source4/dsdb/samdb/ldb_modules/linked_attributes.c | 6 ++++++ 1 file changed, 6 insertions(+) (limited to 'source4') diff --git a/source4/dsdb/samdb/ldb_modules/linked_attributes.c b/source4/dsdb/samdb/ldb_modules/linked_attributes.c index b4144efe3f..0bb9ecc7ed 100644 --- a/source4/dsdb/samdb/ldb_modules/linked_attributes.c +++ b/source4/dsdb/samdb/ldb_modules/linked_attributes.c @@ -1212,6 +1212,8 @@ static int linked_attributes_prepare_commit(struct ldb_module *module) talloc_get_type(ldb_module_get_private(module), struct la_private); struct la_context *ac; + DEBUG(0,(__location__ ": prepare commit starting\n")); + /* walk the list backwards, to do the first entry first, as we * added the entries with DLIST_ADD() which puts them at the * start of the list */ @@ -1223,12 +1225,16 @@ static int linked_attributes_prepare_commit(struct ldb_module *module) ret = la_do_mod_request(module, ac); if (ret != LDB_SUCCESS) { DEBUG(0,(__location__ ": Failed mod request ret=%d\n", ret)); + talloc_free(la_private); + ldb_module_set_private(module, NULL); return ret; } } talloc_free(la_private); ldb_module_set_private(module, NULL); + + DEBUG(0,(__location__ ": prepare commit done\n")); return ldb_next_prepare_commit(module); } -- cgit