Paul! On Thu, Oct 19 2023 at 12:13, Paul E. McKenney wrote: > On Thu, Oct 19, 2023 at 02:21:35AM +0200, Thomas Gleixner wrote: >> The important point is that at the very end the scheduler has the >> ultimate power to say: "Not longer Mr. Nice Guy" without the risk of any >> random damage due to the fact that preemption count is functional, which >> makes your life easier as well as you admitted already. But that does >> not mean you can eat the cake and still have it. :) > > Which is exactly why I need rcu_read_lock() to map to preempt_disable() > and rcu_read_unlock() to preempt_enable(). ;-) After reading back in the thread, I think we greatly talked past each other mostly due to the different expectations and the resulting dependencies which seem to be hardwired into our brains. I'm pleading guilty as charged as I failed completely to read your initial statement "The key thing to note is that from RCU's viewpoint, with this change, all kernels are preemptible, though rcu_read_lock() readers remain non-preemptible." with that in mind and instead of dissecting it properly I committed the fallacy of stating exactly the opposite, which obviously reflects only the point of view I'm coming from. With a fresh view, this turns out to be a complete non-problem because there is no semantical dependency between the preemption model and the RCU flavour. The unified kernel preemption model has the following properties: 1) It provides full preemptive multitasking. 2) Preemptability is limited by implicit and explicit mechanisms. 3) The ability to avoid overeager preemption for SCHED_OTHER tasks via the PREEMPT_LAZY mechanism. This emulates the NONE/VOLUNTARY preemption models which semantically provide collaborative multitasking. This emulation is not breaking the semantical properties of full preemptive multitasking because the scheduler still has the ability to enforce immediate preemption under consideration of #2. Which in turn is a prerequiste for removing the semantically ill-defined cond/might_resched() constructs. The compile time selectable RCU flavour (preemptible/non-preemptible) is not imposing a semantical change on this unified preemption model. The selection of the RCU flavour is solely affecting the preemptability (#2 above). Selecting non-preemptible RCU reduces preemptability by adding an implicit restriction via mapping rcu_read_lock() to preempt_disable(). IOW, the current upstream enforcement of RCU_PREEMPT=n when PREEMPTION=n is only enforced by the the lack of the full preempt counter in PREEMPTION=n configs. Once the preemption counter is always enabled this hardwired dependency goes away. Even PREEMPT_DYNAMIC should just work with RCU_PREEMPT=n today because with PREEMPT_DYNAMIC the preemption counter is unconditionally available. So that makes these hardwired dependencies go away in practice and hopefully soon from our mental models too :) RT will keep its hard dependency on RCU_PREEMPT in the same way it depends hard on forced interrupt threading and other minor details to enable the spinlock substitution. >> That said, I completely understand your worries about the consequences, >> but please take the step back and look at it from a conceptual point of >> view. > > Conceptual point of view? That sounds suspiciously academic. Hehehe. > Who are you and what did you do with the real Thomas Gleixner? ;-) The point I'm trying to make is not really academic, it comes from a very practical point of view. As you know for almost two decades I'm mostly busy with janitoring and mopping up the kernel. A major takeaway from this eclectic experience is that there is a tendency to implement very specialized solutions for different classes of use cases. The reasons to do so in the first place: 1) Avoid breaking the existing and established solutions: E.g. the initial separation of x8664 and i386 2) Enforcement due to dependencies on mechanisms, which are considered "harmful" for particular use cases E.g. Preemptible RCU, which is separate also due to #1 3) Because we can and something is sooo special You probably remember the full day we both spent in a room with SoC people to make them understand that their SoCs are not so special at all. :) So there are perfectly valid reasons (#1, #2) to separate things, but we really need to go back from time to time and think hard about the question whether a particular separation is still justified. This is especially true when dependencies or prerequisites change. But in many cases we just keep going, take the separation as set in stone forever and add features and workarounds on all ends without rethinking whether we could unify these things for the better. The real bad thing about this is that the more we add to the separation the harder consolidation or unification becomes. Granted that my initial take of consolidating on preemptible RCU might be too brisk or too naive, but I still think that with the prospect of an unified preemption model it's at least worth to have a very close look at this question. Not asking such questions or dismissing them upfront is a real danger for the long term sustainability and maintainability of the kernel in my opinion. Especially when the few people who actively "janitor" these things are massively outnumbered by people who indulge in specialization. :) That said, the real Thomas Gleixner and his grumpy self are still there, just slightly tired of handling the slurry brush all day long :) Thanks, tglx