From: Nguyễn Thái Ngọc Duy Date: Thu, 20 Feb 2014 23:47:47 +0000 (+0700) Subject: sha1_file: fix delta_stack memory leak in unpack_entry X-Git-Tag: v2.0.0-rc0~100^2 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=019d1e65f5bc715a40b1cd77852af0a649753c56;p=git sha1_file: fix delta_stack memory leak in unpack_entry This delta_stack array can grow to any length depending on the actual delta chain, but we forget to free it. Normally it does not matter because we use small_delta_stack[] from stack and small_delta_stack can hold 64-delta chains, more than standard --depth=50 in pack-objects. Signed-off-by: Nguyễn Thái Ngọc Duy Signed-off-by: Junio C Hamano --- diff --git a/sha1_file.c b/sha1_file.c index b220a470f9..ca31de2df9 100644 --- a/sha1_file.c +++ b/sha1_file.c @@ -2058,6 +2058,10 @@ void *unpack_entry(struct packed_git *p, off_t obj_offset, *final_size = size; unuse_pack(&w_curs); + + if (delta_stack != small_delta_stack) + free(delta_stack); + return data; }