From: Volker Lendecke Date: Mon, 25 Jan 2016 11:40:53 +0000 (+0100) Subject: ldb: Avoid a "talloc_steal" X-Git-Tag: tevent-0.9.27~102 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=d56e42de64af84ad839749beaa22450f71bec58a;p=thirdparty%2Fsamba.git ldb: Avoid a "talloc_steal" There's only one caller of "next_chunk" that does a talloc_steal right after the call. Pass in a talloc context. Signed-off-by: Volker Lendecke Reviewed-by: Guenther Deschner --- diff --git a/lib/ldb/common/ldb_ldif.c b/lib/ldb/common/ldb_ldif.c index a8ad4aae7bc..07de5179ba7 100644 --- a/lib/ldb/common/ldb_ldif.c +++ b/lib/ldb/common/ldb_ldif.c @@ -417,7 +417,7 @@ int ldb_ldif_write(struct ldb_context *ldb, caller frees */ -static char *next_chunk(struct ldb_context *ldb, +static char *next_chunk(struct ldb_context *ldb, TALLOC_CTX *mem_ctx, int (*fgetc_fn)(void *), void *private_data) { size_t alloc_size=0, chunk_size = 0; @@ -429,7 +429,7 @@ static char *next_chunk(struct ldb_context *ldb, if (chunk_size+1 >= alloc_size) { char *c2; alloc_size += 1024; - c2 = talloc_realloc(ldb, chunk, char, alloc_size); + c2 = talloc_realloc(mem_ctx, chunk, char, alloc_size); if (!c2) { talloc_free(chunk); errno = ENOMEM; @@ -774,11 +774,10 @@ struct ldb_ldif *ldb_ldif_read(struct ldb_context *ldb, msg->elements = NULL; msg->num_elements = 0; - chunk = next_chunk(ldb, fgetc_fn, private_data); + chunk = next_chunk(ldb, ldif, fgetc_fn, private_data); if (!chunk) { goto failed; } - talloc_steal(ldif, chunk); s = chunk;