Hey Tejun, So Dmitry Shmidt recently noticed that with 4.4 based systems we're seeing quite a bit of performance overhead from __cgroup_procs_write().
With 4.4 tree as it stands, we're seeing __cgroup_procs_write() quite often take 10s of miliseconds to execute (with max times up in the 80ms range). While with 4.1 it was quite often in the single usec range, and max time values still in in sub-milisecond range. The majority of these performance regressions seem to come from the locking changes in: 3014dde762f6 ("cgroup: simplify threadgroup locking") and 1ed1328792ff ("sched, cgroup: replace signal_struct->group_rwsem with a global percpu_rwsem") Dmitry has found that by reverting these two changes (which don't revert easiliy), we can get back down to tens 10-100 usec range for most calls, with max values occasionally spiking to ~18ms. Those two commits do talk about performance regressions, that were supposedly alleviated by percpu_rwsem changes, but I'm not sure we are seeing this. In 1ed1328792ff, the commit talks about the write path being a fairly cold path, but with Android I worry this may not actually be the case, as Android uses cpuset cgroups to group tasks into foreground and background tasks, but this means when switching applications, tasks are migrated between cgroups. Putting an additional 80 milisecond delay on this adds potentially visible latencies on task switching. Reverting those two changes in the Android common.git tree doesn't feel like a good long term solution here, so I was wondering if you had any thoughts on how to further reduce the performance regression here? All the credit for finding this goes to Dmitry, I just was able to reproduce his results and thoguht we should bring it up for discussion here. thanks -john