On 10/11/21 11:09, Roman Gushchin wrote: > > Convenient will be only true assuming you have a full comprehensive list of > > hooks to never require adding a new one. As I highlighted above, this > > convenience is limited to hooks that you added now. > > > > Do people always want more hooks? Rhetorical question ;-) > > Why do you think that the list of the hooks will be so large/dynamic? It's not a fact. Just my thoughts/guess based on how things usually end up. It's very likely this will grow. I could be wrong of course :) > I'm not saying we can figure it out from a first attempt, but I'm pretty sure > that after some initial phase it can be relatively stable, e.g. changing only > with some _major_ changes in the scheduler code. My point was that the speed up in workflow will be limited by the what's available. It might be enough for a large use cases as you say, but at some point there will be a new bottleneck that you might think worth experimenting with and the chances a suitable hook is available are 50:50 in theory. So it's not a magical fix where one would *never* have to push a custom kernel on all these systems to experiment with some scheduler changes. > > > > So my worry is that this will open the gate for these hooks to get more than > > > > just micro-optimization done in a platform specific way. And that it will > > > > discourage having the right discussion to fix real problems in the scheduler > > > > because the easy path is to do whatever you want in userspace. I am not sure we > > > > can control how these hooks are used. > > > > > > I totally understand your worry. I think we need to find a right balance between > > > allowing to implement custom policies and keeping the core functionality > > > working well enough for everybody without a need to tweak anything. > > > > > > It seems like an alternative to this "let's allow cfs customization via bpf" > > > approach is to completely move the scheduler code into userspace/bpf, something > > > that Google's ghOSt is aiming to do. > > > > Why not ship a custom kernel instead then? > > Shipping a custom kernel (actually any kernel) at this scale isn't easy or fast. > Just for example, imagine a process of rebooting of a 1000000 machines running > 1000's different workloads, each with their own redundancy and capacity requirements. > > This what makes an ability to push scheduler changes without a reboot/kernel upgrade > so attractive. > > Obviously, it's not a case when we talk about a single kernel engineer and their > laptop/dev server/vm. I think you're still referring to ghOSt here. I thought your 2 use cases are different as you mentioned they "completely move the scheduler code into userspace/bpf"; but it could be just me mis-interpreting what this means. That didn't read to me they want to micro-optimize (few) certain decisions in the scheduler, rather replace it altogether, hence my question. Anyway. My 2cents here is that we should be careful not to introduce something that encourages out-of-tree workarounds for real scheduler problems nor have it done in a way where we lose visibility over how these hooks are used and being able to share it with others who could benefit from the same mico-optimization too. Thanks! -- Qais Yousef