Re: [RFC REPOST] cgroup: removing css reference drain wait duringcgroup removal

From: Tejun Heo
Date: Tue Mar 13 2012 - 12:39:17 EST


Hello, KAMEZAWA.

On Tue, Mar 13, 2012 at 03:11:48PM +0900, KAMEZAWA Hiroyuki wrote:
> The trouble for pre_destroy() is _not_ refcount, Memory cgroup has its own refcnt
> and use it internally. The problem is 'charges'. It's not related to refcnt.

Hmmm.... yeah, I'm not familiar with memcg internals at all. For
blkcg, refcnt matters but if it doesn't for memcg, great.

> Cgroup is designed to exists with 'tasks'. But memory may not be related to any
> task...just related to a cgroup.
>
> But ok, pre_destory() & rmdir() is complicated, I agree.
>
> Now, we prevent rmdir() if we can't move charges to its parent. If pre_destory()
> shouldn't fail, I can think of some alternatives.
>
> * move all charges to the parent and if it fails...move all charges to
> root cgroup.
> (drop_from_memory may not work well in swapless system.)

I think this one is better and this shouldn't fail if hierarchical
mode is in use, right?

> I think.. if pre_destory() never fails, we don't need pre_destroy().

For memcg maybe, blkcg still needs it.

> > The last one seems more tricky. On destruction of cgroup, the
> > charges are transferred to its parent and the parent may not have
> > enough room for that. Greg told me that this should only be a
> > problem for !hierarchical case. I think this can be dealt with by
> > dumping what's left over to root cgroup with a warning message.
>
> I don't like warning ;)

I agree this isn't perfect but then again failing rmdir isn't perfect
either and given that the condition can be wholly avoided in
hierarchical mode, which should be the default anyway (is there any
reason to keep flat mode except for backward compatibility?), I don't
think the trade off is too bad.

> I think we can do all in 'destroy()'.

That would be even better. I tried myself but that was a lot of code
I didn't have much idea about. If someone more familiar with memcg
can write up such patch, I owe a beer. :)

Thank you.

--
tejun
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@xxxxxxxxxxxxxxx
More majordomo info at http://vger.kernel.org/majordomo-info.html
Please read the FAQ at http://www.tux.org/lkml/