Re: [PATCH] rev-list: skip bitmap traversal for --left-right

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

 



On Mon, Nov 04, 2024 at 12:41:27PM -0500, Jeff King wrote:

> On Fri, Nov 01, 2024 at 10:40:41AM -0400, Taylor Blau wrote:
> 
> > Nice find, and well explained (not just why it doesn't work today but
> > could in the future, but why making it work in the future with bitmaps
> > does not necessarily a clear performance improvement).
> > 
> > Probably you and I should think more about other rev-list options that
> > *don't* work with --use-bitmap-index. I share your feeling there that
> > there probably exist such options which silently do nothing (or the
> > wrong thing) in the presence of '--use-bitmap-index'.
> 
> I'm pretty sure --cherry-pick and --cherry-mark are examples, but I
> suspect it's the tip of the iceberg. I don't know if it's worth spending
> much effort on this. It's certainly a wart, but there's a certain amount
> of "if it hurts, don't do it". The --left-right one bugged me so much
> just because I thought it _would_ work. ;)

Actually, I wonder if this could be an interesting #leftoverbits or
intern mini-project:

  1. Look at the set of rev-list options and pick one.

  2. Repack a repo (say, git.git) with reachability bitmaps using "git
     repack -adb".

  3. Compare output of "rev-list --your-option" with and without
     --use-bitmap-index. If the outputs do not reasonably match, add
     code to try_bitmap_traversal() to forbid it and bail to the
     non-bitmap path. Maybe also other try_bitmap_*() functions, as
     well.

It's a little more involved than other miniprojects just because there
may be some judgement needed for "reasonably match". Being byte-for-byte
identical is good, but in some cases the output will be different (e.g.,
bitmap output is in a different order, lacks path annotations, etc). So
it would help in step (1) if you understand what the option is supposed
to do and how you'd expect it to work with bitmaps. ;)

-Peff




[Index of Archives]     [Linux Kernel Development]     [Gcc Help]     [IETF Annouce]     [DCCP]     [Netdev]     [Networking]     [Security]     [V4L]     [Bugtraq]     [Yosemite]     [MIPS Linux]     [ARM Linux]     [Linux Security]     [Linux RAID]     [Linux SCSI]     [Fedora Users]

  Powered by Linux