Hey, On Mon, Feb 02, 2015 at 10:26:44PM +0300, Konstantin Khlebnikov wrote: > Removing memcg pointer from struct page might be tricky. > It's not clear what to do with truncated pages: either link them > with lru differently or remove from lru right at truncate. > Swap cache pages have the same problem. Hmmm... idk, maybe play another trick with low bits of page->mapping and make it point to the cgroup after truncation? Do we even care tho? Can't we just push them to the root and forget about them? They are pretty transient after all, no? > Process of moving inodes from memcg to memcg is more or less doable. > Possible solution: keep at inode two pointers to memcg "old" and "new". > Each page will be accounted (and linked into corresponding lru) to one > of them. Separation to "old" and "new" pages could be done by flag on > struct page or by bordering page index stored in inode: pages where > index < border are accounted to the new memcg, the rest to the old. Yeah, pretty much the same scheme that the per-page cgroup writeback is using with lower bits of page->mem_cgroup should work with the bits moved to page->flags. > Keeping shared inodes in common ancestor is reasonable. > We could schedule asynchronous moving when somebody opens or mmaps > inode from outside of its current cgroup. But it's not clear when > inode should be moved into opposite direction: when inode should > become private and how detect if it's no longer shared. > > For example each inode could keep yet another pointer to memcg where > it will track subtree of cgroups where it was accessed in past 5 > minutes or so. And sometimes that informations goes into moving thread. > > Actually I don't see other options except that time-based estimation: > tracking all cgroups for each inode is too expensive, moving pages > from one lru to another is expensive too. So, moving inodes back and > forth at each access from the outside world is not an option. > That should be rare operation which runs in background or in reclaimer. Right, what strategy to use for migration is up for debate, even for moving to the common ancestor. e.g. should we do that on the first access? In the other direction, it get more interesting. Let's say if we decide to move back an inode to a descendant, what if that triggers OOM condition? Do we still go through it and cause OOM in the target? Do we even want automatic moving in this direction? For explicit cases, userland can do FADV_DONTNEED, I suppose. Thanks. -- tejun -- 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>