From: Mike Hommey Date: Fri, 22 Nov 2019 08:37:04 +0000 (+0900) Subject: revision: free topo_walk_info before creating a new one in init_topo_walk X-Git-Tag: v2.25.0-rc0~70^2 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=0aa0c2b2ec12c91a122aec7a8497fe3577529eba;p=thirdparty%2Fgit.git revision: free topo_walk_info before creating a new one in init_topo_walk init_topo_walk doesn't reuse an existing topo_walk_info, and currently leaks the one that might exist on the current rev_info if it was already used for a topo walk beforehand. Signed-off-by: Mike Hommey Signed-off-by: Junio C Hamano --- diff --git a/revision.c b/revision.c index 4827360ed8..fb93c993a4 100644 --- a/revision.c +++ b/revision.c @@ -3201,10 +3201,26 @@ static void compute_indegrees_to_depth(struct rev_info *revs, indegree_walk_step(revs); } +static void reset_topo_walk(struct rev_info *revs) +{ + struct topo_walk_info *info = revs->topo_walk_info; + + clear_prio_queue(&info->explore_queue); + clear_prio_queue(&info->indegree_queue); + clear_prio_queue(&info->topo_queue); + clear_indegree_slab(&info->indegree); + clear_author_date_slab(&info->author_date); + + FREE_AND_NULL(revs->topo_walk_info); +} + static void init_topo_walk(struct rev_info *revs) { struct topo_walk_info *info; struct commit_list *list; + if (revs->topo_walk_info) + reset_topo_walk(revs); + revs->topo_walk_info = xmalloc(sizeof(struct topo_walk_info)); info = revs->topo_walk_info; memset(info, 0, sizeof(struct topo_walk_info));