Hello, On Wed, May 10, 2023 at 04:59:01PM +0200, Maarten Lankhorst wrote: > The misc controller is not granular enough. A single computer may have any number of > graphics cards, some of them with multiple regions of vram inside a single card. Extending the misc controller to support dynamic keys shouldn't be that difficult. ... > In the next version, I will move all the code for handling the resource limit to > TTM's eviction layer, because otherwise it cannot handle the resource limit correctly. > > The effect of moving the code to TTM, is that it will make the code even more generic > for drivers that have vram and use TTM. When using TTM, you only have to describe your > VRAM, update some fields in the TTM manager and (un)register your device with the > cgroup handler on (un)load. It's quite trivial to add vram accounting to amdgpu and > nouveau. [2] > > If you want to add a knob for scheduling weight for a process, it makes sense to > also add resource usage as a knob, otherwise the effect of that knob is very > limited. So even for Tvrtko's original proposed usecase, it would make sense. It does make sense but unlike Tvrtko's scheduling weights what's being proposed doesn't seem to encapsulate GPU memory resource in a generic enough manner at least to my untrained eyes. ie. w/ drm.weight, I don't need any specific knoweldge of how a specific GPU operates to say "this guy should get 2x processing power over that guy". This more or less holds for other major resources including CPU, memory and IO. What you're proposing seems a lot more tied to hardware details and users would have to know a lot more about how memory is configured on that particular GPU. Now, if this is inherent to how all, or at least most, GPUs operate, sure, but otherwise let's start small in terms of interface and not take up space which should be for something universal. If this turns out to be the way, expanding to take up the generic interface space isn't difficult. I don't know GPU space so please educate me where I'm wrong. Thanks. -- tejun