Re: [PATCH v6 14/16] refs/iterator: implement seeking for packed-ref iterators

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

 



On Thu, Apr 03, 2025 at 12:56:39PM -0700, Elijah Newren wrote:
> On Wed, Mar 12, 2025 at 11:42 PM Patrick Steinhardt <ps@xxxxxx> wrote:
> >
> 
> > @@ -951,12 +954,41 @@ static int packed_ref_iterator_advance(struct ref_iterator *ref_iterator)
> >                                             &iter->oid, iter->flags))
> >                         continue;
> >
> > +               while (prefix && *prefix) {
> > +                       if (*refname < *prefix)
> > +                               BUG("packed-refs backend yielded reference preceding its prefix");
> 
> I just triggered this bug upon a "git pull" in an internal repository:
> 
> $ git pull
> remote: Enumerating objects: 161255, done.
> remote: Counting objects: 100% (55884/55884), done.
> remote: Compressing objects: 100% (5518/5518), done.
> remote: Total 161255 (delta 54253), reused 50509 (delta 50364),
> pack-reused 105371 (from 4)
> Receiving objects: 100% (161255/161255), 309.90 MiB | 16.87 MiB/s, done.
> Resolving deltas: 100% (118048/118048), completed with 13416 local objects.
> From github.com:github/github
>    97ab7ae3f3745..8fb2f9fa180ed  master
>                     -> origin/master
> [...snip many screenfuls of updates to origin remotes...]
> BUG: refs/packed-backend.c:984: packed-refs backend yielded reference
> preceding its prefix
> error: fetch died of signal 6
> 
> I made a backup of the repo with rsync.

Thanks, I can indeed reproduce the issue rather easily:

	test_expect_success 'list refs with unicode characters' '
		test_when_finished "rm -rf repo" &&
		git init repo &&
		(
			cd repo &&
			test_commit A &&
			git update-ref refs/heads/ HEAD &&
			git pack-refs --all &&
			git for-each-ref refs/heads/z
		)
	'

I'll investigate.

Patrick




[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