Transparent huge page support on tmpfs. Please review. Intro ----- The goal of the project is to enable transparent huge page support on tmpfs. The whole patchset is based on Kirill's latest patchset about Transparent huge page cache v6. As the link below: https://lkml.org/lkml/2013/9/23/230 To further proof that the proposed changes are functional we try enable this feature for a more complex file system tmpfs besides ramfs. tmpfs comes with swap support which make is more usable. Design overview --------------- We share the exact same design from Kirill's work. However, due to the complexity of tmpfs, we do a lot of refactoring on the implementation. Changes since v1 --------------- * extract common code from add_to_page_cache_locked, so most of the function could be shared by shmem * remove all the ifdef for thp page cache as it's not necessary * completely rewrite shmem_writepage to handle huge page correctly * fix the problem about when to split huge page in shmem_fault * leave the GFP_MOVABLE flags untouched, from the current code, seems the migration code should have splitted the huge page before migration. Known problem --------------- We do try to make it work with swapping, but currently there are still some problem with it. Things are getting better with rewriting the shmem_wrigepage logic. However, it is still crashing after running into swapping for a whileI, I am debbugging it. It would be great to have more opinions about the design in the current patchset and where we should be heading. Ning Qu (13): mm, thp: extract the common code from add_to_page_cache_locked mm, thp, tmpfs: add function to alloc huge page for tmpfs mm, thp, tmpfs: support to add huge page into page cache for tmpfs mm, thp, tmpfs: handle huge page cases in shmem_getpage_gfp mm, thp, tmpfs: split huge page when moving from page cache to swap mm, thp, tmpfs: request huge page in shm_fault when needed mm, thp, tmpfs: initial support for huge page in write_begin/write_end in tmpfs mm, thp, tmpfs: handle huge page in shmem_undo_range for truncate mm, thp, tmpfs: huge page support in do_shmem_file_read mm, thp, tmpfs: huge page support in shmem_fallocate mm, thp, tmpfs: only alloc small pages in shmem_file_splice_read mm, thp, tmpfs: enable thp page cache in tmpfs mm, thp, tmpfs: misc fixes for thp tmpfs include/linux/huge_mm.h | 2 + include/linux/pagemap.h | 2 + mm/Kconfig | 4 +- mm/filemap.c | 91 ++++++--- mm/huge_memory.c | 27 +++ mm/shmem.c | 521 +++++++++++++++++++++++++++++++++++++++--------- 6 files changed, 522 insertions(+), 125 deletions(-) -- 1.8.4 -- 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>