On Tue, Apr 6, 2021 at 6:39 PM Pavan Kondeti <pkondeti@xxxxxxxxxxxxxx> wrote: > > On Tue, Apr 06, 2021 at 12:15:24PM -0400, Tejun Heo wrote: > > Hello, > > > > On Tue, Apr 06, 2021 at 08:57:15PM +0530, Pavan Kondeti wrote: > > > Yeah. The workqueue attrs comes in handy to reduce the nice/prio of a > > > background workqueue if we identify that it is cpu intensive. However, this > > > needs case by case analysis, tweaking etc. If there is no other alternative, > > > we might end up chasing the background workers and reduce their nice value. > > > > There shouldn't be that many workqueues that consume a lot of cpu cycles. > > The usual culprit is kswapd, IO related stuff (writeback, encryption), so it > > shouldn't be a long list and we want them identified anyway. > > > Sure. I have not done a complete study on which workers in our system can > compete with important tasks in other cgroups. We will have to do that to > adjust the workqueue priority so that the impact can be minimized. > kswapd0 is actually migratable to subgroup. But echo what Pavan said, the real world is not ideal and the problematice drivers are inactive when the use case is not activated in Android, e.g. connectivity, camera, etc. It is tricky sometimes to track all of those. > > > The problem at our hand (which you might be knowing already) is that, lets say > > > we have 2 cgroups in our setup and we want to prioritize UX over background. > > > IOW, reduce the cpu.shares of background cgroup. This helps in prioritizing > > > Task-A and Task-B over Task-X and Task-Y. However, each individual kworker > > > can potentially have CPU share equal to the entire UX cgroup. > > > > > > -kworker/0:0 > > > -kworker/1:0 > > > - UX > > > ----Task-A > > > ----Task-B > > > - background > > > ----Task-X > > > ----Task-Y > > > Hence we want to move all kernel threads to another cgroup so that this cgroup > > > will have CPU share equal to UX. > > > > > > The patch presented here allows us to create the above setup. Any other > > > alternative approaches to achieve the same without impacting any future > > > designs/requirements? > > > > Not quite the same but we already have > > /sys/devices/virtual/workqueue/cpumask which affects all unbound workqueues, > > so maybe a global default priority knob would help here? > > > > yeah, not exactly what we are looking for. It gives us the abiility to restrict > the priority of all unbound workqueues at the expense of not being able to > prioritize one workqueue over another workqueue. > Same here, Android used to have its cgroup setup like this, where the BG group can be starved too long potentially (and sometimes PI is not inevitable of course, that's the reason why I removed BG cgroup in Android (https://android-review.googlesource.com/q/topic:remove_bg_cgroup)). -Task-A -Task-B -kworker/0:0 - background ----Task-X ----Task-Y So having things left in root will post the same risk, > Thanks, > Pavan > -- > Qualcomm India Private Limited, on behalf of Qualcomm Innovation Center, Inc. > Qualcomm Innovation Center, Inc. is a member of Code Aurora Forum, a Linux Foundation Collaborative Project. >