summaryrefslogtreecommitdiff
path: root/pkt-line.c
diff options
context:
space:
mode:
authorMichael Haggerty <mhagger@alum.mit.edu>2013-07-15 17:24:17 +0200
committerJunio C Hamano <gitster@pobox.com>2013-07-17 18:19:16 -0700
commitd0cf51e9401b6486aaecfea5dc3b01c3bb00f271 (patch)
tree02e8d69901e235a0a087aff1c0e6eada091c9895 /pkt-line.c
parent2f1ef15070a8664d3194d164f20283d78571e51c (diff)
downloadgit-d0cf51e9401b6486aaecfea5dc3b01c3bb00f271.tar.gz
do_one_ref(): save and restore value of current_refmh/packed-refs-do-one-ref-recursion
If do_one_ref() is called recursively, then the inner call should not permanently overwrite the value stored in current_ref by the outer call. Aside from the tiny optimization loss, peel_ref() expects the value of current_ref not to change across a call to peel_entry(). But in the presence of replace references that assumption could be violated by a recursive call to do_one_ref: do_for_each_entry() do_one_ref() builtin/describe.c:get_name() peel_ref() peel_entry() peel_object () deref_tag_noverify() parse_object() lookup_replace_object() do_lookup_replace_object() prepare_replace_object() do_for_each_ref() do_for_each_entry() do_for_each_entry_in_dir() do_one_ref() The inner call to do_one_ref() was unconditionally setting current_ref to NULL when it was done, causing peel_ref() to perform an invalid memory access. So change do_one_ref() to save the old value of current_ref before overwriting it, and restore the old value afterward rather than setting it to NULL. Reported-by: Mantas Mikulėnas <grawity@gmail.com> Signed-off-by: Michael Haggerty <mhagger@alum.mit.edu> Signed-off-by: Junio C Hamano <gitster@pobox.com>
Diffstat (limited to 'pkt-line.c')
0 files changed, 0 insertions, 0 deletions