On Wed, Jul 14, 2021 at 09:52:53AM -0400, Sasha Levin wrote:
On Wed, Jul 14, 2021 at 11:18:14AM +0200, Greg Kroah-Hartman wrote:
On Tue, Jul 13, 2021 at 06:28:13PM -0700, Andrew Morton wrote:
Alternatively I could just invent a new tag to replace the "Fixes:" ("Fixes-no-backport?") to be used on patches which fix a known previous commit but which we don't want backported.
No please, that's not needed, I'll just ignore these types of patches now, and will go drop these from the queues.
Sasha, can you also add these to your "do not apply" script as well?
Sure, but I don't see how this is viable in the long term. Look at distros that don't follow LTS trees and cherry pick only important fixes, and see how many of those don't have a stable@ tag.
I've been talking to an enterprise distro who chooses not to use the LTS releases, and it's mainly because they tried it, and there was too many regressions leading to their customers filing problem reports which get escalated to their engineers, leading to unhappy customers and extra work for their engineers. (And they have numbers to back up this assertion; this isn't just a gut feel sort of thing.)
There are a couple of ways of solving it. Once is that perhaps we need to have more people testing the stable trees --- and not just for functional regressions but also for performance regressions. Ideally we would be doing lots of performance regression testing all the time, for all releases, and not just for the stable kernels, but the reality is that performance testing takes a lot of time, effort, and in some cases large amounts of expensive equipment.
We have syzbot and the zero-day bot; perhaps we can see if some company might be interested in setting up a "perfbot"?
Another solution (and these don't have to be mutually exclusive) might be for maintainers can explicitly state that certain patches shouldn't be backported into stable kernels. I think having an explicit "No-Backport: <Reason>" might be useful, since it documents why a maintainer requested that the patch not be backported, and being an explicit tag, it makes it clear that it wasn't just a case of the developer forgetting the "Cc: stable" tag. This makes it much better than implicit rules such as "If from: akpm then don't backport" hidden in various stable maintainers' scripts.
- Ted