Hello, KAMEZAWA. On Thu, Aug 25, 2011 at 09:39:58AM +0900, KAMEZAWA Hiroyuki wrote: > > +Called prior to moving one or more tasks into a cgroup; if the > > +subsystem returns an error, this will abort the attach operation. > > +@tset contains the tasks to be attached and is guaranteed to have at > > +least one task in it. If there are multiple, it's guaranteed that all > > +are from the same thread group, > > > Do this, "If there are multiple, it's guaranteed that all > are from the same thread group ", means the 'tset' contains > only one mm_struct ? Yes, CLONE_THREAD requires CLONE_SIGHAND which in turn requires CLONE_VM, so they'll all have the same mm. > And is it guaranteed that any task in tset will not be freed while > subsystem routine runs ? Yeap, that one is guaranteed. It might die but the the task_struct itself won't be released. However, I think it might be bette to block task exits during migration too. > > @@ -5460,8 +5460,9 @@ static void mem_cgroup_clear_mc(void) > > > > static int mem_cgroup_can_attach(struct cgroup_subsys *ss, > > struct cgroup *cgroup, > > - struct task_struct *p) > > + struct cgroup_taskset *tset) > > { > > + struct task_struct *p = cgroup_taskset_first(tset); > > int ret = 0; > > struct mem_cgroup *mem = mem_cgroup_from_cont(cgroup); > > > > Ah..hmm. I think this doesn't work as expected for memcg. > Maybe code like this will be required. Hmmm... the above is basically identity transformation of the existing code. If the above is broken, the current code is broken too. Is it? Thanks. -- tejun _______________________________________________ linux-pm mailing list linux-pm@xxxxxxxxxxxxxxxxxxxxxxxxxx https://lists.linux-foundation.org/mailman/listinfo/linux-pm