Jeff King <peff@xxxxxxxx> writes: > I mean that later in the process, if we need to find an object we may > open the .idx file to look for it. So by opening them all up front, we > _might_ just be doing work that would get done later. > > But it's not guaranteed. Imagine you have 10,000 small packs, and one > big bitmapped pack. If you can serve the request from just the big pack, > then you'd never need to open those other .idx files at all. However, > the current code will open them anyway. > > I care less about mmap space, and more that it's work (syscalls, and > examining the contents of the idx) to open each one. It's probably not > even measurable unless you have a ton of packs, though. > > > > So it may not be worth worrying about. It does seem like it would be > > > easy to reorder open_pack_bitmap_1() to look for a bitmap file first and > > > only open the idx if it finds something. > > > > I think it may be worthy if we have lots of packs and the bitmap is refer to > > an older one, but I didn't make the test. At least, the scenario is common, I > > agree with that, so maybe we could shuffle the sort order in "open_pack_bitmap()". > > I don't mean the order in which we look at packs. I mean the order of > operations in open_pack_bitmap_1(), something like: Thank you for the explanation. Make sense. I run a test under a repo with 3 packs and without bitmaps,it seems like now will open every idx and failed at last: ➜ pack git:(master) git rev-list --test-bitmap HEAD pack: /Users/tenglong.tl/Downloads/trace-test/.git/objects/pack/pack-c9fe9d2dc5d002d4a4b622626ffa282bcbccb7ee.pack pack: /Users/tenglong.tl/Downloads/trace-test/.git/objects/pack/pack-08841c0c4c1fd176c354bdbd25c5a1b152ea95d0.pack pack: /Users/tenglong.tl/Downloads/trace-test/.git/objects/pack/pack-3cea516b416961285fd8f519e12102b19bcf257e.pack fatal: failed to load bitmap indexes So we're now looping for packs first, then try to find the corresponded bitmap of it. In that case, why can't we start the search from the bitmap files at first? If this is possible, when we found the first bitmap file or an appropriate one under some mechanism (biggest or newest maybe?I'm not deep into it right now) then break the loop and open it. > diff --git a/pack-bitmap.c b/pack-bitmap.c > index 440407f1be..1df2f6c8b6 100644 > --- a/pack-bitmap.c > +++ b/pack-bitmap.c > @@ -411,9 +411,6 @@ static int open_pack_bitmap_1(struct bitmap_index *bitmap_git, struct packed_git > struct stat st; > char *bitmap_name; > > - if (open_pack_index(packfile)) > - return -1; > - > bitmap_name = pack_bitmap_filename(packfile); > fd = git_open(bitmap_name); > > @@ -438,6 +435,10 @@ static int open_pack_bitmap_1(struct bitmap_index *bitmap_git, struct packed_git > return -1; > } > > + /* now we know we have a plausible bitmap; make sure the idx is OK, too */ > + if (open_pack_index(packfile)) > + return -1; > + > if (!is_pack_valid(packfile)) { > close(fd); > return -1; > > But we can further observe that the first thing is_pack_valid() will do > is open the idx file. :) So we can really just drop this line entirely, > I'd think. I agree that and I think it could append to patch v3, maybe. > BTW, another oddity I noticed in this function. We check: > > if (bitmap_git->pack || bitmap_git->midx) { > /* ignore extra bitmap file; we can only handle one */ > ... > } > > but it's impossible for bitmap_git->midx to be set here. If we opened > the midx bitmap, we'll skip calling open_pack_bitmap() entirely. Oh, I remember that and it's mentioned in another patchset at Tue, 29 Mar 2022: https://public-inbox.org/git/20220329024949.62091-1-dyroneteng@xxxxxxxxx/ I agree with Taylor with https://public-inbox.org/git/YkPGq0mDL4NG6D1o@nand.local/ But I'm ok if you think it should be solved. Thank you very much for your help.