* Re: linux-next: stackprotector tree build failure
[not found] ` <20081022182149.f89fe88d.sfr@canb.auug.org.au>
@ 2008-10-22 7:29 ` Ingo Molnar
2008-10-22 8:27 ` Stephen Rothwell
0 siblings, 1 reply; 6+ messages in thread
From: Ingo Molnar @ 2008-10-22 7:29 UTC (permalink / raw)
To: Stephen Rothwell
Cc: Thomas Gleixner, H. Peter Anvin, linux-next, Junio C Hamano, git
* Stephen Rothwell <sfr@canb.auug.org.au> wrote:
> Hi Ingo,
>
> On Wed, 22 Oct 2008 06:32:27 +0200 Ingo Molnar <mingo@elte.hu> wrote:
> >
> > This seems to have been caused by a git-rerere bug - it mis-matched a
> > timers tree conflict resolution. I cleared out that resolution (it had
> > nothing to do with stackprotector), re-did the conflict resolution
> > (which was about overlapping additions of header files), and pushed out
> > a new stackprotector tree - the delta below has the expected result.
>
> I wondered how you could have possibly got that result - aren't
> computers wonderful! :-)
heh, yes :)
this is the second time i met a git-rerere mismatch - the first one was
half a year ago.
Unfortunately i failed at generating a reproducer back then and even now
- as to resolve this problem i manually removed the preimage and
postimage, so it's gone now.
I've Cc:-ed Junio and the Git list as a general FYI - but it must be
frustrating to get such a bugreport, because i have no reproducer.
git-rerere sometimes seems to be picking up the wrong resolution. VERY
rarely.
It seems random and content dependent. Once it happened to
arch/x86/kernel/traps_32.c and now to kernel/fork.c. Along the ~170
successful resolutions i have in my tree right now. And i do many
conflict resolutions every day - and it happened only once every 6
months or so.
(the arch/x86/kernel/traps_32.c one happened regularly, that's why i
thought it's content sha1 dependent, and not some corruption.)
Next time it happens i'll be on the watchout and will save the complete
tree.
Ingo
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: linux-next: stackprotector tree build failure
2008-10-22 7:29 ` linux-next: stackprotector tree build failure Ingo Molnar
@ 2008-10-22 8:27 ` Stephen Rothwell
2008-10-22 8:31 ` Stephen Rothwell
2008-10-22 8:31 ` Ingo Molnar
0 siblings, 2 replies; 6+ messages in thread
From: Stephen Rothwell @ 2008-10-22 8:27 UTC (permalink / raw)
To: Ingo Molnar
Cc: Thomas Gleixner, H. Peter Anvin, linux-next, Junio C Hamano, git
[-- Attachment #1: Type: text/plain, Size: 1292 bytes --]
On Wed, 22 Oct 2008 09:29:23 +0200 Ingo Molnar <mingo@elte.hu> wrote:
>
> I've Cc:-ed Junio and the Git list as a general FYI - but it must be
> frustrating to get such a bugreport, because i have no reproducer.
>
> git-rerere sometimes seems to be picking up the wrong resolution. VERY
> rarely.
>
> It seems random and content dependent. Once it happened to
> arch/x86/kernel/traps_32.c and now to kernel/fork.c. Along the ~170
> successful resolutions i have in my tree right now. And i do many
> conflict resolutions every day - and it happened only once every 6
> months or so.
>
> (the arch/x86/kernel/traps_32.c one happened regularly, that's why i
> thought it's content sha1 dependent, and not some corruption.)
>
> Next time it happens i'll be on the watchout and will save the complete
> tree.
I think rerere matches preimages on the SHA1 of the conflict (or its
reverse), so sufficiently similar pieces of code will match. I would
expect things like ext2/3/4 to be candidates. Did the traps_32.c one
match one for traps_64.c?
I may be mistaken, but I once followed the code in rerere to try to
figure out how to fix a resolution.
--
Cheers,
Stephen Rothwell sfr@canb.auug.org.au
http://www.canb.auug.org.au/~sfr/
[-- Attachment #2: Type: application/pgp-signature, Size: 197 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: linux-next: stackprotector tree build failure
2008-10-22 8:27 ` Stephen Rothwell
@ 2008-10-22 8:31 ` Stephen Rothwell
2008-10-22 8:31 ` Ingo Molnar
1 sibling, 0 replies; 6+ messages in thread
From: Stephen Rothwell @ 2008-10-22 8:31 UTC (permalink / raw)
To: Ingo Molnar
Cc: Thomas Gleixner, H. Peter Anvin, linux-next, Junio C Hamano, git
[-- Attachment #1: Type: text/plain, Size: 566 bytes --]
On Wed, 22 Oct 2008 19:27:25 +1100 Stephen Rothwell <sfr@canb.auug.org.au> wrote:
>
> I think rerere matches preimages on the SHA1 of the conflict (or its
> reverse), so sufficiently similar pieces of code will match. I would
> expect things like ext2/3/4 to be candidates. Did the traps_32.c one
> match one for traps_64.c?
Or, of course similar conflicts in different merges in different branches
of the same tree are really asking for it ...
--
Cheers,
Stephen Rothwell sfr@canb.auug.org.au
http://www.canb.auug.org.au/~sfr/
[-- Attachment #2: Type: application/pgp-signature, Size: 197 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: linux-next: stackprotector tree build failure
2008-10-22 8:27 ` Stephen Rothwell
2008-10-22 8:31 ` Stephen Rothwell
@ 2008-10-22 8:31 ` Ingo Molnar
2008-10-22 17:41 ` Johannes Schindelin
1 sibling, 1 reply; 6+ messages in thread
From: Ingo Molnar @ 2008-10-22 8:31 UTC (permalink / raw)
To: Stephen Rothwell
Cc: Thomas Gleixner, H. Peter Anvin, linux-next, Junio C Hamano, git
* Stephen Rothwell <sfr@canb.auug.org.au> wrote:
> On Wed, 22 Oct 2008 09:29:23 +0200 Ingo Molnar <mingo@elte.hu> wrote:
> >
> > I've Cc:-ed Junio and the Git list as a general FYI - but it must be
> > frustrating to get such a bugreport, because i have no reproducer.
> >
> > git-rerere sometimes seems to be picking up the wrong resolution. VERY
> > rarely.
> >
> > It seems random and content dependent. Once it happened to
> > arch/x86/kernel/traps_32.c and now to kernel/fork.c. Along the ~170
> > successful resolutions i have in my tree right now. And i do many
> > conflict resolutions every day - and it happened only once every 6
> > months or so.
> >
> > (the arch/x86/kernel/traps_32.c one happened regularly, that's why i
> > thought it's content sha1 dependent, and not some corruption.)
> >
> > Next time it happens i'll be on the watchout and will save the complete
> > tree.
>
> I think rerere matches preimages on the SHA1 of the conflict (or its
> reverse), so sufficiently similar pieces of code will match. I would
> expect things like ext2/3/4 to be candidates. Did the traps_32.c one
> match one for traps_64.c?
>
> I may be mistaken, but I once followed the code in rerere to try to
> figure out how to fix a resolution.
the traps_32.c one was that git-rerere put in a traps_64.c end result.
So i ended up with a 32-bit kernel that tried to build a 64-bit piece of
code - fireworks. That condition persisted - i had to fix it up manually
all the time i integrated that portion of the tree. That too was i think
centered around a header file chunk - perhaps the #include section of
traps_32.c and traps_64.c was similar enough in that section?
Ingo
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: linux-next: stackprotector tree build failure
2008-10-22 8:31 ` Ingo Molnar
@ 2008-10-22 17:41 ` Johannes Schindelin
2008-10-22 23:54 ` Stephen Rothwell
0 siblings, 1 reply; 6+ messages in thread
From: Johannes Schindelin @ 2008-10-22 17:41 UTC (permalink / raw)
To: Ingo Molnar
Cc: Stephen Rothwell, Thomas Gleixner, H. Peter Anvin, linux-next,
Junio C Hamano, git
Hi,
On Wed, 22 Oct 2008, Ingo Molnar wrote:
>
> * Stephen Rothwell <sfr@canb.auug.org.au> wrote:
>
> > On Wed, 22 Oct 2008 09:29:23 +0200 Ingo Molnar <mingo@elte.hu> wrote:
> > >
> > > I've Cc:-ed Junio and the Git list as a general FYI - but it must be
> > > frustrating to get such a bugreport, because i have no reproducer.
> > >
> > > git-rerere sometimes seems to be picking up the wrong resolution. VERY
> > > rarely.
> > >
> > > It seems random and content dependent. Once it happened to
> > > arch/x86/kernel/traps_32.c and now to kernel/fork.c. Along the ~170
> > > successful resolutions i have in my tree right now. And i do many
> > > conflict resolutions every day - and it happened only once every 6
> > > months or so.
> > >
> > > (the arch/x86/kernel/traps_32.c one happened regularly, that's why i
> > > thought it's content sha1 dependent, and not some corruption.)
> > >
> > > Next time it happens i'll be on the watchout and will save the complete
> > > tree.
> >
> > I think rerere matches preimages on the SHA1 of the conflict (or its
> > reverse), so sufficiently similar pieces of code will match. I would
> > expect things like ext2/3/4 to be candidates. Did the traps_32.c one
> > match one for traps_64.c?
> >
> > I may be mistaken, but I once followed the code in rerere to try to
> > figure out how to fix a resolution.
>
> the traps_32.c one was that git-rerere put in a traps_64.c end result.
> So i ended up with a 32-bit kernel that tried to build a 64-bit piece of
> code - fireworks. That condition persisted - i had to fix it up manually
> all the time i integrated that portion of the tree. That too was i think
> centered around a header file chunk - perhaps the #include section of
> traps_32.c and traps_64.c was similar enough in that section?
I think it might be in order to explain how git-rerere works internally:
- in case of a conflicts, the files' conflicts are written into the
rr-cache _per file_.
First, the human readable stuff after the "<<<", "|||" and ">>>" lines
is removed.
Then, the "||| ... ===" part is removed, too (in effect turning the
diff3-style conflicts into an RCS merge-style conflicts).
The result is recorded as "preimage". The conflict is identified by the
SHA-1 of _just_ the conflicts (including the "<<<", "===" and ">>>"
lines).
After all the conflicted files have been handled, a list is written to
the file "MERGE_RR" containing the SHA-1s of the conflicts together with
the file names.
- when committing, the files whose conflicts were resolved are recorded
verbatim in the file "postimage".
Now, when rerere is called again and there are conflicted files, again the
files' conflicts are identified by their SHA-1. If a resolution exists, a
3-way merge is performed with the recorded preimage (the
original file with conflict lines) as base, the postimage (the originally
resolved file) and the current file with conflict lines.
The idea being: the diff between the recorded preimage and postimage gives
the resolution that you want, and the diff between the recorded preimage
and the current file with conflict lines gives you the changes that
happened to the file in-between.
So I think that you might hit the unfortunate case where two files
happened to have the same conflicts, but you needed to resolve them one
way for one file, and another way for the other file.
Ciao,
Dscho
^ permalink raw reply [flat|nested] 6+ messages in thread
* Re: linux-next: stackprotector tree build failure
2008-10-22 17:41 ` Johannes Schindelin
@ 2008-10-22 23:54 ` Stephen Rothwell
0 siblings, 0 replies; 6+ messages in thread
From: Stephen Rothwell @ 2008-10-22 23:54 UTC (permalink / raw)
To: Johannes Schindelin
Cc: Ingo Molnar, Thomas Gleixner, H. Peter Anvin, linux-next,
Junio C Hamano, git
[-- Attachment #1: Type: text/plain, Size: 585 bytes --]
Hi Johannes,
On Wed, 22 Oct 2008 19:41:18 +0200 (CEST) Johannes Schindelin <Johannes.Schindelin@gmx.de> wrote:
>
> I think it might be in order to explain how git-rerere works internally:
Thanks for the explanation.
> So I think that you might hit the unfortunate case where two files
> happened to have the same conflicts, but you needed to resolve them one
> way for one file, and another way for the other file.
Which makes perfect sense, unfortunately.
--
Cheers,
Stephen Rothwell sfr@canb.auug.org.au
http://www.canb.auug.org.au/~sfr/
[-- Attachment #2: Type: application/pgp-signature, Size: 197 bytes --]
^ permalink raw reply [flat|nested] 6+ messages in thread
end of thread, other threads:[~2008-10-22 23:56 UTC | newest]
Thread overview: 6+ messages (download: mbox.gz follow: Atom feed
-- links below jump to the message on this page --
[not found] <20081022131124.a572b11f.sfr@canb.auug.org.au>
[not found] ` <20081022043227.GA31413@elte.hu>
[not found] ` <20081022182149.f89fe88d.sfr@canb.auug.org.au>
2008-10-22 7:29 ` linux-next: stackprotector tree build failure Ingo Molnar
2008-10-22 8:27 ` Stephen Rothwell
2008-10-22 8:31 ` Stephen Rothwell
2008-10-22 8:31 ` Ingo Molnar
2008-10-22 17:41 ` Johannes Schindelin
2008-10-22 23:54 ` Stephen Rothwell
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).