On Mon, Oct 10, 2016 at 07:02:11PM +0530, Parav Pandit wrote: > Hi Tejun, > > On Mon, Oct 10, 2016 at 6:50 PM, Tejun Heo <tj@xxxxxxxxxx> wrote: > > Hello, Parav. > > > > On Mon, Oct 10, 2016 at 06:43:59PM +0530, Parav Pandit wrote: > >> > Also, I don't get what you mean by using percentage and when people > >> > brought up this idea, it always has been stemming from > >> > misunderstanding. Can you please elaborate how percentage based > >> > proportional control would work? What would 100% mean when cgroups > >> > can come and go? > >> > >> When 100% is given to one cgroup, all resources of all type can be > >> charged by processes of that cgroup. > >> Resources are stateful resource. So when cgroup goes away, they go > >> back to global pool (or hw). > >> Giving 100% to two cgroups is configuration error anyway (or without config). > > > > That isn't proportional control. That's using percentage as the unit > > to implement absolute limits. Proportional control implies work > > conservation. > > > >> As you know weight configuration allows automatic increase/decrease of > >> resource to other cgroups when one of them go away, as opposed to > >> absolute value. How this is going to work in exact terms for stateful > > > > Hmm.... so are you saying that ti'd be work-conserving? > They cannot be work conversing. > > > But what does > > it mean to say "30%" and then have it all resources when there are no > > other users. Also, is it even possible to take back what have already > > been allocated and are in use? > > > Most resources that I know of, and whats described in current > cgroup_rdma.h are not work conversing, therefore it cannot be taken > back. > > >> Nop. Thats not true. > >> (a) Every new resource has to be defined in cgroup_rdma.h > >> (b) charge()/uncharge() has to happen by the cgroup for each. > >> (c) Letting drivers do will make things fall apart. There are no APIs > >> exposed either to let drivers know process cgroup either. There is no > >> intention either. > >> > >> (d) ratio means -if adapter has > >> 100 resources of type - A, > >> 80 resource of type - B, > >> > >> 10% for cgroup-1 means, > >> 10 resource of type - A > >> 8 resource of type - B > > > > So, this is not work-conserving. There's too much confusion here. > > Give me some more time, I will think more and take feeback from Leon > and others on > (a) how can we implement or want to implement weight like > functionality for non-work-conversing resource I'm not fully understand the question. RDMA resources are static and won't be recalculated dynamically for running cgroups consumers while new cgroup is started. In this situation, weights and percentages are the same. > (b) what could be its acceptable limitations of that interface would be > before we propose you. More easy is to summarize requirements: 1. It needs to be convenient for users. 2. It can limit any future objects without change in user tools. > > At minimum we would need to expose actual value in rdma.max in > subsequent patch, instead of exposing just "max" string. I don't want > to complicate this discussion but similar functionality is needed for > pid controller as well to expose actual value. > > > > > Thanks. > > > > -- > > tejun
Attachment:
signature.asc
Description: PGP signature