git.vger.kernel.org archive mirror
 help / color / mirror / Atom feed
From: "René Scharfe" <rene.scharfe@lsrfire.ath.cx>
To: Felipe Contreras <felipe.contreras@gmail.com>
Cc: git@vger.kernel.org, "Junio C Hamano" <gitster@pobox.com>,
	"Nguyễn Thái Ngọc Duy" <pclouds@gmail.com>,
	"Adam Spiers" <git@adamspiers.org>,
	"Ramkumar Ramachandra" <artagnon@gmail.com>
Subject: Re: [PATCH v3 2/2] read-cache: plug a few leaks
Date: Sat, 08 Jun 2013 15:22:05 +0200	[thread overview]
Message-ID: <51B32FFD.5070302@lsrfire.ath.cx> (raw)
In-Reply-To: <CAMP44s2Bp5p1211e6Utdch4B+v3J83GCY0_ucG7duakswkb+pg@mail.gmail.com>

Am 08.06.2013 14:15, schrieb Felipe Contreras:
> On Sat, Jun 8, 2013 at 6:32 AM, René Scharfe
> <rene.scharfe@lsrfire.ath.cx> wrote:
>>> diff --git a/read-cache.c b/read-cache.c
>>> index 5e30746..a1dd04d 100644
>>> --- a/read-cache.c
>>> +++ b/read-cache.c
>>> @@ -1451,6 +1451,7 @@ int read_index_from(struct index_state *istate,
>>> const char *path)
>>>          istate->version = ntohl(hdr->hdr_version);
>>>          istate->cache_nr = ntohl(hdr->hdr_entries);
>>>          istate->cache_alloc = alloc_nr(istate->cache_nr);
>>> +       free(istate->cache);
>>>          istate->cache = xcalloc(istate->cache_alloc,
>>> sizeof(*istate->cache));
>>>          istate->initialized = 1;
>>
>>
>> You wrote earlier that this change is safe with current callers and that it
>> prevents leaks with the following sequence:
>>
>> discard_cache();
>> # add entries
>> read_cache();
>>
>> Do we currently have such a call sequence somewhere?
>
> I don't know.
>
>> Wouldn't that be a
>> bug, namely forgetting to call discard_cache before read_cache?
>
> Why would it be a bug? There's nothing in the API that hints there's a
> problem with that.

A comment before read_index_from says "remember to discard_cache() 
before reading a different cache!".  That is probably a reminder that 
read_index_from does nothing if ->initialized is set.  Entries added 
before calling read_index_from make up a different cache, however, so I 
think this comment applies for the call sequence above as well.

Only read_index_from and add_index_entry allocate ->cache, and only 
discard_index frees it, so the two are a triple like malloc, realloc and 
free.

Granted, these hints are not part of the API -- that looks like a 
documentation bug, however.

Side note: I wonder why we need to guard against multiple 
read_index_from calls in a row with ->initialized.  Wouldn't it be 
easier to avoid the duplicate calls in the first place?  Finding them 
now might be not so easy, though.

>> I've added a "assert(istate->cache_nr == 0);" a few lines above and the test
>> suite still passed.  With the hunk below, ->cache is also always NULL and
>> cache_alloc is always 0 at that point.  So we don't need that free call
>> there in the cases covered by the test suite at least -- better leave it
>> out.
>
> Why leave it out? If somebody makes the mistake of doing the above
> sequence, would you prefer that we leak?

Leaking is better than silently cleaning up after a buggy caller because 
it still allows the underlying bug to be found.  Even better would be an 
assert, but it's important to make sure it doesn't trigger for existing 
use cases.

René

  reply	other threads:[~2013-06-08 13:22 UTC|newest]

Thread overview: 16+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2013-06-07 22:29 [PATCH v3 0/2] cherry-pick: fix memory leaks Felipe Contreras
2013-06-07 22:29 ` [PATCH v3 1/2] unpack-trees: plug a memory leak Felipe Contreras
2013-06-07 22:29 ` [PATCH v3 2/2] read-cache: plug a few leaks Felipe Contreras
2013-06-08 11:32   ` René Scharfe
2013-06-08 12:15     ` Felipe Contreras
2013-06-08 13:22       ` René Scharfe [this message]
2013-06-08 14:04         ` Felipe Contreras
2013-06-08 15:56           ` René Scharfe
2013-06-08 16:53             ` Felipe Contreras
2013-06-08 17:22               ` René Scharfe
2013-06-08 17:27                 ` Felipe Contreras
2013-06-09  2:11                   ` René Scharfe
2013-06-09  2:25                     ` Felipe Contreras
2013-06-09 17:38                       ` René Scharfe
2013-06-09 18:27                         ` Felipe Contreras
2013-06-09 18:49         ` Junio C Hamano

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=51B32FFD.5070302@lsrfire.ath.cx \
    --to=rene.scharfe@lsrfire.ath.cx \
    --cc=artagnon@gmail.com \
    --cc=felipe.contreras@gmail.com \
    --cc=git@adamspiers.org \
    --cc=git@vger.kernel.org \
    --cc=gitster@pobox.com \
    --cc=pclouds@gmail.com \
    /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).