From: Patrick Steinhardt <ps@pks.im>
To: git@vger.kernel.org
Subject: [PATCH 00/29] Memory leak fixes (pt.2)
Date: Mon, 3 Jun 2024 11:46:23 +0200 [thread overview]
Message-ID: <cover.1717402439.git.ps@pks.im> (raw)
[-- Attachment #1: Type: text/plain, Size: 9385 bytes --]
Hi,
this is another random assortment of memory leak fixes for Git. With
these changes, another 77 test suites start to pass with the leak
sanitizer enabled. With that, we're down to ~270 test suites that do not
yet pass with the sanitizer enabled. My goal is that we can reduce this
number to 0 this year -- any help here would be appreciated.
While most of the commits are trivial, I realize that the overall series
is quite large. If you think that this is too big, please feel free to
speak up up and I'll split this and future series into batches of at
most 20 patches or less, if you think that's still too many.
The series is built on top of 9eaef5822c (Sync with 'maint', 2024-05-31)
with ps/leakfixes at 164937678c (Merge remote-tracking branch
'junio/ps/leakfixes' into HEAD, 2024-06-03) merged into it.
Thanks!
Patrick Steinhardt (29):
revision: fix memory leak when reversing revisions
parse-options: fix leaks for users of OPT_FILENAME
notes-utils: free note trees when releasing copied notes
bundle: plug leaks in `create_bundle()`
biultin/rev-parse: fix memory leaks in `--parseopt` mode
merge-recursive: fix leaging rename conflict info
revision: fix leaking display notes
notes: fix memory leak when pruning notes
builtin/rev-list: fix leaking bitmap index when calculating disk usage
object-name: free leaking object contexts
builtin/difftool: plug memory leaks in `run_dir_diff()`
builtin/merge-recursive: fix leaking object ID bases
merge-recursive: fix memory leak when finalizing merge
builtin/log: fix leaking commit list in git-cherry(1)
revision: free diff options
builtin/stash: fix leak in `show_stash()`
rerere: fix various trivial leaks
config: fix leaking "core.notesref" variable
commit: fix leaking parents when calling `commit_tree_extended()`
sequencer: fix leaking string buffer in `commit_staged_changes()`
apply: fix leaking string in `match_fragment()`
builtin/clone: plug leaking HEAD ref in `wanted_peer_refs()`
sequencer: fix memory leaks in `make_script_with_merges()`
builtin/merge: fix leaking `struct cmdnames` in `get_strategy()`
merge: fix leaking merge bases
line-range: plug leaking find functions
blame: fix leaking data for blame scoreboards
builtin/blame: fix leaking prefixed paths
builtin/blame: fix leaking ignore revs files
apply.c | 88 ++++++++++-------
apply.h | 2 +-
blame.c | 4 +
builtin/am.c | 7 +-
builtin/archive.c | 7 +-
builtin/blame.c | 8 +-
builtin/cat-file.c | 17 ++--
builtin/clone.c | 3 +-
builtin/commit-tree.c | 11 ++-
builtin/commit.c | 10 +-
builtin/difftool.c | 3 +
builtin/fmt-merge-msg.c | 4 +-
builtin/grep.c | 4 +-
builtin/log.c | 16 ++--
builtin/ls-tree.c | 3 +-
builtin/merge-recursive.c | 6 +-
builtin/merge-tree.c | 1 +
builtin/merge.c | 18 +++-
builtin/multi-pack-index.c | 13 ++-
builtin/replay.c | 14 ++-
builtin/rev-list.c | 2 +
builtin/rev-parse.c | 55 ++++++-----
builtin/shortlog.c | 5 +-
builtin/sparse-checkout.c | 1 +
builtin/stash.c | 23 +++--
bundle.c | 29 ++++--
commit.c | 28 +++---
commit.h | 12 +--
config.c | 1 +
diff-lib.c | 2 +
diff.c | 8 +-
help.c | 12 +--
help.h | 2 +
line-range.c | 2 +
list-objects-filter.c | 2 +
log-tree.c | 1 +
merge-ort-wrappers.c | 2 +-
merge-ort-wrappers.h | 2 +-
merge-ort.c | 12 ++-
merge-ort.h | 2 +-
merge-recursive.c | 68 ++++++++-----
merge-recursive.h | 4 +-
notes-merge.c | 1 +
notes-utils.c | 9 +-
notes-utils.h | 2 +-
notes.c | 21 +++--
notes.h | 5 +
object-name.c | 40 +++++---
object-name.h | 2 +
rerere.c | 3 +
revision.c | 59 +++++++-----
sequencer.c | 110 +++++++++++++++-------
t/helper/test-parse-options.c | 1 +
t/t1004-read-tree-m-u-wf.sh | 1 +
t/t1015-read-index-unmerged.sh | 2 +
t/t1021-rerere-in-workdir.sh | 1 +
t/t1512-rev-parse-disambiguation.sh | 1 +
t/t2500-untracked-overwriting.sh | 1 +
t/t3301-notes.sh | 1 +
t/t3306-notes-prune.sh | 1 +
t/t3308-notes-merge.sh | 1 +
t/t3309-notes-merge-auto-resolve.sh | 1 +
t/t3400-rebase.sh | 1 +
t/t3401-rebase-and-am-rename.sh | 1 +
t/t3403-rebase-skip.sh | 1 +
t/t3406-rebase-message.sh | 1 +
t/t3407-rebase-abort.sh | 1 +
t/t3417-rebase-whitespace-fix.sh | 1 +
t/t3418-rebase-continue.sh | 1 +
t/t3420-rebase-autostash.sh | 1 +
t/t3421-rebase-topology-linear.sh | 2 +
t/t3424-rebase-empty.sh | 1 +
t/t3428-rebase-signoff.sh | 1 +
t/t3430-rebase-merges.sh | 1 +
t/t3434-rebase-i18n.sh | 1 +
t/t3500-cherry.sh | 1 +
t/t3504-cherry-pick-rerere.sh | 1 +
t/t3505-cherry-pick-empty.sh | 1 +
t/t3508-cherry-pick-many-commits.sh | 1 +
t/t3509-cherry-pick-merge-df.sh | 1 +
t/t3907-stash-show-config.sh | 1 +
t/t4061-diff-indent.sh | 1 +
t/t4131-apply-fake-ancestor.sh | 1 +
t/t4151-am-abort.sh | 1 +
t/t4153-am-resume-override-opts.sh | 1 +
t/t4208-log-magic-pathspec.sh | 1 +
t/t4253-am-keep-cr-dos.sh | 1 +
t/t4255-am-submodule.sh | 1 +
t/t5150-request-pull.sh | 1 +
t/t5300-pack-object.sh | 4 +-
t/t5305-include-tag.sh | 1 +
t/t5407-post-rewrite-hook.sh | 1 +
t/t5605-clone-local.sh | 1 +
t/t5607-clone-bundle.sh | 1 +
t/t5612-clone-refspec.sh | 1 +
t/t6000-rev-list-misc.sh | 1 +
t/t6001-rev-list-graft.sh | 1 +
t/t6013-rev-list-reverse-parents.sh | 1 +
t/t6017-rev-list-stdin.sh | 1 +
t/t6020-bundle-misc.sh | 1 +
t/t6115-rev-list-du.sh | 2 +
t/t6130-pathspec-noglob.sh | 2 +
t/t6402-merge-rename.sh | 1 +
t/t6427-diff3-conflict-markers.sh | 1 +
t/t6430-merge-recursive.sh | 1 +
t/t6432-merge-recursive-space-options.sh | 1 +
t/t6434-merge-recursive-rename-options.sh | 1 +
t/t6436-merge-overwrite.sh | 1 +
t/t7006-pager.sh | 1 +
t/t7010-setup.sh | 1 +
t/t7012-skip-worktree-writing.sh | 1 +
t/t7201-co.sh | 1 +
t/t7501-commit-basic-functionality.sh | 1 +
t/t7505-prepare-commit-msg-hook.sh | 1 +
t/t7512-status-help.sh | 1 +
t/t7600-merge.sh | 1 +
t/t7606-merge-custom.sh | 1 +
t/t7611-merge-abort.sh | 1 +
t/t8002-blame.sh | 1 +
t/t8003-blame-corner-cases.sh | 1 +
t/t8004-blame-with-conflicts.sh | 1 +
t/t8006-blame-textconv.sh | 2 +
t/t8008-blame-formats.sh | 2 +
t/t8009-blame-vs-topicbranches.sh | 2 +
t/t8011-blame-split-file.sh | 2 +
t/t8012-blame-colors.sh | 1 +
t/t8013-blame-ignore-revs.sh | 2 +
t/t8014-blame-ignore-fuzzy.sh | 2 +
t/t9500-gitweb-standalone-no-errors.sh | 1 +
t/t9502-gitweb-standalone-parse-output.sh | 1 +
130 files changed, 588 insertions(+), 269 deletions(-)
--
2.45.1.410.g58bac47f8e.dirty
[-- Attachment #2: signature.asc --]
[-- Type: application/pgp-signature, Size: 833 bytes --]
next reply other threads:[~2024-06-03 9:46 UTC|newest]
Thread overview: 74+ messages / expand[flat|nested] mbox.gz Atom feed top
2024-06-03 9:46 Patrick Steinhardt [this message]
2024-06-03 9:46 ` [PATCH 01/29] revision: fix memory leak when reversing revisions Patrick Steinhardt
2024-06-03 9:46 ` [PATCH 02/29] parse-options: fix leaks for users of OPT_FILENAME Patrick Steinhardt
2024-06-06 10:00 ` Karthik Nayak
2024-06-03 9:46 ` [PATCH 03/29] notes-utils: free note trees when releasing copied notes Patrick Steinhardt
2024-06-06 10:02 ` Karthik Nayak
2024-06-03 9:46 ` [PATCH 04/29] bundle: plug leaks in `create_bundle()` Patrick Steinhardt
2024-06-03 9:46 ` [PATCH 05/29] biultin/rev-parse: fix memory leaks in `--parseopt` mode Patrick Steinhardt
2024-06-03 9:46 ` [PATCH 06/29] merge-recursive: fix leaging rename conflict info Patrick Steinhardt
2024-06-06 10:07 ` Karthik Nayak
2024-06-03 9:46 ` [PATCH 07/29] revision: fix leaking display notes Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 08/29] notes: fix memory leak when pruning notes Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 09/29] builtin/rev-list: fix leaking bitmap index when calculating disk usage Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 10/29] object-name: free leaking object contexts Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 11/29] builtin/difftool: plug memory leaks in `run_dir_diff()` Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 12/29] builtin/merge-recursive: fix leaking object ID bases Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 13/29] merge-recursive: fix memory leak when finalizing merge Patrick Steinhardt
2024-06-06 10:50 ` Karthik Nayak
2024-06-06 15:52 ` Phillip Wood
2024-06-12 9:33 ` Karthik Nayak
2024-06-03 9:47 ` [PATCH 14/29] builtin/log: fix leaking commit list in git-cherry(1) Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 15/29] revision: free diff options Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 16/29] builtin/stash: fix leak in `show_stash()` Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 17/29] rerere: fix various trivial leaks Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 18/29] config: fix leaking "core.notesref" variable Patrick Steinhardt
2024-06-03 9:47 ` [PATCH 19/29] commit: fix leaking parents when calling `commit_tree_extended()` Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 20/29] sequencer: fix leaking string buffer in `commit_staged_changes()` Patrick Steinhardt
2024-06-03 13:14 ` Phillip Wood
2024-06-04 6:45 ` Patrick Steinhardt
2024-06-04 7:19 ` Patrick Steinhardt
2024-06-04 13:58 ` Phillip Wood
2024-06-03 9:48 ` [PATCH 21/29] apply: fix leaking string in `match_fragment()` Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 22/29] builtin/clone: plug leaking HEAD ref in `wanted_peer_refs()` Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 23/29] sequencer: fix memory leaks in `make_script_with_merges()` Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 24/29] builtin/merge: fix leaking `struct cmdnames` in `get_strategy()` Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 25/29] merge: fix leaking merge bases Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 26/29] line-range: plug leaking find functions Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 27/29] blame: fix leaking data for blame scoreboards Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 28/29] builtin/blame: fix leaking prefixed paths Patrick Steinhardt
2024-06-03 9:48 ` [PATCH 29/29] builtin/blame: fix leaking ignore revs files Patrick Steinhardt
2024-06-06 14:33 ` [PATCH 00/29] Memory leak fixes (pt.2) Karthik Nayak
2024-06-07 4:07 ` Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 " Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 01/29] revision: fix memory leak when reversing revisions Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 02/29] parse-options: fix leaks for users of OPT_FILENAME Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 03/29] notes-utils: free note trees when releasing copied notes Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 04/29] bundle: plug leaks in `create_bundle()` Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 05/29] biultin/rev-parse: fix memory leaks in `--parseopt` mode Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 06/29] merge-recursive: fix leaking rename conflict info Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 07/29] revision: fix leaking display notes Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 08/29] notes: fix memory leak when pruning notes Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 09/29] builtin/rev-list: fix leaking bitmap index when calculating disk usage Patrick Steinhardt
2024-06-11 9:19 ` [PATCH v2 10/29] object-name: free leaking object contexts Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 11/29] builtin/difftool: plug memory leaks in `run_dir_diff()` Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 12/29] builtin/merge-recursive: fix leaking object ID bases Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 13/29] merge-recursive: fix memory leak when finalizing merge Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 14/29] builtin/log: fix leaking commit list in git-cherry(1) Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 15/29] revision: free diff options Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 16/29] builtin/stash: fix leak in `show_stash()` Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 17/29] rerere: fix various trivial leaks Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 18/29] config: fix leaking "core.notesref" variable Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 19/29] commit: fix leaking parents when calling `commit_tree_extended()` Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 20/29] sequencer: fix leaking string buffer in `commit_staged_changes()` Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 21/29] apply: fix leaking string in `match_fragment()` Patrick Steinhardt
2024-06-11 9:20 ` [PATCH v2 22/29] builtin/clone: plug leaking HEAD ref in `wanted_peer_refs()` Patrick Steinhardt
2024-06-11 9:21 ` [PATCH v2 23/29] sequencer: fix memory leaks in `make_script_with_merges()` Patrick Steinhardt
2024-06-11 9:21 ` [PATCH v2 24/29] builtin/merge: fix leaking `struct cmdnames` in `get_strategy()` Patrick Steinhardt
2024-06-11 9:21 ` [PATCH v2 25/29] merge: fix leaking merge bases Patrick Steinhardt
2024-06-11 9:21 ` [PATCH v2 26/29] line-range: plug leaking find functions Patrick Steinhardt
2024-06-11 9:21 ` [PATCH v2 27/29] blame: fix leaking data for blame scoreboards Patrick Steinhardt
2024-06-11 9:21 ` [PATCH v2 28/29] builtin/blame: fix leaking prefixed paths Patrick Steinhardt
2024-06-11 9:21 ` [PATCH v2 29/29] builtin/blame: fix leaking ignore revs files Patrick Steinhardt
2024-06-12 9:09 ` [PATCH v2 00/29] Memory leak fixes (pt.2) Phillip Wood
2024-06-12 9:35 ` Karthik Nayak
Reply instructions:
You may reply publicly to this message via plain-text email
using any one of the following methods:
* Save the following mbox file, import it into your mail client,
and reply-to-all from there: mbox
Avoid top-posting and favor interleaved quoting:
https://en.wikipedia.org/wiki/Posting_style#Interleaved_style
* Reply using the --to, --cc, and --in-reply-to
switches of git-send-email(1):
git send-email \
--in-reply-to=cover.1717402439.git.ps@pks.im \
--to=ps@pks.im \
--cc=git@vger.kernel.org \
/path/to/YOUR_REPLY
https://kernel.org/pub/software/scm/git/docs/git-send-email.html
* If your mail client supports setting the In-Reply-To header
via mailto: links, try the mailto: link
Be sure your reply has a Subject: header at the top and a blank line
before the message body.
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox;
as well as URLs for NNTP newsgroup(s).