git@vger.kernel.org mailing list mirror (one of many)
 help / color / mirror / code / Atom feed
* Signal conflict on merging metadata-differing patches
@ 2019-11-18 17:29 Eugeniu Rosca
  2019-11-18 17:35 ` Greg KH
  0 siblings, 1 reply; 5+ messages in thread
From: Eugeniu Rosca @ 2019-11-18 17:29 UTC (permalink / raw)
  To: git; +Cc: linux-kernel, Greg KH, Felipe Balbi, Eugeniu Rosca, Eugeniu Rosca

Dear Git community,

Due to high inflow of patches which Linux maintainers carry on their
shoulders and due to occasionally intricate relationships between
consecutive revisions of the same series, it may [1] happen that two
distinct revisions of the same patch (differing only/mostly in
metadata, e.g. Author's time-stamp and commit description) may end up
being merged on the same branch, without git to complain about that.

Is there any "git merge" flag available off-the-shelf which (if used)
would signal such situations?

[1] https://patchwork.kernel.org/patch/11135107/#23007101

-- 
Best Regards,
Eugeniu

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: Signal conflict on merging metadata-differing patches
  2019-11-18 17:29 Signal conflict on merging metadata-differing patches Eugeniu Rosca
@ 2019-11-18 17:35 ` Greg KH
  2019-11-18 18:45   ` Eugeniu Rosca
  0 siblings, 1 reply; 5+ messages in thread
From: Greg KH @ 2019-11-18 17:35 UTC (permalink / raw)
  To: Eugeniu Rosca; +Cc: git, linux-kernel, Felipe Balbi, Eugeniu Rosca

On Mon, Nov 18, 2019 at 06:29:17PM +0100, Eugeniu Rosca wrote:
> Dear Git community,
> 
> Due to high inflow of patches which Linux maintainers carry on their
> shoulders and due to occasionally intricate relationships between
> consecutive revisions of the same series, it may [1] happen that two
> distinct revisions of the same patch (differing only/mostly in
> metadata, e.g. Author's time-stamp and commit description) may end up
> being merged on the same branch, without git to complain about that.

Why would git complain about that?

> Is there any "git merge" flag available off-the-shelf which (if used)
> would signal such situations?

I don't understand what you are looking for here.  Two different
versions of the patch were merged to different branches and then merged
together, and git did the right thing with the resolution of the code.

What more can it do here?

thanks,

greg k-h

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: Signal conflict on merging metadata-differing patches
  2019-11-18 17:35 ` Greg KH
@ 2019-11-18 18:45   ` Eugeniu Rosca
  2019-11-18 19:48     ` Greg KH
  0 siblings, 1 reply; 5+ messages in thread
From: Eugeniu Rosca @ 2019-11-18 18:45 UTC (permalink / raw)
  To: Greg KH; +Cc: Eugeniu Rosca, git, linux-kernel, Felipe Balbi, Eugeniu Rosca

On Mon, Nov 18, 2019 at 06:35:17PM +0100, Greg KH wrote:
> On Mon, Nov 18, 2019 at 06:29:17PM +0100, Eugeniu Rosca wrote:
> > Dear Git community,
> > 
> > Due to high inflow of patches which Linux maintainers carry on their
> > shoulders and due to occasionally intricate relationships between
> > consecutive revisions of the same series, it may [1] happen that two
> > distinct revisions of the same patch (differing only/mostly in
> > metadata, e.g. Author's time-stamp and commit description) may end up
> > being merged on the same branch, without git to complain about that.
> 
> Why would git complain about that?

This would help those performing the merge identify and (if needed)
avoid having several slightly different patches on the same branch.

> 
> > Is there any "git merge" flag available off-the-shelf which (if used)
> > would signal such situations?
> 
> I don't understand what you are looking for here.  Two different
> versions of the patch were merged to different branches and then merged
> together, and git did the right thing with the resolution of the code.

I personally care about commit metadata (i.e. Author's/Committer's names
and timestamps, as well as commit description) as much as (and sometimes
more than) the code contents of the patch.

If I am given multiple patches which perform the same code changes, but
provide different descriptions, this _already_ generates potential work
on my plate, since I have to make sense of those differences when I
stumble upon them. Which patch do I recommend to the customer (who,
let's say, still lives on the older v4.14 LTS), if I am asked to?

Why should I (or anybody else) spend time doing research at all, if this
can be avoided by just passing an additional option to "git merge"?

It is the most basic requirement I can think of that the maintainers
select the _latest_ version of a patch series, without intertwining it
with a superseded version.

> 
> What more can it do here?

Currently Git says nothing in below merge scenarios (all of them are
conflict-less successful merges):
 - Merge two commits which perform identical code changes but have
   different metadata
 - Merge commit "A" and commits ("B", "C", "D"), the latter being
   subsets of "A"

I don't advocate for "git merge" to fail in the above scenarios. No.
I just say that Git could likely detect such scenarios and help people
like you not pushing v2 and v5 of the same patch into the main tree.

> 
> thanks,
> 
> greg k-h

-- 
Best Regards,
Eugeniu

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: Signal conflict on merging metadata-differing patches
  2019-11-18 18:45   ` Eugeniu Rosca
@ 2019-11-18 19:48     ` Greg KH
  2019-11-19  2:04       ` Junio C Hamano
  0 siblings, 1 reply; 5+ messages in thread
From: Greg KH @ 2019-11-18 19:48 UTC (permalink / raw)
  To: Eugeniu Rosca; +Cc: git, linux-kernel, Felipe Balbi, Eugeniu Rosca

On Mon, Nov 18, 2019 at 07:45:23PM +0100, Eugeniu Rosca wrote:
> On Mon, Nov 18, 2019 at 06:35:17PM +0100, Greg KH wrote:
> > On Mon, Nov 18, 2019 at 06:29:17PM +0100, Eugeniu Rosca wrote:
> > > Dear Git community,
> > > 
> > > Due to high inflow of patches which Linux maintainers carry on their
> > > shoulders and due to occasionally intricate relationships between
> > > consecutive revisions of the same series, it may [1] happen that two
> > > distinct revisions of the same patch (differing only/mostly in
> > > metadata, e.g. Author's time-stamp and commit description) may end up
> > > being merged on the same branch, without git to complain about that.
> > 
> > Why would git complain about that?
> 
> This would help those performing the merge identify and (if needed)
> avoid having several slightly different patches on the same branch.

The patches were not on the same branch to start with, they ended up on
two different branches that got merged together at some point in time
later on.

This happens all the time in kernel development :)

> > > Is there any "git merge" flag available off-the-shelf which (if used)
> > > would signal such situations?
> > 
> > I don't understand what you are looking for here.  Two different
> > versions of the patch were merged to different branches and then merged
> > together, and git did the right thing with the resolution of the code.
> 
> I personally care about commit metadata (i.e. Author's/Committer's names
> and timestamps, as well as commit description) as much as (and sometimes
> more than) the code contents of the patch.
> 
> If I am given multiple patches which perform the same code changes, but
> provide different descriptions, this _already_ generates potential work
> on my plate, since I have to make sense of those differences when I
> stumble upon them. Which patch do I recommend to the customer (who,
> let's say, still lives on the older v4.14 LTS), if I am asked to?

Welcome to my life :)

As I said above, this happens quite frequently, and honestly, I just
live with it.  Look at the kernel's DRM branch for the main abusers of
this, they cherry-pick patches from their local tree to a tree to send
to Linus today, with the sha1 in the commit message.  That means that
Linus ends up with a commit referencing a sha1 that will not show up in
his tree until sometime in the _future_.

It causes havoc with my scripts and I hate it.

But, it makes things easier for the developers and maintainers of that
subsystem and in the end, that's what really matters.  Stable and
backports should almost never cause developers any problems or extra
work as that is not their responsibility.

> Why should I (or anybody else) spend time doing research at all, if this
> can be avoided by just passing an additional option to "git merge"?
> 
> It is the most basic requirement I can think of that the maintainers
> select the _latest_ version of a patch series, without intertwining it
> with a superseded version.

I really don't understand what you expect to have happen here.

Look at the drm tree again, what should git do sometime in the future
when the same "logical change" gets merged into Linus's tree.  I think
it should do what it does today, handle the merge of the code changes
just fine and allow for perfect representation at any point in time what
the tree looked like if you check it out then.

What should git do instead?

> > What more can it do here?
> 
> Currently Git says nothing in below merge scenarios (all of them are
> conflict-less successful merges):
>  - Merge two commits which perform identical code changes but have
>    different metadata
>  - Merge commit "A" and commits ("B", "C", "D"), the latter being
>    subsets of "A"
> 
> I don't advocate for "git merge" to fail in the above scenarios. No.
> I just say that Git could likely detect such scenarios and help people
> like you not pushing v2 and v5 of the same patch into the main tree.

But what should it do in either of those above situations?  Fail the
merge?  No, that's not ok as those different branches were just fine on
their own and I will never expect them to be rebased/rewritten just for
something like this.  That's crazy.

thanks,

greg k-h

^ permalink raw reply	[flat|nested] 5+ messages in thread

* Re: Signal conflict on merging metadata-differing patches
  2019-11-18 19:48     ` Greg KH
@ 2019-11-19  2:04       ` Junio C Hamano
  0 siblings, 0 replies; 5+ messages in thread
From: Junio C Hamano @ 2019-11-19  2:04 UTC (permalink / raw)
  To: Greg KH; +Cc: Eugeniu Rosca, git, linux-kernel, Felipe Balbi, Eugeniu Rosca

Greg KH <gregkh@linuxfoundation.org> writes:

>> I don't advocate for "git merge" to fail in the above scenarios. No.
>> I just say that Git could likely detect such scenarios and help people
>> like you not pushing v2 and v5 of the same patch into the main tree.
>
> But what should it do in either of those above situations?  Fail the
> merge?  No, that's not ok as those different branches were just fine on
> their own and I will never expect them to be rebased/rewritten just for
> something like this.  That's crazy.

;-)

I agree that the requested "feature" would make no sense for kernel
maintainers at various levels, as long as they are dealing with
merges among published branches.  What's done at the submaintainers'
trees are better treated as "already cast in stone".

It may be a useful feature when one maintains a bag of local/private
branches that haven't been published, though.  I however do not know
what its implementation would look like X-<.


^ permalink raw reply	[flat|nested] 5+ messages in thread

end of thread, other threads:[~2019-11-19  2:04 UTC | newest]

Thread overview: 5+ messages (download: mbox.gz / follow: Atom feed)
-- links below jump to the message on this page --
2019-11-18 17:29 Signal conflict on merging metadata-differing patches Eugeniu Rosca
2019-11-18 17:35 ` Greg KH
2019-11-18 18:45   ` Eugeniu Rosca
2019-11-18 19:48     ` Greg KH
2019-11-19  2:04       ` Junio C Hamano

Code repositories for project(s) associated with this public inbox

	https://80x24.org/mirrors/git.git

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 read-only IMAP folder(s) and NNTP newsgroup(s).