On Fri, Nov 20, 2015 at 03:42:16PM +0300, Vladimir Davydov wrote: > On Thu, Nov 12, 2015 at 06:41:28PM -0500, Johannes Weiner wrote: > > There won't be any separate counters for socket memory consumed by > > protocols other than TCP in the future. Remove the indirection and > > I really want to believe you're right. And with vmpressure propagation > implemented properly you are likely to be right. > > However, we might still want to account other socket protos to > memcg->memory in the unified hierarchy, e.g. UDP, or SCTP, or whatever > else. Adding new consumers should be trivial, but it will break the > legacy usecase, where only TCP sockets are supposed to be accounted. > What about adding a check to sock_update_memcg() so that it would enable > accounting only for TCP sockets in case legacy hierarchy is used? Yup, I was thinking the same thing. But we can cross that bridge when we come to it and are actually adding further packet types. > For the same reason, I think we'd better rename memcg->tcp_mem to > something like memcg->sk_mem or we can even drop the cg_proto struct > altogether embedding its fields directly to mem_cgroup struct. > > Also, I don't see any reason to have tcp_memcontrol.c file. It's tiny > and with this patch it does not depend on tcp code any more. Let's move > it to memcontrol.c? I actually had all this at first, but then wondered if it makes more sense to keep the legacy code in isolation. Don't you think it would be easier to keep track of what's v1 and what's v2 if we keep the legacy stuff physically separate as much as possible? In particular I found that 'tcp_mem.' marker really useful while working on the code. In the same vein, tcp_memcontrol.c doesn't really hurt anybody and I'd expect it to remain mostly unopened and unchanged in the future. But if we merge it into memcontrol.c, that code will likely be in the way and we'd have to make it explicit somehow that this is not actually part of the new memory controller anymore. What do you think? > Other than that this patch looks OK to me. Thank you! -- To unsubscribe, send a message with 'unsubscribe linux-mm' in the body to majordomo@xxxxxxxxx. For more info on Linux MM, see: http://www.linux-mm.org/ . Don't email: <a href=mailto:"dont@xxxxxxxxx"> email@xxxxxxxxx </a>