From: LorenzoPegorari Date: Mon, 1 Jun 2026 13:52:12 +0000 (+0200) Subject: http: fix memory leak in fetch_and_setup_pack_index() X-Git-Url: http://git.ipfire.org/gitweb/index.cgi?a=commitdiff_plain;h=18decad922884a69ea39c0332f7a94ce82cf99cc;p=thirdparty%2Fgit.git http: fix memory leak in fetch_and_setup_pack_index() Inside the function `fetch_and_setup_pack_index()`, when the pack obtained using `parse_pack_index()` fails to be verified by `verify_pack_index()`, the function returns without closing and freeing said pack. Fix this by calling `close_pack_index()` to munmap the index file for the leaking pack (which might have been mmapped by `fetch_pack_index()` or `verify_pack_index()`), and then free it, when the verification fails. Signed-off-by: LorenzoPegorari Signed-off-by: Junio C Hamano --- diff --git a/http.c b/http.c index 55dd856a27..d50a34e446 100644 --- a/http.c +++ b/http.c @@ -2614,11 +2614,13 @@ static int fetch_and_setup_pack_index(struct packfile_list *packs, } ret = verify_pack_index(new_pack); - if (!ret) - close_pack_index(new_pack); + + close_pack_index(new_pack); free(tmp_idx); - if (ret) + if (ret) { + free(new_pack); return -1; + } packfile_list_prepend(packs, new_pack); return 0;